00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021 #include <stdint.h>
00022
00023 #include "libavcodec/avcodec.h"
00024 #include "libavcodec/dsputil.h"
00025 #include "dsputil_arm.h"
00026
00027 void ff_simple_idct_armv6(DCTELEM *data);
00028 void ff_simple_idct_put_armv6(uint8_t *dest, int line_size, DCTELEM *data);
00029 void ff_simple_idct_add_armv6(uint8_t *dest, int line_size, DCTELEM *data);
00030
00031 void ff_put_pixels16_armv6(uint8_t *, const uint8_t *, int, int);
00032 void ff_put_pixels16_x2_armv6(uint8_t *, const uint8_t *, int, int);
00033 void ff_put_pixels16_y2_armv6(uint8_t *, const uint8_t *, int, int);
00034
00035 void ff_put_pixels16_x2_no_rnd_armv6(uint8_t *, const uint8_t *, int, int);
00036 void ff_put_pixels16_y2_no_rnd_armv6(uint8_t *, const uint8_t *, int, int);
00037
00038 void ff_avg_pixels16_armv6(uint8_t *, const uint8_t *, int, int);
00039
00040 void ff_put_pixels8_armv6(uint8_t *, const uint8_t *, int, int);
00041 void ff_put_pixels8_x2_armv6(uint8_t *, const uint8_t *, int, int);
00042 void ff_put_pixels8_y2_armv6(uint8_t *, const uint8_t *, int, int);
00043
00044 void ff_put_pixels8_x2_no_rnd_armv6(uint8_t *, const uint8_t *, int, int);
00045 void ff_put_pixels8_y2_no_rnd_armv6(uint8_t *, const uint8_t *, int, int);
00046
00047 void ff_avg_pixels8_armv6(uint8_t *, const uint8_t *, int, int);
00048
00049 void ff_add_pixels_clamped_armv6(const DCTELEM *block,
00050 uint8_t *restrict pixels,
00051 int line_size);
00052
00053 void ff_get_pixels_armv6(DCTELEM *block, const uint8_t *pixels, int stride);
00054 void ff_diff_pixels_armv6(DCTELEM *block, const uint8_t *s1,
00055 const uint8_t *s2, int stride);
00056
00057 int ff_pix_abs16_armv6(void *s, uint8_t *blk1, uint8_t *blk2,
00058 int line_size, int h);
00059 int ff_pix_abs16_x2_armv6(void *s, uint8_t *blk1, uint8_t *blk2,
00060 int line_size, int h);
00061 int ff_pix_abs16_y2_armv6(void *s, uint8_t *blk1, uint8_t *blk2,
00062 int line_size, int h);
00063
00064 int ff_pix_abs8_armv6(void *s, uint8_t *blk1, uint8_t *blk2,
00065 int line_size, int h);
00066
00067 int ff_sse16_armv6(void *s, uint8_t *blk1, uint8_t *blk2,
00068 int line_size, int h);
00069
00070 int ff_pix_norm1_armv6(uint8_t *pix, int line_size);
00071 int ff_pix_sum_armv6(uint8_t *pix, int line_size);
00072
00073 void av_cold ff_dsputil_init_armv6(DSPContext* c, AVCodecContext *avctx)
00074 {
00075 const int high_bit_depth = avctx->codec_id == CODEC_ID_H264 && avctx->bits_per_raw_sample > 8;
00076
00077 if (!avctx->lowres && (avctx->idct_algo == FF_IDCT_AUTO ||
00078 avctx->idct_algo == FF_IDCT_SIMPLEARMV6)) {
00079 c->idct_put = ff_simple_idct_put_armv6;
00080 c->idct_add = ff_simple_idct_add_armv6;
00081 c->idct = ff_simple_idct_armv6;
00082 c->idct_permutation_type = FF_LIBMPEG2_IDCT_PERM;
00083 }
00084
00085 if (!high_bit_depth) {
00086 c->put_pixels_tab[0][0] = ff_put_pixels16_armv6;
00087 c->put_pixels_tab[0][1] = ff_put_pixels16_x2_armv6;
00088 c->put_pixels_tab[0][2] = ff_put_pixels16_y2_armv6;
00089
00090 c->put_pixels_tab[1][0] = ff_put_pixels8_armv6;
00091 c->put_pixels_tab[1][1] = ff_put_pixels8_x2_armv6;
00092 c->put_pixels_tab[1][2] = ff_put_pixels8_y2_armv6;
00093
00094
00095 c->put_no_rnd_pixels_tab[0][0] = ff_put_pixels16_armv6;
00096 c->put_no_rnd_pixels_tab[0][1] = ff_put_pixels16_x2_no_rnd_armv6;
00097 c->put_no_rnd_pixels_tab[0][2] = ff_put_pixels16_y2_no_rnd_armv6;
00098
00099 c->put_no_rnd_pixels_tab[1][0] = ff_put_pixels8_armv6;
00100 c->put_no_rnd_pixels_tab[1][1] = ff_put_pixels8_x2_no_rnd_armv6;
00101 c->put_no_rnd_pixels_tab[1][2] = ff_put_pixels8_y2_no_rnd_armv6;
00102
00103
00104 c->avg_pixels_tab[0][0] = ff_avg_pixels16_armv6;
00105 c->avg_pixels_tab[1][0] = ff_avg_pixels8_armv6;
00106 }
00107
00108 c->add_pixels_clamped = ff_add_pixels_clamped_armv6;
00109 c->get_pixels = ff_get_pixels_armv6;
00110 c->diff_pixels = ff_diff_pixels_armv6;
00111
00112 c->pix_abs[0][0] = ff_pix_abs16_armv6;
00113 c->pix_abs[0][1] = ff_pix_abs16_x2_armv6;
00114 c->pix_abs[0][2] = ff_pix_abs16_y2_armv6;
00115
00116 c->pix_abs[1][0] = ff_pix_abs8_armv6;
00117
00118 c->sad[0] = ff_pix_abs16_armv6;
00119 c->sad[1] = ff_pix_abs8_armv6;
00120
00121 c->sse[0] = ff_sse16_armv6;
00122
00123 c->pix_norm1 = ff_pix_norm1_armv6;
00124 c->pix_sum = ff_pix_sum_armv6;
00125 }