Merge branch 'CR_6284_v4l2test_changhuang.liang' into 'jh7110-devel'

CR_6284_v4l2test_changhuang.liang package: starfive: v4l2_test: Add ayuv to nv12

See merge request sdk/buildroot!118
This commit is contained in:
andy.hu
2023-07-06 00:50:48 +00:00
4 changed files with 81 additions and 2 deletions
+4 -2
View File
@@ -115,6 +115,10 @@ uint32_t v4l2fmt_to_drmfmt(uint32_t v4l2_fmt)
case V4L2_PIX_FMT_NV12:
drm_fmt = DRM_FORMAT_NV12;
break;
/*add for jh7110 debug*/
case V4L2_PIX_FMT_AYUV32:
drm_fmt = DRM_FORMAT_NV12;
break;
default:
drm_fmt = DRM_FORMAT_NV21;
LOG(STF_LEVEL_WARN, "drm not support the V4L2_format\n");
@@ -318,5 +322,3 @@ void jpegWrite(uint8_t* img, char* jpegFilename,
// close output file
fclose(outfile);
}
+60
View File
@@ -859,3 +859,63 @@ int convert_rgb888_to_rgb(const uint8_t *inBuf, uint8_t *outBuf, int imgWidth, i
free(tmp);
return 0;
}
enum AYUV
{
AYUV_V = 0,
AYUV_U = 1,
AYUV_Y = 2,
AYUV_A = 3,
};
int convert_ayuv32_to_nv12(const uint8_t *inBuf, uint8_t *outBuf, int imgWidth, int imgHeight)
{
int i, j;
unsigned int uv_start_index = imgWidth * imgHeight, frameWidthProd4 = imgWidth * 4;
unsigned int frameWidthDiv2 = imgWidth / 2, frameWidthDiv4 = imgWidth / 4;
unsigned int rowsFrameWidth, rowsFrameWidthProd4, rowsFrameWidthProd4ColsProd4, rowsAdd1FrameWidthProd4ColsProd4;
unsigned int uvStartIndexRowsFrameWidthDiv2, uvStartIndexRowsFrameWidthDiv2Cols;
int dstSize = imgWidth * imgHeight * 3 / 2;
/* 1. Execute the AYUVToNV12 algorithm. */
/* Y/U/V components extraction for even index i */
for (i = 0; i < imgHeight; i += 2)
{
rowsFrameWidth = i * imgWidth;
rowsFrameWidthProd4 = i * frameWidthProd4;
uvStartIndexRowsFrameWidthDiv2 = uv_start_index + i * frameWidthDiv2;
for (j = 0; j < frameWidthDiv4; j++)
{
/* Y components extraction for even index i */
outBuf[rowsFrameWidth + j] = inBuf[rowsFrameWidthProd4 + j * 4 + AYUV_Y];
rowsFrameWidthProd4ColsProd4 = rowsFrameWidthProd4 + j * 16;
rowsAdd1FrameWidthProd4ColsProd4 = rowsFrameWidthProd4ColsProd4 + frameWidthProd4;
uvStartIndexRowsFrameWidthDiv2Cols = uvStartIndexRowsFrameWidthDiv2 + j * 4;
/* UV components extraction for even index i: processing 4 elements every time */
outBuf[uvStartIndexRowsFrameWidthDiv2Cols] = inBuf[rowsFrameWidthProd4ColsProd4 + 1];
outBuf[uvStartIndexRowsFrameWidthDiv2Cols + 1] = inBuf[rowsAdd1FrameWidthProd4ColsProd4];
outBuf[uvStartIndexRowsFrameWidthDiv2Cols + 2] = inBuf[rowsFrameWidthProd4ColsProd4 + 9];
outBuf[uvStartIndexRowsFrameWidthDiv2Cols + 3] = inBuf[rowsAdd1FrameWidthProd4ColsProd4 + 8];
}
for (; j < imgWidth; j++)
{
outBuf[rowsFrameWidth + j] = inBuf[rowsFrameWidthProd4 + j * 4 + AYUV_Y];
}
}
/* Y components extraction for odd index i */
for (i = 1; i < imgHeight; i += 2)
{
rowsFrameWidth = i * imgWidth;
rowsFrameWidthProd4 = i * frameWidthProd4;
for (j = 0; j < imgWidth; j++)
{
outBuf[rowsFrameWidth + j] = inBuf[rowsFrameWidthProd4 + j * 4 + AYUV_Y];
}
}
return 0;
}
+1
View File
@@ -16,6 +16,7 @@ extern int convert_yuyv_to_rgb(const uint8_t *inBuf, uint8_t *outBuf, int imgWid
extern int convert_yuv444_to_rgb(uint8_t *inBuf, uint8_t *outBuf, int imgWidth, int imgHeight, int cvtMethod);
extern int convert_rgb565_to_rgb(const uint8_t *inBuf, uint8_t *outBuf, int imgWidth, int imgHeight, int cvtMethod);
extern int convert_rgb888_to_rgb(const uint8_t *inBuf, uint8_t *outBuf, int imgWidth, int imgHeight, int cvtMethod);
extern int convert_ayuv32_to_nv12(const uint8_t *inBuf, uint8_t *outBuf, int imgWidth, int imgHeight);
extern void update_videocvt_param(int distype, int scr_width, int scr_height,
int scr_bpp, int scr_size);
+16
View File
@@ -379,6 +379,18 @@ static void imageProcess(const uint8_t* inbuf, uint8_t* outbuf,
sprintf(filename, "raw-%d-BGGR16.raw", s_frmcnt);
write_file(filename, (const uint8_t *)dst, in_width * in_height * 2);
s_frmcnt++;
break;
case V4L2_PIX_FMT_AYUV32:
if (gp_cfg_param->jpegFilename && gp_cfg_param->rec_fp) {
fwrite(inbuf, in_imagesize, 1, gp_cfg_param->rec_fp);
}
if (outbuf) {
if ((STF_DISP_DRM == disp_type) && (out_format == V4L2_PIX_FMT_NV12)) {
convert_ayuv32_to_nv12(inbuf, outbuf, in_width, in_height);
}
}
break;
default:
LOG(STF_LEVEL_ERR, "unknow in_format\n");
@@ -776,6 +788,7 @@ static void usage(FILE* fp, int argc, char** argv)
" 8: V4L2_PIX_FMT_SGRBG12\n"
" 9: V4L2_PIX_FMT_SGBRG12\n"
" 10: V4L2_PIX_FMT_SBGGR12\n"
" 11: V4L2_PIX_FMT_AYUV32\n"
" default: V4L2_PIX_FMT_NV12\n"
"-t | --distype set display type, default 0\n"
" 0: Not display\n"
@@ -948,6 +961,9 @@ void parse_options(int argc, char **argv, ConfigParam_t *cfg_param)
case 10:
value = V4L2_PIX_FMT_SBGGR12;
break;
case 11:
value = V4L2_PIX_FMT_AYUV32;
break;
default:
value = V4L2_PIX_FMT_RGB565;
break;