Ignore:
Timestamp:
Dec 28, 2016 3:40:07 AM (8 years ago)
Author:
nanang
Message:

Re #1900: More merged from trunk (r5512 mistakenly contains merged changes in third-party dir only).

Location:
pjproject/branches/projects/uwp
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • pjproject/branches/projects/uwp

  • pjproject/branches/projects/uwp/pjmedia/src/pjmedia-codec/openh264.cpp

    r5045 r5513  
    164164struct SLayerPEncCtx 
    165165{ 
    166   pj_int32_t                    iDLayerQp; 
    167   SSliceConfig                  sSliceCfg; 
     166    pj_int32_t                  iDLayerQp; 
     167    SSliceArgument              sSliceArgument; 
    168168}; 
    169169 
     
    471471 
    472472    /* Init encoder parameters */ 
    473     pj_bzero(&eprm, sizeof(eprm)); 
    474     eprm.iInputCsp                      = videoFormatI420; 
     473    oh264_data->enc->GetDefaultParams (&eprm); 
     474    eprm.iComplexityMode                = MEDIUM_COMPLEXITY; 
    475475    eprm.sSpatialLayers[0].uiProfileIdc = PRO_BASELINE; 
    476476    eprm.iPicWidth                      = param->enc_fmt.det.vid.size.w; 
     477    eprm.iUsageType                     = CAMERA_VIDEO_REAL_TIME; 
    477478    eprm.iPicHeight                     = param->enc_fmt.det.vid.size.h; 
    478479    eprm.fMaxFrameRate                  = (param->enc_fmt.det.vid.fps.num * 
    479480                                           1.0f / 
    480481                                           param->enc_fmt.det.vid.fps.denum); 
    481     eprm.uiFrameToBeCoded               = (unsigned int) -1; 
    482482    eprm.iTemporalLayerNum              = 1; 
    483483    eprm.uiIntraPeriod                  = 0; /* I-Frame interval in frames */ 
    484     eprm.bEnableSpsPpsIdAddition        = (oh264_data->whole? false : true); 
     484    eprm.eSpsPpsIdStrategy              = (oh264_data->whole ? CONSTANT_ID : 
     485                                           INCREASING_ID); 
    485486    eprm.bEnableFrameCroppingFlag       = true; 
    486487    eprm.iLoopFilterDisableIdc          = 0; 
     
    505506    pj_bzero(&elayer_ctx, sizeof (SLayerPEncCtx)); 
    506507    elayer_ctx.iDLayerQp                = 24; 
    507     elayer_ctx.sSliceCfg.uiSliceMode    = (oh264_data->whole ? 
    508                                             SM_SINGLE_SLICE : SM_DYN_SLICE); 
    509     elayer_ctx.sSliceCfg.sSliceArgument.uiSliceSizeConstraint = param->enc_mtu; 
    510     elayer_ctx.sSliceCfg.sSliceArgument.uiSliceNum      = 1; 
    511     elayer_ctx.sSliceCfg.sSliceArgument.uiSliceMbNum[0] = 960; 
    512     elayer_ctx.sSliceCfg.sSliceArgument.uiSliceMbNum[1] = 0; 
    513     elayer_ctx.sSliceCfg.sSliceArgument.uiSliceMbNum[2] = 0; 
    514     elayer_ctx.sSliceCfg.sSliceArgument.uiSliceMbNum[3] = 0; 
    515     elayer_ctx.sSliceCfg.sSliceArgument.uiSliceMbNum[4] = 0; 
    516     elayer_ctx.sSliceCfg.sSliceArgument.uiSliceMbNum[5] = 0; 
    517     elayer_ctx.sSliceCfg.sSliceArgument.uiSliceMbNum[6] = 0; 
    518     elayer_ctx.sSliceCfg.sSliceArgument.uiSliceMbNum[7] = 0; 
     508    elayer_ctx.sSliceArgument.uiSliceMode = (oh264_data->whole ? 
     509                                             SM_SINGLE_SLICE :  
     510                                             SM_SIZELIMITED_SLICE); 
     511 
     512    /* uiSliceSizeConstraint = uiMaxNalSize - NAL_HEADER_ADD_0X30BYTES */ 
     513    elayer_ctx.sSliceArgument.uiSliceSizeConstraint = param->enc_mtu - 50; 
     514    elayer_ctx.sSliceArgument.uiSliceNum      = 1; 
     515    elayer_ctx.sSliceArgument.uiSliceMbNum[0] = 960; 
     516    elayer_ctx.sSliceArgument.uiSliceMbNum[1] = 0; 
     517    elayer_ctx.sSliceArgument.uiSliceMbNum[2] = 0; 
     518    elayer_ctx.sSliceArgument.uiSliceMbNum[3] = 0; 
     519    elayer_ctx.sSliceArgument.uiSliceMbNum[4] = 0; 
     520    elayer_ctx.sSliceArgument.uiSliceMbNum[5] = 0; 
     521    elayer_ctx.sSliceArgument.uiSliceMbNum[6] = 0; 
     522    elayer_ctx.sSliceArgument.uiSliceMbNum[7] = 0; 
    519523 
    520524    elayer->iVideoWidth                 = eprm.iPicWidth; 
     
    524528    elayer->iSpatialBitrate             = eprm.iTargetBitrate; 
    525529    elayer->iDLayerQp                   = elayer_ctx.iDLayerQp; 
    526     elayer->sSliceCfg.uiSliceMode       = elayer_ctx.sSliceCfg.uiSliceMode; 
    527  
    528     memcpy( &elayer->sSliceCfg, 
    529             &elayer_ctx.sSliceCfg, 
    530             sizeof (SSliceConfig)); 
    531     memcpy( &elayer->sSliceCfg.sSliceArgument.uiSliceMbNum[0], 
    532             &elayer_ctx.sSliceCfg.sSliceArgument.uiSliceMbNum[0], 
    533             sizeof (elayer_ctx.sSliceCfg.sSliceArgument.uiSliceMbNum)); 
     530    elayer->sSliceArgument.uiSliceMode = elayer_ctx.sSliceArgument.uiSliceMode; 
     531 
     532    memcpy ( &elayer->sSliceArgument, 
     533             &elayer_ctx.sSliceArgument, 
     534             sizeof (SSliceArgument)); 
     535    memcpy ( &elayer->sSliceArgument.uiSliceMbNum[0], 
     536             &elayer_ctx.sSliceArgument.uiSliceMbNum[0], 
     537             sizeof (elayer_ctx.sSliceArgument.uiSliceMbNum)); 
    534538 
    535539    /* Init input picture */ 
     
    553557    } 
    554558 
     559    int videoFormat = videoFormatI420; 
     560    rc = oh264_data->enc->SetOption (ENCODER_OPTION_DATAFORMAT, &videoFormat); 
     561    if (rc != cmResultSuccess) { 
     562        PJ_LOG(4,(THIS_FILE, "SVC encoder SetOption videoFormatI420 failed, " 
     563                             "rc=%d", rc)); 
     564        return PJMEDIA_CODEC_EFAILED; 
     565    } 
     566     
    555567    /* 
    556568     * Decoder 
    557569     */ 
    558570    sDecParam.sVideoProperty.size       = sizeof (sDecParam.sVideoProperty); 
    559     sDecParam.iOutputColorFormat        = videoFormatI420; 
    560571    sDecParam.uiTargetDqLayer           = (pj_uint8_t) - 1; 
    561     sDecParam.uiEcActiveFlag            = 1; 
     572    sDecParam.eEcActiveIdc              = ERROR_CON_SLICE_COPY; 
    562573    sDecParam.sVideoProperty.eVideoBsType = VIDEO_BITSTREAM_DEFAULT; 
    563574 
     
    575586        PJ_LOG(4,(THIS_FILE, "Decoder initialization failed, rc=%d", rc)); 
    576587        return PJMEDIA_CODEC_EFAILED; 
    577     } 
    578  
    579     pj_int32_t color_fmt = videoFormatI420; 
    580     rc = oh264_data->dec->SetOption (DECODER_OPTION_DATAFORMAT,  &color_fmt); 
    581     if (rc) { 
    582         PJ_LOG(4,(THIS_FILE, 
    583                  "Warning: SetOption(DECODER_OPTION_DATAFORMAT) failed, rc=%d", 
    584                  rc)); 
    585588    } 
    586589 
     
    662665    } 
    663666 
    664     if (oh264_data->bsi.eOutputFrameType == videoFrameTypeSkip) { 
     667    if (oh264_data->bsi.eFrameType == videoFrameTypeSkip) { 
    665668        output->size = 0; 
    666669        output->type = PJMEDIA_FRAME_TYPE_NONE; 
     
    682685        /* Find which layer with biggest payload */ 
    683686        oh264_data->ilayer = 0; 
    684         payload_size = oh264_data->bsi.sLayerInfo[0].iNalLengthInByte[0]; 
     687        payload_size = oh264_data->bsi.sLayerInfo[0].pNalLengthInByte[0]; 
    685688        for (i=0; i < (unsigned)oh264_data->bsi.iLayerNum; ++i) { 
    686689            unsigned j; 
    687690            pLayerBsInfo = &oh264_data->bsi.sLayerInfo[i]; 
    688691            for (j=0; j < (unsigned)pLayerBsInfo->iNalCount; ++j) { 
    689                 if (pLayerBsInfo->iNalLengthInByte[j] > (int)payload_size) { 
    690                     payload_size = pLayerBsInfo->iNalLengthInByte[j]; 
     692                if (pLayerBsInfo->pNalLengthInByte[j] > (int)payload_size) { 
     693                    payload_size = pLayerBsInfo->pNalLengthInByte[j]; 
    691694                    oh264_data->ilayer = i; 
    692695                } 
     
    704707        payload_size = 0; 
    705708        for (int inal = pLayerBsInfo->iNalCount - 1; inal >= 0; --inal) { 
    706             payload_size += pLayerBsInfo->iNalLengthInByte[inal]; 
     709            payload_size += pLayerBsInfo->pNalLengthInByte[inal]; 
    707710        } 
    708711 
     
    761764        output->size = payload_len; 
    762765 
    763         if (oh264_data->bsi.eOutputFrameType == videoFrameTypeIDR) { 
     766        if (oh264_data->bsi.eFrameType == videoFrameTypeIDR) { 
    764767            output->bit_info |= PJMEDIA_VID_FRM_KEYFRAME; 
    765768        } 
     
    783786    oh264_data->enc_frame_size = 0; 
    784787    for (int inal = pLayerBsInfo->iNalCount - 1; inal >= 0; --inal) { 
    785         oh264_data->enc_frame_size += pLayerBsInfo->iNalLengthInByte[inal]; 
     788        oh264_data->enc_frame_size += pLayerBsInfo->pNalLengthInByte[inal]; 
    786789    } 
    787790 
     
    810813    output->size = payload_len; 
    811814 
    812     if (oh264_data->bsi.eOutputFrameType == videoFrameTypeIDR) { 
     815    if (oh264_data->bsi.eFrameType == videoFrameTypeIDR) { 
    813816        output->bit_info |= PJMEDIA_VID_FRM_KEYFRAME; 
    814817    } 
Note: See TracChangeset for help on using the changeset viewer.