Commit 148bc235 authored by Diego Biurrun's avatar Diego Biurrun

swscale: K&R formatting cosmetics for Blackfin code

Also prettyprint some comments in Assembly code.
parent 3f57bde1
...@@ -30,11 +30,11 @@ and converts it to RGB565. R:5 bits, G:6 bits, B:5 bits.. packed into shorts. ...@@ -30,11 +30,11 @@ and converts it to RGB565. R:5 bits, G:6 bits, B:5 bits.. packed into shorts.
The following calculation is used for the conversion: The following calculation is used for the conversion:
r = clipz((y-oy)*cy + crv*(v-128)) r = clipz((y - oy) * cy + crv * (v - 128))
g = clipz((y-oy)*cy + cgv*(v-128) + cgu*(u-128)) g = clipz((y - oy) * cy + cgv * (v - 128) + cgu * (u - 128))
b = clipz((y-oy)*cy + cbu*(u-128)) b = clipz((y - oy) * cy + cbu * (u - 128))
y,u,v are prescaled by a factor of 4 i.e. left-shifted to gain precision. y, u, v are prescaled by a factor of 4 i.e. left-shifted to gain precision.
New factorization to eliminate the truncation error which was New factorization to eliminate the truncation error which was
...@@ -47,7 +47,7 @@ occurring due to the byteop3p. ...@@ -47,7 +47,7 @@ occurring due to the byteop3p.
2) Scale operands up by a factor of 4 not 8 because Blackfin 2) Scale operands up by a factor of 4 not 8 because Blackfin
multiplies include a shift. multiplies include a shift.
3) Compute into the accumulators cy*yx0, cy*yx1. 3) Compute into the accumulators cy * yx0, cy * yx1.
4) Compute each of the linear equations: 4) Compute each of the linear equations:
r = clipz((y - oy) * cy + crv * (v - 128)) r = clipz((y - oy) * cy + crv * (v - 128))
...@@ -73,7 +73,7 @@ occurring due to the byteop3p. ...@@ -73,7 +73,7 @@ occurring due to the byteop3p.
Where coeffs have the following layout in memory. Where coeffs have the following layout in memory.
uint32_t oy,oc,zero,cy,crv,rmask,cbu,bmask,cgu,cgv; uint32_t oy, oc, zero, cy, crv, rmask, cbu, bmask, cgu, cgv;
coeffs is a pointer to oy. coeffs is a pointer to oy.
......
...@@ -27,32 +27,34 @@ ...@@ -27,32 +27,34 @@
#include <assert.h> #include <assert.h>
#include "config.h" #include "config.h"
#include <unistd.h> #include <unistd.h>
#include "libswscale/rgb2rgb.h" #include "libswscale/rgb2rgb.h"
#include "libswscale/swscale.h" #include "libswscale/swscale.h"
#include "libswscale/swscale_internal.h" #include "libswscale/swscale_internal.h"
#if defined (__FDPIC__) && CONFIG_SRAM #if defined (__FDPIC__) && CONFIG_SRAM
#define L1CODE __attribute__ ((l1_text)) #define L1CODE __attribute__((l1_text))
#else #else
#define L1CODE #define L1CODE
#endif #endif
int ff_bfin_uyvytoyv12(const uint8_t *src, uint8_t *ydst, uint8_t *udst, uint8_t *vdst, int ff_bfin_uyvytoyv12(const uint8_t *src, uint8_t *ydst, uint8_t *udst,
int width, int height, uint8_t *vdst, int width, int height,
int lumStride, int chromStride, int srcStride) L1CODE; int lumStride, int chromStride, int srcStride) L1CODE;
int ff_bfin_yuyvtoyv12(const uint8_t *src, uint8_t *ydst, uint8_t *udst, uint8_t *vdst, int ff_bfin_yuyvtoyv12(const uint8_t *src, uint8_t *ydst, uint8_t *udst,
int width, int height, uint8_t *vdst, int width, int height,
int lumStride, int chromStride, int srcStride) L1CODE; int lumStride, int chromStride, int srcStride) L1CODE;
static int uyvytoyv12_unscaled(SwsContext *c, uint8_t* src[], int srcStride[], int srcSliceY, static int uyvytoyv12_unscaled(SwsContext *c, uint8_t *src[], int srcStride[],
int srcSliceH, uint8_t* dst[], int dstStride[]) int srcSliceY, int srcSliceH, uint8_t *dst[],
int dstStride[])
{ {
uint8_t *dsty = dst[0] + dstStride[0]*srcSliceY; uint8_t *dsty = dst[0] + dstStride[0] * srcSliceY;
uint8_t *dstu = dst[1] + dstStride[1]*srcSliceY/2; uint8_t *dstu = dst[1] + dstStride[1] * srcSliceY / 2;
uint8_t *dstv = dst[2] + dstStride[2]*srcSliceY/2; uint8_t *dstv = dst[2] + dstStride[2] * srcSliceY / 2;
uint8_t *ip = src[0] + srcStride[0]*srcSliceY; uint8_t *ip = src[0] + srcStride[0] * srcSliceY;
int w = dstStride[0]; int w = dstStride[0];
ff_bfin_uyvytoyv12(ip, dsty, dstu, dstv, w, srcSliceH, ff_bfin_uyvytoyv12(ip, dsty, dstu, dstv, w, srcSliceH,
dstStride[0], dstStride[1], srcStride[0]); dstStride[0], dstStride[1], srcStride[0]);
...@@ -60,14 +62,15 @@ static int uyvytoyv12_unscaled(SwsContext *c, uint8_t* src[], int srcStride[], i ...@@ -60,14 +62,15 @@ static int uyvytoyv12_unscaled(SwsContext *c, uint8_t* src[], int srcStride[], i
return srcSliceH; return srcSliceH;
} }
static int yuyvtoyv12_unscaled(SwsContext *c, uint8_t* src[], int srcStride[], int srcSliceY, static int yuyvtoyv12_unscaled(SwsContext *c, uint8_t *src[], int srcStride[],
int srcSliceH, uint8_t* dst[], int dstStride[]) int srcSliceY, int srcSliceH, uint8_t *dst[],
int dstStride[])
{ {
uint8_t *dsty = dst[0] + dstStride[0]*srcSliceY; uint8_t *dsty = dst[0] + dstStride[0] * srcSliceY;
uint8_t *dstu = dst[1] + dstStride[1]*srcSliceY/2; uint8_t *dstu = dst[1] + dstStride[1] * srcSliceY / 2;
uint8_t *dstv = dst[2] + dstStride[2]*srcSliceY/2; uint8_t *dstv = dst[2] + dstStride[2] * srcSliceY / 2;
uint8_t *ip = src[0] + srcStride[0]*srcSliceY; uint8_t *ip = src[0] + srcStride[0] * srcSliceY;
int w = dstStride[0]; int w = dstStride[0];
ff_bfin_yuyvtoyv12(ip, dsty, dstu, dstv, w, srcSliceH, ff_bfin_yuyvtoyv12(ip, dsty, dstu, dstv, w, srcSliceH,
dstStride[0], dstStride[1], srcStride[0]); dstStride[0], dstStride[1], srcStride[0]);
...@@ -75,15 +78,16 @@ static int yuyvtoyv12_unscaled(SwsContext *c, uint8_t* src[], int srcStride[], i ...@@ -75,15 +78,16 @@ static int yuyvtoyv12_unscaled(SwsContext *c, uint8_t* src[], int srcStride[], i
return srcSliceH; return srcSliceH;
} }
void ff_bfin_get_unscaled_swscale(SwsContext *c) void ff_bfin_get_unscaled_swscale(SwsContext *c)
{ {
if (c->dstFormat == PIX_FMT_YUV420P && c->srcFormat == PIX_FMT_UYVY422) { if (c->dstFormat == PIX_FMT_YUV420P && c->srcFormat == PIX_FMT_UYVY422) {
av_log (NULL, AV_LOG_VERBOSE, "selecting Blackfin optimized uyvytoyv12_unscaled\n"); av_log(NULL, AV_LOG_VERBOSE,
"selecting Blackfin optimized uyvytoyv12_unscaled\n");
c->swScale = uyvytoyv12_unscaled; c->swScale = uyvytoyv12_unscaled;
} }
if (c->dstFormat == PIX_FMT_YUV420P && c->srcFormat == PIX_FMT_YUYV422) { if (c->dstFormat == PIX_FMT_YUV420P && c->srcFormat == PIX_FMT_YUYV422) {
av_log (NULL, AV_LOG_VERBOSE, "selecting Blackfin optimized yuyvtoyv12_unscaled\n"); av_log(NULL, AV_LOG_VERBOSE,
"selecting Blackfin optimized yuyvtoyv12_unscaled\n");
c->swScale = yuyvtoyv12_unscaled; c->swScale = yuyvtoyv12_unscaled;
} }
} }
...@@ -26,14 +26,15 @@ ...@@ -26,14 +26,15 @@
#include <string.h> #include <string.h>
#include <inttypes.h> #include <inttypes.h>
#include <assert.h> #include <assert.h>
#include "config.h"
#include <unistd.h> #include <unistd.h>
#include "config.h"
#include "libswscale/rgb2rgb.h" #include "libswscale/rgb2rgb.h"
#include "libswscale/swscale.h" #include "libswscale/swscale.h"
#include "libswscale/swscale_internal.h" #include "libswscale/swscale_internal.h"
#if defined(__FDPIC__) && CONFIG_SRAM #if defined(__FDPIC__) && CONFIG_SRAM
#define L1CODE __attribute__ ((l1_text)) #define L1CODE __attribute__((l1_text))
#else #else
#define L1CODE #define L1CODE
#endif #endif
...@@ -47,21 +48,20 @@ void ff_bfin_yuv2rgb565_line(uint8_t *Y, uint8_t *U, uint8_t *V, uint8_t *out, ...@@ -47,21 +48,20 @@ void ff_bfin_yuv2rgb565_line(uint8_t *Y, uint8_t *U, uint8_t *V, uint8_t *out,
void ff_bfin_yuv2rgb24_line(uint8_t *Y, uint8_t *U, uint8_t *V, uint8_t *out, void ff_bfin_yuv2rgb24_line(uint8_t *Y, uint8_t *U, uint8_t *V, uint8_t *out,
int w, uint32_t *coeffs) L1CODE; int w, uint32_t *coeffs) L1CODE;
typedef void (* ltransform)(uint8_t *Y, uint8_t *U, uint8_t *V, uint8_t *out, typedef void (*ltransform)(uint8_t *Y, uint8_t *U, uint8_t *V, uint8_t *out,
int w, uint32_t *coeffs); int w, uint32_t *coeffs);
static void bfin_prepare_coefficients(SwsContext *c, int rgb, int masks) static void bfin_prepare_coefficients(SwsContext *c, int rgb, int masks)
{ {
int oy; int oy;
oy = c->yOffset&0xffff; oy = c->yOffset & 0xffff;
oy = oy >> 3; // keep everything U8.0 for offset calculation oy = oy >> 3; // keep everything U8.0 for offset calculation
c->oc = 128*0x01010101U; c->oc = 128 * 0x01010101U;
c->oy = oy*0x01010101U; c->oy = oy * 0x01010101U;
/* copy 64bit vector coeffs down to 32bit vector coeffs */ /* copy 64bit vector coeffs down to 32bit vector coeffs */
c->cy = c->yCoeff; c->cy = c->yCoeff;
c->zero = 0; c->zero = 0;
if (rgb) { if (rgb) {
...@@ -76,7 +76,6 @@ static void bfin_prepare_coefficients(SwsContext *c, int rgb, int masks) ...@@ -76,7 +76,6 @@ static void bfin_prepare_coefficients(SwsContext *c, int rgb, int masks)
c->cgv = c->ugCoeff; c->cgv = c->ugCoeff;
} }
if (masks == 555) { if (masks == 555) {
c->rmask = 0x001f * 0x00010001U; c->rmask = 0x001f * 0x00010001U;
c->gmask = 0x03e0 * 0x00010001U; c->gmask = 0x03e0 * 0x00010001U;
...@@ -88,27 +87,25 @@ static void bfin_prepare_coefficients(SwsContext *c, int rgb, int masks) ...@@ -88,27 +87,25 @@ static void bfin_prepare_coefficients(SwsContext *c, int rgb, int masks)
} }
} }
static int core_yuv420_rgb(SwsContext *c, static int core_yuv420_rgb(SwsContext *c, uint8_t **in, int *instrides,
uint8_t **in, int *instrides, int srcSliceY, int srcSliceH, uint8_t **oplanes,
int srcSliceY, int srcSliceH, int *outstrides, ltransform lcscf,
uint8_t **oplanes, int *outstrides, int rgb, int masks)
ltransform lcscf, int rgb, int masks)
{ {
uint8_t *py,*pu,*pv,*op; uint8_t *py, *pu, *pv, *op;
int w = instrides[0]; int w = instrides[0];
int h2 = srcSliceH>>1; int h2 = srcSliceH >> 1;
int i; int i;
bfin_prepare_coefficients(c, rgb, masks); bfin_prepare_coefficients(c, rgb, masks);
py = in[0]; py = in[0];
pu = in[1+(1^rgb)]; pu = in[1 + (1 ^ rgb)];
pv = in[1+(0^rgb)]; pv = in[1 + (0 ^ rgb)];
op = oplanes[0] + srcSliceY*outstrides[0];
for (i=0;i<h2;i++) { op = oplanes[0] + srcSliceY * outstrides[0];
for (i = 0; i < h2; i++) {
lcscf(py, pu, pv, op, w, &c->oy); lcscf(py, pu, pv, op, w, &c->oy);
py += instrides[0]; py += instrides[0];
...@@ -125,9 +122,7 @@ static int core_yuv420_rgb(SwsContext *c, ...@@ -125,9 +122,7 @@ static int core_yuv420_rgb(SwsContext *c,
return srcSliceH; return srcSliceH;
} }
static int bfin_yuv420_rgb555(SwsContext *c, uint8_t **in, int *instrides,
static int bfin_yuv420_rgb555(SwsContext *c,
uint8_t **in, int *instrides,
int srcSliceY, int srcSliceH, int srcSliceY, int srcSliceH,
uint8_t **oplanes, int *outstrides) uint8_t **oplanes, int *outstrides)
{ {
...@@ -135,8 +130,7 @@ static int bfin_yuv420_rgb555(SwsContext *c, ...@@ -135,8 +130,7 @@ static int bfin_yuv420_rgb555(SwsContext *c,
outstrides, ff_bfin_yuv2rgb555_line, 1, 555); outstrides, ff_bfin_yuv2rgb555_line, 1, 555);
} }
static int bfin_yuv420_bgr555(SwsContext *c, static int bfin_yuv420_bgr555(SwsContext *c, uint8_t **in, int *instrides,
uint8_t **in, int *instrides,
int srcSliceY, int srcSliceH, int srcSliceY, int srcSliceH,
uint8_t **oplanes, int *outstrides) uint8_t **oplanes, int *outstrides)
{ {
...@@ -144,8 +138,7 @@ static int bfin_yuv420_bgr555(SwsContext *c, ...@@ -144,8 +138,7 @@ static int bfin_yuv420_bgr555(SwsContext *c,
outstrides, ff_bfin_yuv2rgb555_line, 0, 555); outstrides, ff_bfin_yuv2rgb555_line, 0, 555);
} }
static int bfin_yuv420_rgb24(SwsContext *c, static int bfin_yuv420_rgb24(SwsContext *c, uint8_t **in, int *instrides,
uint8_t **in, int *instrides,
int srcSliceY, int srcSliceH, int srcSliceY, int srcSliceH,
uint8_t **oplanes, int *outstrides) uint8_t **oplanes, int *outstrides)
{ {
...@@ -153,8 +146,7 @@ static int bfin_yuv420_rgb24(SwsContext *c, ...@@ -153,8 +146,7 @@ static int bfin_yuv420_rgb24(SwsContext *c,
outstrides, ff_bfin_yuv2rgb24_line, 1, 888); outstrides, ff_bfin_yuv2rgb24_line, 1, 888);
} }
static int bfin_yuv420_bgr24(SwsContext *c, static int bfin_yuv420_bgr24(SwsContext *c, uint8_t **in, int *instrides,
uint8_t **in, int *instrides,
int srcSliceY, int srcSliceH, int srcSliceY, int srcSliceH,
uint8_t **oplanes, int *outstrides) uint8_t **oplanes, int *outstrides)
{ {
...@@ -162,8 +154,7 @@ static int bfin_yuv420_bgr24(SwsContext *c, ...@@ -162,8 +154,7 @@ static int bfin_yuv420_bgr24(SwsContext *c,
outstrides, ff_bfin_yuv2rgb24_line, 0, 888); outstrides, ff_bfin_yuv2rgb24_line, 0, 888);
} }
static int bfin_yuv420_rgb565(SwsContext *c, static int bfin_yuv420_rgb565(SwsContext *c, uint8_t **in, int *instrides,
uint8_t **in, int *instrides,
int srcSliceY, int srcSliceH, int srcSliceY, int srcSliceH,
uint8_t **oplanes, int *outstrides) uint8_t **oplanes, int *outstrides)
{ {
...@@ -171,8 +162,7 @@ static int bfin_yuv420_rgb565(SwsContext *c, ...@@ -171,8 +162,7 @@ static int bfin_yuv420_rgb565(SwsContext *c,
outstrides, ff_bfin_yuv2rgb565_line, 1, 565); outstrides, ff_bfin_yuv2rgb565_line, 1, 565);
} }
static int bfin_yuv420_bgr565(SwsContext *c, static int bfin_yuv420_bgr565(SwsContext *c, uint8_t **in, int *instrides,
uint8_t **in, int *instrides,
int srcSliceY, int srcSliceH, int srcSliceY, int srcSliceH,
uint8_t **oplanes, int *outstrides) uint8_t **oplanes, int *outstrides)
{ {
...@@ -180,24 +170,35 @@ static int bfin_yuv420_bgr565(SwsContext *c, ...@@ -180,24 +170,35 @@ static int bfin_yuv420_bgr565(SwsContext *c,
outstrides, ff_bfin_yuv2rgb565_line, 0, 565); outstrides, ff_bfin_yuv2rgb565_line, 0, 565);
} }
SwsFunc ff_yuv2rgb_get_func_ptr_bfin(SwsContext *c) SwsFunc ff_yuv2rgb_get_func_ptr_bfin(SwsContext *c)
{ {
SwsFunc f; SwsFunc f;
switch(c->dstFormat) { switch (c->dstFormat) {
case PIX_FMT_RGB555: f = bfin_yuv420_rgb555; break; case PIX_FMT_RGB555:
case PIX_FMT_BGR555: f = bfin_yuv420_bgr555; break; f = bfin_yuv420_rgb555;
case PIX_FMT_RGB565: f = bfin_yuv420_rgb565; break; break;
case PIX_FMT_BGR565: f = bfin_yuv420_bgr565; break; case PIX_FMT_BGR555:
case PIX_FMT_RGB24: f = bfin_yuv420_rgb24; break; f = bfin_yuv420_bgr555;
case PIX_FMT_BGR24: f = bfin_yuv420_bgr24; break; break;
case PIX_FMT_RGB565:
f = bfin_yuv420_rgb565;
break;
case PIX_FMT_BGR565:
f = bfin_yuv420_bgr565;
break;
case PIX_FMT_RGB24:
f = bfin_yuv420_rgb24;
break;
case PIX_FMT_BGR24:
f = bfin_yuv420_bgr24;
break;
default: default:
return 0; return 0;
} }
av_log(c, AV_LOG_INFO, "BlackFin accelerated color space converter %s\n", av_log(c, AV_LOG_INFO, "BlackFin accelerated color space converter %s\n",
sws_format_name (c->dstFormat)); sws_format_name(c->dstFormat));
return f; return f;
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment