コード例 #1
0
MBOOL
JpegCodec::
deallocMem(IMEM_BUF_INFO & rMemBuf)
{
    IMemDrv *pIMemDrv = IMemDrv::createInstance(); 
    CHECK_OBJECT(pIMemDrv); 
    //
    pIMemDrv->init(); 
    //
#if 1
    if (pIMemDrv->unmapPhyAddr(&rMemBuf)) 
    {
        MY_LOGE("m_pIMemDrv->unmapPhyAddr() error");
        return MFALSE;              
    }
#endif 
    //
    if (pIMemDrv->freeVirtBuf(&rMemBuf)) 
    {
        MY_LOGE("m_pIMemDrv->freeVirtBuf() error");
        return MFALSE;        
    }        
    rMemBuf.size = 0; 
    //
    pIMemDrv->uninit(); 
    pIMemDrv->destroyInstance(); 
    return MTRUE; 
}
コード例 #2
0
MBOOL
JpegCodec::
allocMem(IMEM_BUF_INFO & rMemBuf) 
{
    // 
    IMemDrv *pIMemDrv = IMemDrv::createInstance(); 
    CHECK_OBJECT(pIMemDrv); 
    //
    pIMemDrv->init(); 
    // 
    if (pIMemDrv->allocVirtBuf(&rMemBuf)) {
        MY_LOGE("g_pIMemDrv->allocVirtBuf() error");
        return MFALSE;              
    }
    ::memset((void*)rMemBuf.virtAddr, 0 , rMemBuf.size);
#if 1
    if (pIMemDrv->mapPhyAddr(&rMemBuf)) {
        MY_LOGE("mpIMemDrv->mapPhyAddr() error");
        return MFALSE;        
    }
#endif 
    //
    pIMemDrv->uninit(); 
    pIMemDrv->destroyInstance(); 
    return MTRUE; 
}
コード例 #3
0
//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
//
//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
MBOOL
AEBufMgr::
uninit()
{
#if ENABLE_AE_MVHDR_STAT
    IMEM_BUF_INFO buf_info;

	MY_LOG("[%s()] m_eSensorDev: %d, m_Users: %d \n", __FUNCTION__, m_eSensorDev, m_Users);

	Mutex::Autolock lock(m_Lock);

	// If no more users, return directly and do nothing.
	if (m_Users <= 0)
	{
		return MTRUE;
	}

	// More than one user, so decrease one User.
	android_atomic_dec(&m_Users);

	if (m_Users == 0) // There is no more User after decrease one User
	{
	    // Disable AA stat
        //AAStatEnable(MFALSE);

        // AAO DMA buffer uninit
        //DMAUninit();

        for (MINT32 i = 0; i < MAX_AAO_BUFFER_CNT; i++) {
            freeBuf(m_rAAOBufInfo[i]);
        }

       // imem driver ininit
       m_pIMemDrv->uninit();

        if ( 0 != mpIspHwRegAddr ) {
            munmap(mpIspHwRegAddr, CAM_ISP_RANGE);
            mpIspHwRegAddr = NULL;
        }
        
        if(mfd >= 0)
        {
            close(mfd);
            mfd = -1;
        }
       // Normal pipe
       //m_pPipe->destroyInstance("aao_buf_mgr");
    }
	else	// There are still some users.
	{
		MY_LOG_IF(m_bDebugEnable,"Still %d users \n", m_Users);
	}
#endif
    return MTRUE;
}
コード例 #4
0
MBOOL
StereoNodeImpl::
freeBuffers()
{
    FUNC_START;
    MBOOL ret = MFALSE;
    list<IMEM_BUF_INFO>::iterator iter;
    IMEM_BUF_INFO feo;
    IMemDrv* pIMemDrv =  IMemDrv::createInstance();
    if ( !pIMemDrv || !pIMemDrv->init() ) {
        MY_LOGE("pIMemDrv->init() error");
        goto lbExit;
    }
    MY_LOGD("check buffer size(%d)", mlFeBufQueue.size());
    for(iter = mlFeBufQueue.begin(); iter != mlFeBufQueue.end(); iter++)
    {
        MY_LOGD("Buffer addr(0x%x)", (*iter).virtAddr);
        if(0 == (*iter).virtAddr)
        {
            MY_LOGE("Buffer doesn't exist");
            continue;
        }
        if(pIMemDrv->unmapPhyAddr(&(*iter)) < 0)
        {
            MY_LOGE("pIMemDrv->unmapPhyAddr() error");
            goto lbExit;
        }
        if (pIMemDrv->freeVirtBuf(&(*iter)) < 0)
        {
            MY_LOGE("pIMemDrv->freeVirtBuf() error");
            goto lbExit;
        }
    }
    //
    ret = MTRUE;
lbExit:
    if ( !pIMemDrv ) {
        pIMemDrv->uninit();
        pIMemDrv->destroyInstance();
    }
    return ret;
}
コード例 #5
0
static MUINT32 u4SImager_Cmd(int argc, char** argv)
{
	MUINT32 u4SrcWidth = 1600;
	MUINT32 u4SrcHeight = 1200;
	MUINT32 u4TargetWidth = 800;
	MUINT32 u4TargetHeight = 600;
	int srcFmt = 0;
	int dstFmt = 0;


	char *filename = argv[0];
	u4SrcWidth = atoi(argv[1]);
	u4SrcHeight = atoi(argv[2]);
	srcFmt = atoi(argv[3]);
	u4TargetWidth = atoi(argv[4]);
	u4TargetHeight = atoi(argv[5]);
	dstFmt = atoi(argv[6]);

	printf("filename = %s\n", filename);
	printf("size in(%d,%d), out(%d,%d)\n", u4SrcWidth, u4SrcHeight, u4TargetWidth, u4TargetHeight);
	printf("fmt in=%x, out=%x\n", srcFmt, dstFmt);

    printf("SImager Test\n");
    //
    IMemDrv *pIMemDrv =  IMemDrv::createInstance();
    pIMemDrv->init();
    if (NULL == pIMemDrv)
    {
        printf("g_pIMemDrv is NULL");
        return 0;
    }
    //
    IMEM_BUF_INFO rInMem;
    rInMem.size = (u4SrcWidth * u4SrcHeight * 2+ L1_CACHE_BYTES-1) & ~(L1_CACHE_BYTES-1);
    if (pIMemDrv->allocVirtBuf(&rInMem)) {
        printf("g_pIMemDrv->allocVirtBuf() error");
    }
#if WORKAROUND_IMEM
    memset((void*)rInMem.virtAddr, 0 , rInMem.size);
    if (pIMemDrv->mapPhyAddr(&rInMem)) {
        printf("mpIMemDrv->mapPhyAddr() error");
    }
#endif

    if(!loadFileToBuf(filename, reinterpret_cast<MUINT8*>(rInMem.virtAddr), u4SrcWidth * u4SrcHeight)) {
	    printf("can't load image:%s\n", filename);
		return 0;
	}
    printf("load image:%s\n", filename);

    //
	IMEM_BUF_INFO rOutMem;
    rOutMem.size = (u4TargetWidth * u4TargetHeight * 2+ L1_CACHE_BYTES -1) & ~(L1_CACHE_BYTES-1);
    if (pIMemDrv->allocVirtBuf(&rOutMem)) {
        MY_LOGE("g_pIMemDrv->allocVirtBuf() error");
    }
    memset((void*)rOutMem.virtAddr, 128, rOutMem.size);
    if (pIMemDrv->mapPhyAddr(&rOutMem)) {
        MY_LOGE("mpIMemDrv->mapPhyAddr() error");
    }
	HdrShot::CDPResize_simple(
			&rInMem, u4SrcWidth, u4SrcHeight, g_eImgFmt[srcFmt],
			&rOutMem, u4TargetWidth, u4TargetHeight, g_eImgFmt[dstFmt], 0);

	char suffix[8];
	char prefix[8];
	switch(g_eImgFmt[srcFmt]) {
		case eImgFmt_YUY2: sprintf(prefix, "%s", "yuy2"); break;
		case eImgFmt_NV21: sprintf(prefix, "%s", "nv21"); break;
		case eImgFmt_I420: sprintf(prefix, "%s", "i420"); break;
		case eImgFmt_YV16: sprintf(prefix, "%s", "yv16"); break;
		case eImgFmt_JPEG: sprintf(prefix, "%s", "jpg"); break;
		case eImgFmt_YV12: sprintf(prefix, "%s", "yv12"); break;
	}
	switch(g_eImgFmt[dstFmt]) {
		case eImgFmt_YUY2: sprintf(suffix, "%s", "yuy2"); break;
		case eImgFmt_NV21: sprintf(suffix, "%s", "nv21"); break;
		case eImgFmt_I420: sprintf(suffix, "%s", "i420"); break;
		case eImgFmt_YV16: sprintf(suffix, "%s", "yv16"); break;
		case eImgFmt_JPEG: sprintf(suffix, "%s", "jpg"); break;
		case eImgFmt_YV12: sprintf(suffix, "%s", "yv12"); break;
	}
	char outfile[128];
	sprintf(outfile, "/sdcard/0001_%s_%dx%d.%s", prefix, u4TargetWidth, u4TargetHeight, suffix);
	saveBufToFile(outfile, (MUINT8 *)rOutMem.virtAddr, rOutMem.size);

    //!***************************************************
    //! Main thread wait for exit
    //!***************************************************

    //
    //deallocMem(rInMem);
    //deallocMem(rOutMem);
    if (pIMemDrv->unmapPhyAddr(&rInMem)) {
        MY_LOGE("m_pIMemDrv->unmapPhyAddr() error");
    }
    if (pIMemDrv->freeVirtBuf(&rInMem)) {
        MY_LOGE("m_pIMemDrv->freeVirtBuf() error");
    }
    if (pIMemDrv->unmapPhyAddr(&rOutMem)) {
        MY_LOGE("m_pIMemDrv->unmapPhyAddr() error");
    }
    if (pIMemDrv->freeVirtBuf(&rOutMem)) {
        MY_LOGE("m_pIMemDrv->freeVirtBuf() error");
    }


    //
    pIMemDrv->uninit();
    pIMemDrv->destroyInstance();
    return 0;
}
コード例 #6
0
static MUINT32 u4Y8002Y800_Cmd(int argc, char** argv)
{
	MUINT32 u4SrcWidth = 1600;
	MUINT32 u4SrcHeight = 1200;
	MUINT32 u4TargetWidth = 160;
	MUINT32 u4TargetHeight = 120;
	int srcFmt = 0;
	char filename[128];
	sprintf(filename, "/sdcard/hdr_sample_1600x1200_%d.y", 1);


    printf("SImager Test \n");
    //
    IMemDrv *pIMemDrv =  IMemDrv::createInstance();
    pIMemDrv->init();
    if (NULL == pIMemDrv)
    {
        printf("g_pIMemDrv is NULL");
        return 0;
    }
    //
    IMEM_BUF_INFO rInMem;
    rInMem.size = (u4SrcWidth * u4SrcHeight + L1_CACHE_BYTES-1) & ~(L1_CACHE_BYTES-1);
    if (pIMemDrv->allocVirtBuf(&rInMem)) {
        printf("g_pIMemDrv->allocVirtBuf() error");
    }
#if WORKAROUND_IMEM
    memset((void*)rInMem.virtAddr, 0 , rInMem.size);
    if (pIMemDrv->mapPhyAddr(&rInMem)) {
        printf("mpIMemDrv->mapPhyAddr() error");
    }
#endif

    if(!loadFileToBuf(filename, reinterpret_cast<MUINT8*>(rInMem.virtAddr), u4SrcWidth * u4SrcHeight)) {
	    printf("can't load image:%s\n", filename);
		return 0;
	}
    printf("load image:%s\n", filename);

    //
	IMEM_BUF_INFO rOutMem;
    rOutMem.size = (u4TargetWidth * u4TargetHeight + L1_CACHE_BYTES -1) & ~(L1_CACHE_BYTES-1);
    if (pIMemDrv->allocVirtBuf(&rOutMem)) {
        MY_LOGE("g_pIMemDrv->allocVirtBuf() error");
    }
#if WORKAROUND_IMEM
    //memset((void*)rOutMem.virtAddr, 0 , rOutMem.size);
    memset((void*)rOutMem.virtAddr, 128, rOutMem.size);
    if (pIMemDrv->mapPhyAddr(&rOutMem)) {
        MY_LOGE("mpIMemDrv->mapPhyAddr() error");
    }
#endif
#if 0
    //
    MUINT32 u4InStride[3] = {u4SrcWidth, u4SrcWidth, u4SrcWidth};
    ImgBufInfo rSrcImgInfo(ImgInfo(eImgFmt_YUY2, u4SrcWidth, u4SrcHeight),
                           BufInfo(rInMem.size, rInMem.virtAddr, rInMem.phyAddr, rInMem.memID), u4InStride);
#endif
	saveBufToFile("/sdcard/0001_input_1600x1200.y", (MUINT8 *)rInMem.virtAddr, rInMem.size);
	HdrShot::CDPResize_simple(
			&rInMem, u4SrcWidth, u4SrcHeight, eImgFmt_Y800,
			&rOutMem, u4TargetWidth, u4TargetHeight, eImgFmt_Y800, 0);
	saveBufToFile("/sdcard/0001_output_160x120.y", (MUINT8 *)rOutMem.virtAddr, rOutMem.size);

    //!***************************************************
    //! Main thread wait for exit
    //!***************************************************

    //
    //deallocMem(rInMem);
    //deallocMem(rOutMem);
    if (pIMemDrv->unmapPhyAddr(&rInMem)) {
        MY_LOGE("m_pIMemDrv->unmapPhyAddr() error");
    }
    if (pIMemDrv->freeVirtBuf(&rInMem)) {
        MY_LOGE("m_pIMemDrv->freeVirtBuf() error");
    }
    if (pIMemDrv->unmapPhyAddr(&rOutMem)) {
        MY_LOGE("m_pIMemDrv->unmapPhyAddr() error");
    }
    if (pIMemDrv->freeVirtBuf(&rOutMem)) {
        MY_LOGE("m_pIMemDrv->freeVirtBuf() error");
    }


    //
    pIMemDrv->uninit();
    pIMemDrv->destroyInstance();
    return 0;
}
コード例 #7
0
MBOOL
StereoNodeImpl::
allocBuffers(vector<HwPortConfig_t> & lPortCfg)
{
    FUNC_START;
    MBOOL ret = MFALSE;
    //
    vector< HwPortConfig_t >::const_iterator pConfig = lPortCfg.begin();
    IMemDrv* pIMemDrv =  IMemDrv::createInstance();
    if ( !pIMemDrv || !pIMemDrv->init() ) {
        MY_LOGE("pIMemDrv->init() error");
        goto lbExit;
    }
    for(MUINT32 i = 0; i < BUF_COUNT; ++i)
    {
        IMEM_BUF_INFO bufInfo;
        bufInfo.size = getHWFESize().size();
        if(pIMemDrv->allocVirtBuf(&bufInfo) < 0)
        {
            MY_LOGE("pIMemDrv->allocVirtBuf() error, i(%d)",i);
            goto lbExit;
        }
        if(pIMemDrv->mapPhyAddr(&bufInfo) < 0)
        {
            MY_LOGE("pIMemDrv->mapPhyAddr() error, i(%d)",i);
            goto lbExit;
        }
        mlFeBufQueue.push_back(bufInfo);
    }
    //
    while( pConfig != lPortCfg.end() )
    {
        MUINT32 nodedatatype = mapToNodeDataType(pConfig->mPortID);
        ICamBufHandler* pBufHdl = getBufferHandler(nodedatatype);
        MY_LOGD("handle(%p) data(%d) S(%dx%d)F(0x%x)", pBufHdl, nodedatatype, pConfig->mSize.w, pConfig->mSize.h, pConfig->mFmt);
        if( !pBufHdl )
        {
            MY_LOGE("no buffer hdl for data(%d)", nodedatatype);
            goto lbExit;
        }
        //alloc buffer
        AllocInfo allocinfo(pConfig->mSize.w, pConfig->mSize.h, pConfig->mFmt,
                eBUFFER_USAGE_SW_MASK | eBUFFER_USAGE_HW_MASK);

        if( nodedatatype == STEREO_IMG )
        {
            if ( !mDebugDumpGB )
                allocinfo.usage     = eBUFFER_USAGE_HW_RENDER|eBUFFER_USAGE_HW_TEXTURE|eBUFFER_USAGE_SW_WRITE_RARELY;
            else
                allocinfo.usage     = eBUFFER_USAGE_HW_RENDER|eBUFFER_USAGE_HW_TEXTURE|eBUFFER_USAGE_SW_WRITE_RARELY|eBUFFER_USAGE_SW_READ_RARELY;
            allocinfo.isGralloc = MTRUE;
        }

        for(MUINT32 i = 0; i < BUF_COUNT ; i++ )
        {
            if( !pBufHdl->requestBuffer(nodedatatype, allocinfo) )
            {
                MY_LOGE("request buffer failed: data %d", nodedatatype);
                goto lbExit;
            }
        }
        //
        pConfig++;
    }
    //
    ret = MTRUE;
lbExit:
    if ( !pIMemDrv ) {
        pIMemDrv->uninit();
        pIMemDrv->destroyInstance();
    }
    if( !ret ) {
        MY_LOGE("allocBuffers failed");
    }
    FUNC_END;
    return ret;
}