FFMpeg libswscale XBGR32到NV12几乎正常工作,但颜色错误

时间:2016-06-08 19:06:13

标签: c ffmpeg h.264 pixelformat swscale

我正在以XBGR32格式从GPU获得Linx DMA-BUF,我需要使用FFMpeg的libswscale将它在ARM上转换为NV12。

我已经能够根据各种SO帖子和文档几乎让它正常工作。

这是LCD屏幕,它是GPU的实际输出: enter image description here

以下是libswscale创建的NV12帧的编码数据 - 它应显示与屏幕相同的颜色: enter image description here

请注意,图片并非完全同时拍摄。

我做错了什么?

以下是我的代码的相关部分:

/* Prepare to mmap the GBM BO */
union gbm_bo_handle handleUnion = gbm_bo_get_handle(bo);  
struct drm_omap_gem_info req;
req.handle = handleUnion.s32;    
ret = drmCommandWriteRead(m_DRMController.fd, DRM_OMAP_GEM_INFO,&req, sizeof(req));
if (ret) {  
    qDebug() << "drmCommandWriteRead(): Cannot set write/read";
}   

// Perform actual memory mapping of GPU output    
gpuMmapFrame = (char *)mmap(0, req.size, PROT_READ | PROT_WRITE, MAP_SHARED,m_DRMController.fd, req.offset);
assert(gpuMmapFrame != MAP_FAILED);

// Use ffmpeg to do the SW BGR32 to NV12   
static SwsContext *swsCtx = NULL;    
int width    = RNDTO2( convertWidth );    
int height   = RNDTO2( convertHeight );    
int ystride  = RNDTO32 ( width );    
int uvstride = RNDTO32 ( width / 2 );    
int uvsize   = uvstride * ( height / 2 );    
void *plane[] = { y, u, u + uvsize, 0 };    
int stride[] = { ystride, uvstride, uvstride, 0 };    

// Output of GPU is XBGR32    
// #define V4L2_PIX_FMT_XBGR32  v4l2_fourcc('X', 'R', '2', '4') /* 32  BGRX-8-8-8-8  */    
swsCtx = sws_getCachedContext( swsCtx, convertWidth, convertHeight, AV_PIX_FMT_BGR32, width, height, AV_PIX_FMT_NV12, 
                           SWS_FAST_BILINEAR , NULL, NULL, NULL );  
int linesize[1] = { convertWidth * 4 };    
const uint8_t *inData[1] = { (uint8_t*)gpuMmapFrame };    
if ( gpuMmapFrame ) {    
    sws_scale( swsCtx, (const uint8_t *const *)inData, linesize, 0, convertHeight, (uint8_t *const *)plane, stride );    
}        

// Unmap it    
munmap(gpuMmapFrame,req.size);

// Now send the frame to the encoder    
dce.submitFrameToEncode(swEncodeBufferNV12);

0 个答案:

没有答案