|
29 | 29 |
|
30 | 30 | #define CLIP_MIN (1 << 2) ///< minimum value for clipping resulting pixels |
31 | 31 | #define CLIP_MAX_10 (1 << 10) - CLIP_MIN - 1 ///< maximum value for clipping resulting pixels |
| 32 | +#define CLIP_MAX_12 (1 << 12) - CLIP_MIN - 1 ///< maximum value for clipping resulting pixels |
32 | 33 |
|
33 | 34 | #define CLIP_10(x) (av_clip((x), CLIP_MIN, CLIP_MAX_10)) |
| 35 | +#define CLIP_12(x) (av_clip((x), CLIP_MIN, CLIP_MAX_12)) |
34 | 36 |
|
35 | 37 | /** |
36 | 38 | * Add bias value, clamp and output pixels of a slice |
37 | 39 | */ |
38 | | -static void put_pixels_10(uint16_t *dst, ptrdiff_t linesize, const int16_t *in) |
39 | | -{ |
| 40 | + |
| 41 | +static inline void put_pixel(uint16_t *dst, ptrdiff_t linesize, const int16_t *in, int bits_per_raw_sample) { |
40 | 42 | int x, y, src_offset, dst_offset; |
41 | 43 |
|
42 | 44 | for (y = 0, dst_offset = 0; y < 8; y++, dst_offset += linesize) { |
43 | 45 | for (x = 0; x < 8; x++) { |
44 | 46 | src_offset = (y << 3) + x; |
45 | 47 |
|
46 | | - dst[dst_offset + x] = CLIP_10(in[src_offset]); |
| 48 | + if (bits_per_raw_sample == 10) { |
| 49 | + dst[dst_offset + x] = CLIP_10(in[src_offset]); |
| 50 | + } else {//12b |
| 51 | + dst[dst_offset + x] = CLIP_12(in[src_offset]); |
| 52 | + } |
47 | 53 | } |
48 | 54 | } |
49 | 55 | } |
50 | 56 |
|
| 57 | +static void put_pixels_10(uint16_t *dst, ptrdiff_t linesize, const int16_t *in) |
| 58 | +{ |
| 59 | + put_pixel(dst, linesize, in, 10); |
| 60 | +} |
| 61 | + |
| 62 | +static void put_pixels_12(uint16_t *dst, ptrdiff_t linesize, const int16_t *in) |
| 63 | +{ |
| 64 | + put_pixel(dst, linesize, in, 12); |
| 65 | +} |
| 66 | + |
51 | 67 | static void prores_idct_put_10_c(uint16_t *out, ptrdiff_t linesize, int16_t *block, const int16_t *qmat) |
52 | 68 | { |
53 | 69 | ff_prores_idct_10(block, qmat); |
54 | 70 | put_pixels_10(out, linesize >> 1, block); |
55 | 71 | } |
56 | 72 |
|
| 73 | +static void prores_idct_put_12_c(uint16_t *out, ptrdiff_t linesize, int16_t *block, const int16_t *qmat) |
| 74 | +{ |
| 75 | + ff_prores_idct_12(block, qmat); |
| 76 | + put_pixels_12(out, linesize >> 1, block); |
| 77 | +} |
| 78 | + |
57 | 79 | av_cold int ff_proresdsp_init(ProresDSPContext *dsp, AVCodecContext *avctx) |
58 | 80 | { |
59 | 81 | if (avctx->bits_per_raw_sample == 10) { |
60 | 82 | dsp->idct_put = prores_idct_put_10_c; |
61 | 83 | dsp->idct_permutation_type = FF_IDCT_PERM_NONE; |
| 84 | + } else if (avctx->bits_per_raw_sample == 12) { |
| 85 | + dsp->idct_put = prores_idct_put_12_c; |
| 86 | + dsp->idct_permutation_type = FF_IDCT_PERM_NONE; |
62 | 87 | } else { |
63 | 88 | return AVERROR_BUG; |
64 | 89 | } |
|
0 commit comments