hevc: templatize intra_pred
This commit is contained in:
		
							parent
							
								
									04db5794cd
								
							
						
					
					
						commit
						a1c2b48018
					
				| @ -1240,18 +1240,18 @@ static int hls_transform_unit(HEVCContext *s, int x0, int y0, | |||||||
|         int trafo_size = 1 << log2_trafo_size; |         int trafo_size = 1 << log2_trafo_size; | ||||||
|         ff_hevc_set_neighbour_available(s, x0, y0, trafo_size, trafo_size); |         ff_hevc_set_neighbour_available(s, x0, y0, trafo_size, trafo_size); | ||||||
| 
 | 
 | ||||||
|         s->hpc.intra_pred(s, x0, y0, log2_trafo_size, 0); |         s->hpc.intra_pred[log2_trafo_size - 2](s, x0, y0, 0); | ||||||
|         if (log2_trafo_size > 2) { |         if (log2_trafo_size > 2) { | ||||||
|             trafo_size = trafo_size << (s->sps->hshift[1] - 1); |             trafo_size = trafo_size << (s->sps->hshift[1] - 1); | ||||||
|             ff_hevc_set_neighbour_available(s, x0, y0, trafo_size, trafo_size); |             ff_hevc_set_neighbour_available(s, x0, y0, trafo_size, trafo_size); | ||||||
|             s->hpc.intra_pred(s, x0, y0, log2_trafo_size - 1, 1); |             s->hpc.intra_pred[log2_trafo_size - 3](s, x0, y0, 1); | ||||||
|             s->hpc.intra_pred(s, x0, y0, log2_trafo_size - 1, 2); |             s->hpc.intra_pred[log2_trafo_size - 3](s, x0, y0, 2); | ||||||
|         } else if (blk_idx == 3) { |         } else if (blk_idx == 3) { | ||||||
|             trafo_size = trafo_size << s->sps->hshift[1]; |             trafo_size = trafo_size << s->sps->hshift[1]; | ||||||
|             ff_hevc_set_neighbour_available(s, xBase, yBase, |             ff_hevc_set_neighbour_available(s, xBase, yBase, | ||||||
|                                             trafo_size, trafo_size); |                                             trafo_size, trafo_size); | ||||||
|             s->hpc.intra_pred(s, xBase, yBase, log2_trafo_size, 1); |             s->hpc.intra_pred[log2_trafo_size - 2](s, xBase, yBase, 1); | ||||||
|             s->hpc.intra_pred(s, xBase, yBase, log2_trafo_size, 2); |             s->hpc.intra_pred[log2_trafo_size - 2](s, xBase, yBase, 2); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -712,8 +712,7 @@ typedef struct HEVCNAL { | |||||||
| struct HEVCContext; | struct HEVCContext; | ||||||
| 
 | 
 | ||||||
| typedef struct HEVCPredContext { | typedef struct HEVCPredContext { | ||||||
|     void (*intra_pred)(struct HEVCContext *s, int x0, int y0, |     void (*intra_pred[4])(struct HEVCContext *s, int x0, int y0, int c_idx); | ||||||
|                        int log2_size, int c_idx); |  | ||||||
| 
 | 
 | ||||||
|     void (*pred_planar[4])(uint8_t *src, const uint8_t *top, |     void (*pred_planar[4])(uint8_t *src, const uint8_t *top, | ||||||
|                            const uint8_t *left, ptrdiff_t stride); |                            const uint8_t *left, ptrdiff_t stride); | ||||||
|  | |||||||
| @ -40,7 +40,10 @@ void ff_hevc_pred_init(HEVCPredContext *hpc, int bit_depth) | |||||||
| #define FUNC(a, depth) a ## _ ## depth | #define FUNC(a, depth) a ## _ ## depth | ||||||
| 
 | 
 | ||||||
| #define HEVC_PRED(depth)                                \ | #define HEVC_PRED(depth)                                \ | ||||||
|     hpc->intra_pred      = FUNC(intra_pred, depth);     \ |     hpc->intra_pred[0]   = FUNC(intra_pred_2, depth);   \ | ||||||
|  |     hpc->intra_pred[1]   = FUNC(intra_pred_3, depth);   \ | ||||||
|  |     hpc->intra_pred[2]   = FUNC(intra_pred_4, depth);   \ | ||||||
|  |     hpc->intra_pred[3]   = FUNC(intra_pred_5, depth);   \ | ||||||
|     hpc->pred_planar[0]  = FUNC(pred_planar_0, depth);  \ |     hpc->pred_planar[0]  = FUNC(pred_planar_0, depth);  \ | ||||||
|     hpc->pred_planar[1]  = FUNC(pred_planar_1, depth);  \ |     hpc->pred_planar[1]  = FUNC(pred_planar_1, depth);  \ | ||||||
|     hpc->pred_planar[2]  = FUNC(pred_planar_2, depth);  \ |     hpc->pred_planar[2]  = FUNC(pred_planar_2, depth);  \ | ||||||
|  | |||||||
| @ -28,7 +28,8 @@ | |||||||
| 
 | 
 | ||||||
| #define POS(x, y) src[(x) + stride * (y)] | #define POS(x, y) src[(x) + stride * (y)] | ||||||
| 
 | 
 | ||||||
| static void FUNC(intra_pred)(HEVCContext *s, int x0, int y0, int log2_size, int c_idx) | static av_always_inline void FUNC(intra_pred)(HEVCContext *s, int x0, int y0, | ||||||
|  |                                               int log2_size, int c_idx) | ||||||
| { | { | ||||||
| #define PU(x) \ | #define PU(x) \ | ||||||
|     ((x) >> s->sps->log2_min_pu_size) |     ((x) >> s->sps->log2_min_pu_size) | ||||||
| @ -349,6 +350,19 @@ static void FUNC(intra_pred)(HEVCContext *s, int x0, int y0, int log2_size, int | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #define INTRA_PRED(size)                                                            \ | ||||||
|  | static void FUNC(intra_pred_ ## size)(HEVCContext *s, int x0, int y0, int c_idx)    \ | ||||||
|  | {                                                                                   \ | ||||||
|  |     FUNC(intra_pred)(s, x0, y0, size, c_idx);                                       \ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | INTRA_PRED(2) | ||||||
|  | INTRA_PRED(3) | ||||||
|  | INTRA_PRED(4) | ||||||
|  | INTRA_PRED(5) | ||||||
|  | 
 | ||||||
|  | #undef INTRA_PRED | ||||||
|  | 
 | ||||||
| static av_always_inline void FUNC(pred_planar)(uint8_t *_src, const uint8_t *_top, | static av_always_inline void FUNC(pred_planar)(uint8_t *_src, const uint8_t *_top, | ||||||
|                                   const uint8_t *_left, ptrdiff_t stride, |                                   const uint8_t *_left, ptrdiff_t stride, | ||||||
|                                   int trafo_size) |                                   int trafo_size) | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user