/* * Copyright (c) 2010 The VP8 project authors. All Rights Reserved. * * Use of this source code is governed by a BSD-style license and patent * grant that can be found in the LICENSE file in the root of the source * tree. All contributing project authors may be found in the AUTHORS * file in the root of the source tree. */ #include "vpx_ports/config.h" #include "recon.h" #include "blockd.h" void vp8_recon_b_c ( unsigned char *pred_ptr, short *diff_ptr, unsigned char *dst_ptr, int stride ) { int r, c; for (r = 0; r < 4; r++) { for (c = 0; c < 4; c++) { int a = diff_ptr[c] + pred_ptr[c] ; if (a < 0) a = 0; if (a > 255) a = 255; dst_ptr[c] = (unsigned char) a ; } dst_ptr += stride; diff_ptr += 16; pred_ptr += 16; } } void vp8_recon4b_c ( unsigned char *pred_ptr, short *diff_ptr, unsigned char *dst_ptr, int stride ) { int r, c; for (r = 0; r < 4; r++) { for (c = 0; c < 16; c++) { int a = diff_ptr[c] + pred_ptr[c] ; if (a < 0) a = 0; if (a > 255) a = 255; dst_ptr[c] = (unsigned char) a ; } dst_ptr += stride; diff_ptr += 16; pred_ptr += 16; } } void vp8_recon2b_c ( unsigned char *pred_ptr, short *diff_ptr, unsigned char *dst_ptr, int stride ) { int r, c; for (r = 0; r < 4; r++) { for (c = 0; c < 8; c++) { int a = diff_ptr[c] + pred_ptr[c] ; if (a < 0) a = 0; if (a > 255) a = 255; dst_ptr[c] = (unsigned char) a ; } dst_ptr += stride; diff_ptr += 8; pred_ptr += 8; } } void vp8_recon16x16mby(const vp8_recon_rtcd_vtable_t *rtcd, MACROBLOCKD *x) { int i; for (i = 0; i < 16; i += 4) { BLOCKD *b = &x->block[i]; RECON_INVOKE(rtcd, recon4)(b->predictor, b->diff, *(b->base_dst) + b->dst, b->dst_stride); } } void vp8_recon16x16mb(const vp8_recon_rtcd_vtable_t *rtcd, MACROBLOCKD *x) { int i; for (i = 0; i < 16; i += 4) { BLOCKD *b = &x->block[i]; RECON_INVOKE(rtcd, recon4)(b->predictor, b->diff, *(b->base_dst) + b->dst, b->dst_stride); } for (i = 16; i < 24; i += 2) { BLOCKD *b = &x->block[i]; RECON_INVOKE(rtcd, recon2)(b->predictor, b->diff, *(b->base_dst) + b->dst, b->dst_stride); } }