
This avoids explicitly casting them to 'int' later. These methods were already called with signed int arguments for pitch, so this also avoids int -> unsigned int -> int conversion. Change-Id: I2129f5ceff8f2525a188ee3ae52f9fe7067bd2e3
201 lines
7.4 KiB
C
201 lines
7.4 KiB
C
/*
|
|
* Copyright (c) 2016, Alliance for Open Media. All rights reserved
|
|
*
|
|
* This source code is subject to the terms of the BSD 2 Clause License and
|
|
* the Alliance for Open Media Patent License 1.0. If the BSD 2 Clause License
|
|
* was not distributed with this source code in the LICENSE file, you can
|
|
* obtain it at www.aomedia.org/license/software. If the Alliance for Open
|
|
* Media Patent License 1.0 was not distributed with this source code in the
|
|
* PATENTS file, you can obtain it at www.aomedia.org/license/patent.
|
|
*/
|
|
|
|
#include "./aom_scale_rtcd.h"
|
|
#include "aom_scale/aom_scale.h"
|
|
#include "aom_mem/aom_mem.h"
|
|
/****************************************************************************
|
|
* Imports
|
|
****************************************************************************/
|
|
|
|
/****************************************************************************
|
|
*
|
|
*
|
|
* INPUTS : const unsigned char *source : Pointer to source data.
|
|
* unsigned int source_width : Stride of source.
|
|
* unsigned char *dest : Pointer to destination data.
|
|
* unsigned int dest_width : Stride of destination
|
|
* (NOT USED).
|
|
*
|
|
* OUTPUTS : None.
|
|
*
|
|
* RETURNS : void
|
|
*
|
|
* FUNCTION : Copies horizontal line of pixels from source to
|
|
* destination scaling up by 4 to 5.
|
|
*
|
|
* SPECIAL NOTES : None.
|
|
*
|
|
****************************************************************************/
|
|
void aom_horizontal_line_5_4_scale_c(const unsigned char *source,
|
|
unsigned int source_width,
|
|
unsigned char *dest,
|
|
unsigned int dest_width) {
|
|
const unsigned char *const source_end = source + source_width;
|
|
(void)dest_width;
|
|
|
|
while (source < source_end) {
|
|
const unsigned int a = source[0];
|
|
const unsigned int b = source[1];
|
|
const unsigned int c = source[2];
|
|
const unsigned int d = source[3];
|
|
const unsigned int e = source[4];
|
|
|
|
dest[0] = (unsigned char)a;
|
|
dest[1] = (unsigned char)((b * 192 + c * 64 + 128) >> 8);
|
|
dest[2] = (unsigned char)((c * 128 + d * 128 + 128) >> 8);
|
|
dest[3] = (unsigned char)((d * 64 + e * 192 + 128) >> 8);
|
|
|
|
source += 5;
|
|
dest += 4;
|
|
}
|
|
}
|
|
|
|
void aom_vertical_band_5_4_scale_c(unsigned char *source, int src_pitch,
|
|
unsigned char *dest, int dest_pitch,
|
|
unsigned int dest_width) {
|
|
const unsigned char *const dest_end = dest + dest_width;
|
|
while (dest < dest_end) {
|
|
const unsigned int a = source[0 * src_pitch];
|
|
const unsigned int b = source[1 * src_pitch];
|
|
const unsigned int c = source[2 * src_pitch];
|
|
const unsigned int d = source[3 * src_pitch];
|
|
const unsigned int e = source[4 * src_pitch];
|
|
|
|
dest[0 * dest_pitch] = (unsigned char)a;
|
|
dest[1 * dest_pitch] = (unsigned char)((b * 192 + c * 64 + 128) >> 8);
|
|
dest[2 * dest_pitch] = (unsigned char)((c * 128 + d * 128 + 128) >> 8);
|
|
dest[3 * dest_pitch] = (unsigned char)((d * 64 + e * 192 + 128) >> 8);
|
|
|
|
++source;
|
|
++dest;
|
|
}
|
|
}
|
|
|
|
/*7***************************************************************************
|
|
*
|
|
* ROUTINE : aom_horizontal_line_3_5_scale_c
|
|
*
|
|
* INPUTS : const unsigned char *source : Pointer to source data.
|
|
* unsigned int source_width : Stride of source.
|
|
* unsigned char *dest : Pointer to destination data.
|
|
* unsigned int dest_width : Stride of destination
|
|
* (NOT USED).
|
|
*
|
|
* OUTPUTS : None.
|
|
*
|
|
* RETURNS : void
|
|
*
|
|
* FUNCTION : Copies horizontal line of pixels from source to
|
|
* destination scaling up by 3 to 5.
|
|
*
|
|
* SPECIAL NOTES : None.
|
|
*
|
|
*
|
|
****************************************************************************/
|
|
void aom_horizontal_line_5_3_scale_c(const unsigned char *source,
|
|
unsigned int source_width,
|
|
unsigned char *dest,
|
|
unsigned int dest_width) {
|
|
const unsigned char *const source_end = source + source_width;
|
|
(void)dest_width;
|
|
while (source < source_end) {
|
|
const unsigned int a = source[0];
|
|
const unsigned int b = source[1];
|
|
const unsigned int c = source[2];
|
|
const unsigned int d = source[3];
|
|
const unsigned int e = source[4];
|
|
|
|
dest[0] = (unsigned char)a;
|
|
dest[1] = (unsigned char)((b * 85 + c * 171 + 128) >> 8);
|
|
dest[2] = (unsigned char)((d * 171 + e * 85 + 128) >> 8);
|
|
|
|
source += 5;
|
|
dest += 3;
|
|
}
|
|
}
|
|
|
|
void aom_vertical_band_5_3_scale_c(unsigned char *source, int src_pitch,
|
|
unsigned char *dest, int dest_pitch,
|
|
unsigned int dest_width) {
|
|
const unsigned char *const dest_end = dest + dest_width;
|
|
while (dest < dest_end) {
|
|
const unsigned int a = source[0 * src_pitch];
|
|
const unsigned int b = source[1 * src_pitch];
|
|
const unsigned int c = source[2 * src_pitch];
|
|
const unsigned int d = source[3 * src_pitch];
|
|
const unsigned int e = source[4 * src_pitch];
|
|
|
|
dest[0 * dest_pitch] = (unsigned char)a;
|
|
dest[1 * dest_pitch] = (unsigned char)((b * 85 + c * 171 + 128) >> 8);
|
|
dest[2 * dest_pitch] = (unsigned char)((d * 171 + e * 85 + 128) >> 8);
|
|
|
|
++source;
|
|
++dest;
|
|
}
|
|
}
|
|
|
|
/****************************************************************************
|
|
*
|
|
* ROUTINE : aom_horizontal_line_1_2_scale_c
|
|
*
|
|
* INPUTS : const unsigned char *source : Pointer to source data.
|
|
* unsigned int source_width : Stride of source.
|
|
* unsigned char *dest : Pointer to destination data.
|
|
* unsigned int dest_width : Stride of destination
|
|
* (NOT USED).
|
|
*
|
|
* OUTPUTS : None.
|
|
*
|
|
* RETURNS : void
|
|
*
|
|
* FUNCTION : Copies horizontal line of pixels from source to
|
|
* destination scaling up by 1 to 2.
|
|
*
|
|
* SPECIAL NOTES : None.
|
|
*
|
|
****************************************************************************/
|
|
void aom_horizontal_line_2_1_scale_c(const unsigned char *source,
|
|
unsigned int source_width,
|
|
unsigned char *dest,
|
|
unsigned int dest_width) {
|
|
const unsigned char *const source_end = source + source_width;
|
|
(void)dest_width;
|
|
while (source < source_end) {
|
|
dest[0] = source[0];
|
|
source += 2;
|
|
++dest;
|
|
}
|
|
}
|
|
|
|
void aom_vertical_band_2_1_scale_c(unsigned char *source, int src_pitch,
|
|
unsigned char *dest, int dest_pitch,
|
|
unsigned int dest_width) {
|
|
(void)dest_pitch;
|
|
(void)src_pitch;
|
|
memcpy(dest, source, dest_width);
|
|
}
|
|
|
|
void aom_vertical_band_2_1_scale_i_c(unsigned char *source, int src_pitch,
|
|
unsigned char *dest, int dest_pitch,
|
|
unsigned int dest_width) {
|
|
const unsigned char *const dest_end = dest + dest_width;
|
|
(void)dest_pitch;
|
|
while (dest < dest_end) {
|
|
const unsigned int a = source[-src_pitch] * 3;
|
|
const unsigned int b = source[0] * 10;
|
|
const unsigned int c = source[src_pitch] * 3;
|
|
dest[0] = (unsigned char)((8 + a + b + c) >> 4);
|
|
++source;
|
|
++dest;
|
|
}
|
|
}
|