status_t PVPlayerExtensionHandler::callPlayerExtension(PlayerExtensionCommand* cmd, const Parcel& request, Parcel& reply)
{
    status_t status;
    int32_t opcode = -1;
    status = request.readInt32(&opcode);
    switch(opcode) {
        case EXTN_HANDLER_CMD_QUERY_EXTN_IFACE: {
            LOGV("callPlayerExtension EXTN_HANDLER_CMD_QUERY_EXTN_IFACE ");
            status = queryExtnIface(request , reply);
            if (NO_ERROR != status) {
                getPlayerDriver().commandFailed((PlayerCommand*)cmd);
            } else {
                FinishSyncCommand((PlayerCommand*)cmd);
            }
            return status;
        }
        case EXTN_HANDLER_CMD_EXTN_API_CALL: {  
            LOGV("callPlayerExtension EXTN_HANDLER_CMD_EXTN_API_CALL");
            //Extract the handle
            IDispatch* extIface = (IDispatch*)request.readInt32();
            if (extIface){
                LOGV("callPlayerExtension extIface=%d",(int)extIface);
                //invoke the requested API
                return extIface->invoke(request,reply,cmd);
            }else{
                status = reply.writeInt32(INVALID_OPERATION);
                getPlayerDriver().commandFailed((PlayerCommand*)cmd);
                return status;
            }
        }
        case EXTN_HANDLER_CMD_RELEASE_EXTN_IFACE: {  
            LOGV("callPlayerExtension EXTN_HANDLER_CMD_RELEASE_EXTN_IFACE");
            //Extract the handle
            IDispatch* extIface = (IDispatch*)request.readInt32();
            if (extIface && (1 == iExtensionInstancesList.remove_element(extIface))) {
                LOGV("callPlayerExtension Release extIface=%d",(int)extIface);
                //Release Extension
                delete extIface; 
                status = reply.writeInt32(NO_ERROR);
                FinishSyncCommand((PlayerCommand*)cmd);
                return status;
            } else {
                status = reply.writeInt32(INVALID_OPERATION);
                getPlayerDriver().commandFailed((PlayerCommand*)cmd);
                return status;
            }
        }
        default:
            LOGE("Unknown opcode %d", opcode);
            status = reply.writeInt32(INVALID_OPERATION);
            getPlayerDriver().commandFailed((PlayerCommand*)cmd);
            return status;
    }

}