1cabdff1aSopenharmony_ci/* 2cabdff1aSopenharmony_ci * This file is part of FFmpeg. 3cabdff1aSopenharmony_ci * 4cabdff1aSopenharmony_ci * FFmpeg is free software; you can redistribute it and/or 5cabdff1aSopenharmony_ci * modify it under the terms of the GNU Lesser General Public 6cabdff1aSopenharmony_ci * License as published by the Free Software Foundation; either 7cabdff1aSopenharmony_ci * version 2.1 of the License, or (at your option) any later version. 8cabdff1aSopenharmony_ci * 9cabdff1aSopenharmony_ci * FFmpeg is distributed in the hope that it will be useful, 10cabdff1aSopenharmony_ci * but WITHOUT ANY WARRANTY; without even the implied warranty of 11cabdff1aSopenharmony_ci * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 12cabdff1aSopenharmony_ci * Lesser General Public License for more details. 13cabdff1aSopenharmony_ci * 14cabdff1aSopenharmony_ci * You should have received a copy of the GNU Lesser General Public 15cabdff1aSopenharmony_ci * License along with FFmpeg; if not, write to the Free Software 16cabdff1aSopenharmony_ci * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA 17cabdff1aSopenharmony_ci */ 18cabdff1aSopenharmony_ci 19cabdff1aSopenharmony_ci#include <stdint.h> 20cabdff1aSopenharmony_ci 21cabdff1aSopenharmony_ci#include "config.h" 22cabdff1aSopenharmony_ci#include "libavutil/attributes.h" 23cabdff1aSopenharmony_ci#include "utvideodsp.h" 24cabdff1aSopenharmony_ci 25cabdff1aSopenharmony_cistatic void restore_rgb_planes_c(uint8_t *src_r, 26cabdff1aSopenharmony_ci uint8_t *src_g, 27cabdff1aSopenharmony_ci uint8_t *src_b, 28cabdff1aSopenharmony_ci ptrdiff_t linesize_r, 29cabdff1aSopenharmony_ci ptrdiff_t linesize_g, 30cabdff1aSopenharmony_ci ptrdiff_t linesize_b, 31cabdff1aSopenharmony_ci int width, int height) 32cabdff1aSopenharmony_ci{ 33cabdff1aSopenharmony_ci uint8_t r, g, b; 34cabdff1aSopenharmony_ci int i, j; 35cabdff1aSopenharmony_ci 36cabdff1aSopenharmony_ci for (j = 0; j < height; j++) { 37cabdff1aSopenharmony_ci for (i = 0; i < width; i++) { 38cabdff1aSopenharmony_ci r = src_r[i]; 39cabdff1aSopenharmony_ci g = src_g[i]; 40cabdff1aSopenharmony_ci b = src_b[i]; 41cabdff1aSopenharmony_ci src_r[i] = r + g - 0x80; 42cabdff1aSopenharmony_ci src_b[i] = b + g - 0x80; 43cabdff1aSopenharmony_ci } 44cabdff1aSopenharmony_ci src_r += linesize_r; 45cabdff1aSopenharmony_ci src_g += linesize_g; 46cabdff1aSopenharmony_ci src_b += linesize_b; 47cabdff1aSopenharmony_ci } 48cabdff1aSopenharmony_ci} 49cabdff1aSopenharmony_ci 50cabdff1aSopenharmony_cistatic void restore_rgb_planes10_c(uint16_t *src_r, 51cabdff1aSopenharmony_ci uint16_t *src_g, 52cabdff1aSopenharmony_ci uint16_t *src_b, 53cabdff1aSopenharmony_ci ptrdiff_t linesize_r, 54cabdff1aSopenharmony_ci ptrdiff_t linesize_g, 55cabdff1aSopenharmony_ci ptrdiff_t linesize_b, 56cabdff1aSopenharmony_ci int width, int height) 57cabdff1aSopenharmony_ci{ 58cabdff1aSopenharmony_ci int r, g, b; 59cabdff1aSopenharmony_ci int i, j; 60cabdff1aSopenharmony_ci 61cabdff1aSopenharmony_ci for (j = 0; j < height; j++) { 62cabdff1aSopenharmony_ci for (i = 0; i < width; i++) { 63cabdff1aSopenharmony_ci r = src_r[i]; 64cabdff1aSopenharmony_ci g = src_g[i]; 65cabdff1aSopenharmony_ci b = src_b[i]; 66cabdff1aSopenharmony_ci src_r[i] = (r + g - 0x200) & 0x3FF; 67cabdff1aSopenharmony_ci src_b[i] = (b + g - 0x200) & 0x3FF; 68cabdff1aSopenharmony_ci } 69cabdff1aSopenharmony_ci src_r += linesize_r; 70cabdff1aSopenharmony_ci src_g += linesize_g; 71cabdff1aSopenharmony_ci src_b += linesize_b; 72cabdff1aSopenharmony_ci } 73cabdff1aSopenharmony_ci} 74cabdff1aSopenharmony_ci 75cabdff1aSopenharmony_ciav_cold void ff_utvideodsp_init(UTVideoDSPContext *c) 76cabdff1aSopenharmony_ci{ 77cabdff1aSopenharmony_ci c->restore_rgb_planes = restore_rgb_planes_c; 78cabdff1aSopenharmony_ci c->restore_rgb_planes10 = restore_rgb_planes10_c; 79cabdff1aSopenharmony_ci 80cabdff1aSopenharmony_ci#if ARCH_X86 81cabdff1aSopenharmony_ci ff_utvideodsp_init_x86(c); 82cabdff1aSopenharmony_ci#endif 83cabdff1aSopenharmony_ci} 84