libavcodec/high_bit_depth.h
683df9bf
 /*
  * This file is part of Libav.
  *
  * Libav is free software; you can redistribute it and/or
  * modify it under the terms of the GNU Lesser General Public
  * License as published by the Free Software Foundation; either
  * version 2.1 of the License, or (at your option) any later version.
  *
  * Libav is distributed in the hope that it will be useful,
  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  * Lesser General Public License for more details.
  *
  * You should have received a copy of the GNU Lesser General Public
  * License along with Libav; if not, write to the Free Software
  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  */
 
19a0729b
 #include "dsputil.h"
 
 #ifndef BIT_DEPTH
 #define BIT_DEPTH 8
 #endif
 
 #ifdef AVCODEC_H264_HIGH_DEPTH_H
 #   undef pixel
 #   undef pixel2
 #   undef pixel4
 #   undef dctcoef
 #   undef INIT_CLIP
 #   undef no_rnd_avg_pixel4
 #   undef rnd_avg_pixel4
 #   undef AV_RN2P
 #   undef AV_RN4P
2caf19e9
 #   undef AV_RN4PA
19a0729b
 #   undef AV_WN2P
 #   undef AV_WN4P
 #   undef AV_WN4PA
 #   undef CLIP
 #   undef FUNC
 #   undef FUNCC
 #   undef av_clip_pixel
 #   undef PIXEL_SPLAT_X4
 #else
 #   define AVCODEC_H264_HIGH_DEPTH_H
 #   define CLIP_PIXEL(depth)\
     static inline uint16_t av_clip_pixel_ ## depth (int p)\
     {\
         const int pixel_max = (1 << depth)-1;\
         return (p & ~pixel_max) ? (-p)>>31 & pixel_max : p;\
     }
 
 CLIP_PIXEL( 9)
 CLIP_PIXEL(10)
 #endif
 
 #if BIT_DEPTH > 8
 #   define pixel  uint16_t
 #   define pixel2 uint32_t
 #   define pixel4 uint64_t
 #   define dctcoef int32_t
 
 #   define INIT_CLIP
 #   define no_rnd_avg_pixel4 no_rnd_avg64
 #   define    rnd_avg_pixel4    rnd_avg64
 #   define AV_RN2P  AV_RN32
 #   define AV_RN4P  AV_RN64
2caf19e9
 #   define AV_RN4PA AV_RN64A
19a0729b
 #   define AV_WN2P  AV_WN32
 #   define AV_WN4P  AV_WN64
 #   define AV_WN4PA AV_WN64A
 #   define PIXEL_SPLAT_X4(x) ((x)*0x0001000100010001ULL)
 #else
 #   define pixel  uint8_t
 #   define pixel2 uint16_t
 #   define pixel4 uint32_t
 #   define dctcoef int16_t
 
 #   define INIT_CLIP uint8_t *cm = ff_cropTbl + MAX_NEG_CROP;
 #   define no_rnd_avg_pixel4 no_rnd_avg32
 #   define    rnd_avg_pixel4    rnd_avg32
 #   define AV_RN2P  AV_RN16
 #   define AV_RN4P  AV_RN32
2caf19e9
 #   define AV_RN4PA AV_RN32A
19a0729b
 #   define AV_WN2P  AV_WN16
 #   define AV_WN4P  AV_WN32
 #   define AV_WN4PA AV_WN32A
 #   define PIXEL_SPLAT_X4(x) ((x)*0x01010101U)
 #endif
 
 #if BIT_DEPTH == 8
 #   define av_clip_pixel(a) av_clip_uint8(a)
 #   define CLIP(a) cm[a]
 #   define FUNC(a)  a ## _8
 #   define FUNCC(a) a ## _8_c
 #elif BIT_DEPTH == 9
 #   define av_clip_pixel(a) av_clip_pixel_9(a)
 #   define CLIP(a)          av_clip_pixel_9(a)
 #   define FUNC(a)  a ## _9
 #   define FUNCC(a) a ## _9_c
 #elif BIT_DEPTH == 10
 #   define av_clip_pixel(a) av_clip_pixel_10(a)
 #   define CLIP(a)          av_clip_pixel_10(a)
 #   define FUNC(a)  a ## _10
 #   define FUNCC(a) a ## _10_c
 #endif