Spaces:
Runtime error
Runtime error
/* | |
* This file is part of FFmpeg. | |
* | |
* FFmpeg 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. | |
* | |
* FFmpeg 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 FFmpeg; if not, write to the Free Software | |
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | |
*/ | |
void ff_hscale16to15_4_neon_asm(int shift, int16_t *_dst, int dstW, | |
const uint8_t *_src, const int16_t *filter, | |
const int32_t *filterPos, int filterSize); | |
void ff_hscale16to15_X8_neon_asm(int shift, int16_t *_dst, int dstW, | |
const uint8_t *_src, const int16_t *filter, | |
const int32_t *filterPos, int filterSize); | |
void ff_hscale16to15_X4_neon_asm(int shift, int16_t *_dst, int dstW, | |
const uint8_t *_src, const int16_t *filter, | |
const int32_t *filterPos, int filterSize); | |
void ff_hscale16to19_4_neon_asm(int shift, int16_t *_dst, int dstW, | |
const uint8_t *_src, const int16_t *filter, | |
const int32_t *filterPos, int filterSize); | |
void ff_hscale16to19_X8_neon_asm(int shift, int16_t *_dst, int dstW, | |
const uint8_t *_src, const int16_t *filter, | |
const int32_t *filterPos, int filterSize); | |
void ff_hscale16to19_X4_neon_asm(int shift, int16_t *_dst, int dstW, | |
const uint8_t *_src, const int16_t *filter, | |
const int32_t *filterPos, int filterSize); | |
static void ff_hscale16to15_4_neon(SwsContext *c, int16_t *_dst, int dstW, | |
const uint8_t *_src, const int16_t *filter, | |
const int32_t *filterPos, int filterSize) | |
{ | |
const AVPixFmtDescriptor *desc = av_pix_fmt_desc_get(c->srcFormat); | |
int sh = desc->comp[0].depth - 1; | |
if (sh<15) { | |
sh = isAnyRGB(c->srcFormat) || c->srcFormat==AV_PIX_FMT_PAL8 ? 13 : (desc->comp[0].depth - 1); | |
} else if (desc->flags & AV_PIX_FMT_FLAG_FLOAT) { /* float input are process like uint 16bpc */ | |
sh = 16 - 1; | |
} | |
ff_hscale16to15_4_neon_asm(sh, _dst, dstW, _src, filter, filterPos, filterSize); | |
} | |
static void ff_hscale16to15_X8_neon(SwsContext *c, int16_t *_dst, int dstW, | |
const uint8_t *_src, const int16_t *filter, | |
const int32_t *filterPos, int filterSize) | |
{ | |
const AVPixFmtDescriptor *desc = av_pix_fmt_desc_get(c->srcFormat); | |
int sh = desc->comp[0].depth - 1; | |
if (sh<15) { | |
sh = isAnyRGB(c->srcFormat) || c->srcFormat==AV_PIX_FMT_PAL8 ? 13 : (desc->comp[0].depth - 1); | |
} else if (desc->flags & AV_PIX_FMT_FLAG_FLOAT) { /* float input are process like uint 16bpc */ | |
sh = 16 - 1; | |
} | |
ff_hscale16to15_X8_neon_asm(sh, _dst, dstW, _src, filter, filterPos, filterSize); | |
} | |
static void ff_hscale16to15_X4_neon(SwsContext *c, int16_t *_dst, int dstW, | |
const uint8_t *_src, const int16_t *filter, | |
const int32_t *filterPos, int filterSize) | |
{ | |
const AVPixFmtDescriptor *desc = av_pix_fmt_desc_get(c->srcFormat); | |
int sh = desc->comp[0].depth - 1; | |
if (sh<15) { | |
sh = isAnyRGB(c->srcFormat) || c->srcFormat==AV_PIX_FMT_PAL8 ? 13 : (desc->comp[0].depth - 1); | |
} else if (desc->flags & AV_PIX_FMT_FLAG_FLOAT) { /* float input are process like uint 16bpc */ | |
sh = 16 - 1; | |
} | |
ff_hscale16to15_X4_neon_asm(sh, _dst, dstW, _src, filter, filterPos, filterSize); | |
} | |
static void ff_hscale16to19_4_neon(SwsContext *c, int16_t *_dst, int dstW, | |
const uint8_t *_src, const int16_t *filter, | |
const int32_t *filterPos, int filterSize) | |
{ | |
const AVPixFmtDescriptor *desc = av_pix_fmt_desc_get(c->srcFormat); | |
int bits = desc->comp[0].depth - 1; | |
int sh = bits - 4; | |
if ((isAnyRGB(c->srcFormat) || c->srcFormat==AV_PIX_FMT_PAL8) && desc->comp[0].depth<16) { | |
sh = 9; | |
} else if (desc->flags & AV_PIX_FMT_FLAG_FLOAT) { /* float input are process like uint 16bpc */ | |
sh = 16 - 1 - 4; | |
} | |
ff_hscale16to19_4_neon_asm(sh, _dst, dstW, _src, filter, filterPos, filterSize); | |
} | |
static void ff_hscale16to19_X8_neon(SwsContext *c, int16_t *_dst, int dstW, | |
const uint8_t *_src, const int16_t *filter, | |
const int32_t *filterPos, int filterSize) | |
{ | |
const AVPixFmtDescriptor *desc = av_pix_fmt_desc_get(c->srcFormat); | |
int bits = desc->comp[0].depth - 1; | |
int sh = bits - 4; | |
if ((isAnyRGB(c->srcFormat) || c->srcFormat==AV_PIX_FMT_PAL8) && desc->comp[0].depth<16) { | |
sh = 9; | |
} else if (desc->flags & AV_PIX_FMT_FLAG_FLOAT) { /* float input are process like uint 16bpc */ | |
sh = 16 - 1 - 4; | |
} | |
ff_hscale16to19_X8_neon_asm(sh, _dst, dstW, _src, filter, filterPos, filterSize); | |
} | |
static void ff_hscale16to19_X4_neon(SwsContext *c, int16_t *_dst, int dstW, | |
const uint8_t *_src, const int16_t *filter, | |
const int32_t *filterPos, int filterSize) | |
{ | |
const AVPixFmtDescriptor *desc = av_pix_fmt_desc_get(c->srcFormat); | |
int bits = desc->comp[0].depth - 1; | |
int sh = bits - 4; | |
if ((isAnyRGB(c->srcFormat) || c->srcFormat==AV_PIX_FMT_PAL8) && desc->comp[0].depth<16) { | |
sh = 9; | |
} else if (desc->flags & AV_PIX_FMT_FLAG_FLOAT) { /* float input are process like uint 16bpc */ | |
sh = 16 - 1 - 4; | |
} | |
ff_hscale16to19_X4_neon_asm(sh, _dst, dstW, _src, filter, filterPos, filterSize); | |
} | |
ALL_SCALE_FUNCS(neon); | |
void ff_yuv2planeX_8_neon(const int16_t *filter, int filterSize, | |
const int16_t **src, uint8_t *dest, int dstW, | |
const uint8_t *dither, int offset); | |
void ff_yuv2plane1_8_neon( | |
const int16_t *src, | |
uint8_t *dest, | |
int dstW, | |
const uint8_t *dither, | |
int offset); | |
av_cold void ff_sws_init_swscale_aarch64(SwsContext *c) | |
{ | |
int cpu_flags = av_get_cpu_flags(); | |
if (have_neon(cpu_flags)) { | |
ASSIGN_SCALE_FUNC(c->hyScale, c->hLumFilterSize, neon); | |
ASSIGN_SCALE_FUNC(c->hcScale, c->hChrFilterSize, neon); | |
ASSIGN_VSCALE_FUNC(c->yuv2plane1, neon); | |
if (c->dstBpc == 8) { | |
c->yuv2planeX = ff_yuv2planeX_8_neon; | |
} | |
} | |
} | |