本文整理汇总了C++中SII_DEBUG_PRINT函数的典型用法代码示例。如果您正苦于以下问题:C++ SII_DEBUG_PRINT函数的具体用法?C++ SII_DEBUG_PRINT怎么用?C++ SII_DEBUG_PRINT使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了SII_DEBUG_PRINT函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: SendRcp
ssize_t SendRcp(struct device *dev, struct device_attribute *attr,
const char *buf, size_t count)
{
unsigned long keyCode;
int status = -EINVAL;
SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE,"SendRcp received string: ""%s""\n", buf);
if(HalAcquireIsrLock() != HAL_RET_SUCCESS)
{
return -ERESTARTSYS;
}
while(gDriverContext.flags & MHL_STATE_FLAG_RCP_READY) {
if(strict_strtoul(buf, 0, &keyCode)) {
SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE,"Unable to convert keycode string\n");
break;
}
if(keyCode >= 0xFE) {
SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE,"keycode (0x%x) is too large to be valid\n", (int)keyCode);
break;
}
gDriverContext.flags &= ~(MHL_STATE_FLAG_RCP_RECEIVED |
MHL_STATE_FLAG_RCP_ACK |
MHL_STATE_FLAG_RCP_NAK);
gDriverContext.flags |= MHL_STATE_FLAG_RCP_SENT;
gDriverContext.keyCode = (uint8_t)keyCode;
SiiMhlTxRcpSend((uint8_t)keyCode);
status = count;
break;
}
HalReleaseIsrLock();
return status;
}
示例2: HalSmbusWriteBlock
/**
* @brief Write a series of bytes to an I2c device using SMBus protocol.
*
*****************************************************************************/
halReturn_t HalSmbusWriteBlock(uint8_t command, uint8_t const *blockData,
uint8_t length)
{
halReturn_t retStatus;
int32_t status;
retStatus = I2cAccessCheck();
if (retStatus != HAL_RET_SUCCESS)
{
return retStatus;
}
if(length > I2C_SMBUS_BLOCK_MAX)
{
SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE,
"HalSmbusWriteBlock, bufferLen param too big (%d) max size (%d)!\n",
length, I2C_SMBUS_BLOCK_MAX);
return HAL_RET_PARAMETER_ERROR;
}
status = i2c_smbus_write_i2c_block_data(gMhlDevice.pI2cClient, command,
length, blockData);
if (status < 0)
{
SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE,
"i2c_smbus_write_i2c_block_data returned error: %d\n",status);
return HAL_RET_FAILURE;
}
return HAL_RET_SUCCESS;
}
示例3: HalGpioConfigStatus
static halReturn_t HalGpioConfigStatus(enum iomux_func status)
{
int ret = 0;
struct iomux_block *pMhlGpioBlock = NULL;
struct block_config *pMhlGpioBlockConfig = NULL;
/* get gpio block*/
pMhlGpioBlock = iomux_get_block(MHL_GPIO_BLOCK_NAME);
if (IS_ERR(pMhlGpioBlock))
{
SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE,"HalGpioSetResource: Get GPIO Block Failed\n");
return HAL_RET_FAILURE;
}
/* get gpio block config*/
pMhlGpioBlockConfig = iomux_get_blockconfig(MHL_GPIO_BLOCK_NAME);
if (IS_ERR(pMhlGpioBlockConfig))
{
SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE,"HalGpioSetResource: get GPIO Block Config Failed\n");
return HAL_RET_FAILURE;
}
/* config gpio work mode*/
ret = blockmux_set(pMhlGpioBlock, pMhlGpioBlockConfig, status);
if (ret)
{
SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE,"HalGpioConfigStatus: Config GPIO Block Failed\n");
return HAL_RET_FAILURE;
}
return HAL_RET_SUCCESS;
}
示例4: HalGpioGetPin
/**
* @brief Platform specific function to get the input pin value of the MHL
* transmitter device.
*
*****************************************************************************/
halReturn_t HalGpioGetPin(GpioIndex_t gpio,int * value)
{
halReturn_t halRet;
GPIOInfo_t *pGpioInfo;
halRet = HalInitCheck();
if(halRet != HAL_RET_SUCCESS)
{
return halRet;
}
pGpioInfo = GetGPIOInfo(gpio);
if(!pGpioInfo)
{
SII_DEBUG_PRINT(MSG_ERR,"%d is NOT right gpio_index!\n",(int)gpio);
return HAL_RET_FAILURE;
}
if(pGpioInfo->gpio_direction != DIRECTION_IN)
{
SII_DEBUG_PRINT(MSG_ERR,"gpio(%d) is NOT input gpio!\n",pGpioInfo->gpio_number);
return HAL_RET_FAILURE;
}
*value = gpio_get_value(pGpioInfo->gpio_number);
return HAL_RET_SUCCESS;
}
示例5: StopMhlTxDevice
int32_t StopMhlTxDevice(void)
{
halReturn_t halStatus;
printk("Stopping %s\n", MHL_PART_NAME);
HalRemoveIrqHandler();
//HalRemoveSilMonRequestIrqHandler();
#ifdef RGB_BOARD
//HalRemoveSilExtDeviceIrqHandler();
#endif
halStatus = HalCloseI2cDevice();
if (halStatus != HAL_RET_SUCCESS)
{
SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE,
"Closing of I2c device failed, error code: %d\n",halStatus);
return -EIO;
}
halStatus = HalTerm();
if (halStatus != HAL_RET_SUCCESS)
{
SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE,
"Termination of HAL failed, error code: %d\n",halStatus);
return -EIO;
}
SiiOsTerm();
return 0;
}
示例6: HalSmbusReadBlock
/**
* @brief Read a series of bytes from an I2c device using SMBus protocol.
*
*****************************************************************************/
halReturn_t HalSmbusReadBlock(uint8_t command, uint8_t *buffer, uint8_t *bufferLen)
{
halReturn_t retStatus;
int32_t status;
retStatus = I2cAccessCheck();
if (retStatus != HAL_RET_SUCCESS)
{
return retStatus;
}
if(*bufferLen > I2C_SMBUS_BLOCK_MAX)
{
SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE,
"HalSmbusReadBlock, bufferLen param too big (%d) max size (%d)!\n",
*bufferLen, I2C_SMBUS_BLOCK_MAX);
return HAL_RET_PARAMETER_ERROR;
}
status = i2c_smbus_read_i2c_block_data(gMhlDevice.pI2cClient, command,
*bufferLen, buffer);
if (status < 0)
{
SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE,
"i2c_smbus_read_i2c_block_data returned error: %d\n",status);
return HAL_RET_FAILURE;
}
*bufferLen = (uint8_t)status; /* return # of bytes read */
return HAL_RET_SUCCESS;
}
示例7: HalGpioSetPin
/**
* @brief Platform specific function to set the output pin to control the MHL
* transmitter device.
*
*****************************************************************************/
halReturn_t HalGpioSetPin(GpioIndex_t gpio,int value)
{
halReturn_t halRet;
GPIOInfo_t *pGpioInfo;
halRet = HalInitCheck();
if(halRet != HAL_RET_SUCCESS)
{
return halRet;
}
pGpioInfo = GetGPIOInfo(gpio);
if(!pGpioInfo)
{
SII_DEBUG_PRINT(MSG_ERR,"%d is NOT right gpio_index!\n",(int)gpio);
return HAL_RET_FAILURE;
}
if(pGpioInfo->gpio_direction != DIRECTION_OUT)
{
SII_DEBUG_PRINT(MSG_ERR,"gpio(%d) is NOT ouput gpio!\n",pGpioInfo->gpio_number);
return HAL_RET_FAILURE;
}
gpio_set_value(pGpioInfo->gpio_number, value ? 1 : 0);
if(value)
{
SII_DEBUG_PRINT(MSG_STAT,">> %s to HIGH <<\n",pGpioInfo->gpio_descripion);
}
else
{
SII_DEBUG_PRINT(MSG_STAT,">> %s to LOW <<\n",pGpioInfo->gpio_descripion);
}
return HAL_RET_SUCCESS;
}
示例8: HalInstallIrqHandler
halReturn_t HalInstallIrqHandler(fwIrqHandler_t irqHandler)
{
//int retStatus;
halReturn_t halRet;
init_waitqueue_head(&mhl_irq_wq);
mhl_irq_task = kthread_create(mhl_irq_kthread, NULL, "hdmi_update_kthread");
wake_up_process(mhl_irq_task);
if(irqHandler == NULL)
{
SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE,"HalInstallIrqHandler: irqHandler cannot be NULL!\n");
return HAL_RET_PARAMETER_ERROR;
}
halRet = I2cAccessCheck();
if (halRet != HAL_RET_SUCCESS)
{
return halRet;
}
#if 0
if(gMhlDevice.pI2cClient->irq == 0)
{
SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE,"HalInstallIrqHandler: No IRQ assigned to I2C device!\n");
return HAL_RET_FAILURE;
}
#endif
#if 0
mt_set_gpio_mode(GPIO_MHL_EINT_PIN, GPIO_MODE_01);
mt_set_gpio_dir(GPIO_MHL_EINT_PIN, GPIO_DIR_IN);
mt_set_gpio_pull_select(GPIO_MHL_EINT_PIN, GPIO_PULL_UP);
mt_set_gpio_pull_enable(GPIO_MHL_EINT_PIN, true);
#endif
mt65xx_eint_set_sens(CUST_EINT_MHL_NUM, MT65xx_LEVEL_SENSITIVE);
mt65xx_eint_registration(CUST_EINT_MHL_NUM, 0, MT65XX_EINT_POL_NEG, &mhl8338_irq_handler, 0);
#if 0
gMhlDevice.irqHandler = irqHandler;
retStatus = request_threaded_irq(gMhlDevice.pI2cClient->irq, NULL,
HalThreadedIrqHandler,
IRQF_TRIGGER_LOW | IRQF_ONESHOT,
gMhlI2cIdTable[0].name,
&gMhlDevice);
if(retStatus != 0)
{
SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE,"HalInstallIrqHandler: request_threaded_irq failed, status: %d\n",
retStatus);
gMhlDevice.irqHandler = NULL;
return HAL_RET_FAILURE;
}
#endif
return HAL_RET_SUCCESS;
}
示例9: HalOpenI2cDevice
/**
* @brief Request access to the specified I2c device.
*
*****************************************************************************/
halReturn_t HalOpenI2cDevice(char const *DeviceName, char const *DriverName)
{
halReturn_t retStatus;
int32_t retVal;
retStatus = HalInitCheck();
if (retStatus != HAL_RET_SUCCESS)
{
return retStatus;
}
retVal = strnlen(DeviceName, I2C_NAME_SIZE);
if (retVal >= I2C_NAME_SIZE)
{
SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE, "I2c device name too long!\n");
return HAL_RET_PARAMETER_ERROR;
}
memcpy(gMhlI2cIdTable[0].name, DeviceName, retVal);
gMhlI2cIdTable[0].name[retVal] = 0;
gMhlI2cIdTable[0].driver_data = 0;
gMhlDevice.driver.driver.name = DriverName;
gMhlDevice.driver.id_table = gMhlI2cIdTable;
gMhlDevice.driver.probe = MhlI2cProbe;
gMhlDevice.driver.remove = MhlI2cRemove;
retVal = i2c_add_driver(&gMhlDevice.driver);
if (retVal != 0)
{
SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE, "I2C driver add failed\n");
retStatus = HAL_RET_FAILURE;
}
else
{
if (gMhlDevice.pI2cClient == NULL)
{
i2c_del_driver(&gMhlDevice.driver);
SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE, "I2C driver add failed\n");
retStatus = HAL_RET_NO_DEVICE;
}
else
{
retStatus = HAL_RET_SUCCESS;
}
}
return retStatus;
}
示例10: HalGpioInit
/**
* @brief Configure platform GPIOs needed by the MHL device.
*
*****************************************************************************/
halReturn_t HalGpioInit(void)
{
int status;
int i ,j;
#if 0 // pinmux need not be configed here in aml platform. by Jets, Nov/25/2013
HalSetPinMux();
#endif
aml_get_gpio();
for(i =0; i< ARRAY_SIZE(GPIO_List);i++)
{
/* Request GPIO . */
status = gpio_request(GPIO_List[i].gpio_number, GPIO_List[i].gpio_descripion);
if (status < 0 && status != -EBUSY)
{
SII_DEBUG_PRINT(MSG_ERR,"HalInit gpio_request for GPIO %d (H/W Reset) failed, status: %d\n", GPIO_List[i].gpio_number, status);
for(j = 0; j < i;j++)
{
gpio_free(GPIO_List[j].gpio_number);
}
return HAL_RET_FAILURE;
}
if(GPIO_List[i].gpio_direction == DIRECTION_OUT)
{
status = gpio_direction_output(GPIO_List[i].gpio_number, GPIO_List[i].init_value);
}
else
{
status = gpio_direction_input(GPIO_List[i].gpio_number);
}
if (status < 0)
{
SII_DEBUG_PRINT(MSG_ERR,"HalInit gpio_direction_output for GPIO %d (H/W Reset) failed, status: %d\n", GPIO_List[i].gpio_number, status);
for(j = 0; j <= i;j++)
{
gpio_free(GPIO_List[j].gpio_number);
}
return HAL_RET_FAILURE;
}
// SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE,"initialize %s successfully\n",GPIO_List[i].gpio_descripion);
}
return HAL_RET_SUCCESS;
}
示例11: HalSilMonRequestIrqHandler
/**
* @brief SilMon IRQ handler,
*
*****************************************************************************/
static irqreturn_t HalSilMonRequestIrqHandler(int irq, void *data)
{
pMhlDeviceContext pMhlDevContext = (pMhlDeviceContext)data;
int gpio_value;
unsigned long flags;
// SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE,"------------- HalSilMonRequestIrqHandler irq coming! -------------\n");
spin_lock_irqsave(&pMhlDevContext->SilMonRequestIRQ_Lock, flags);
if(HalGpioGetPin(GPIO_REQ_IN,&gpio_value)<0)
{
SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE,"HalSilMonRequestIrqHandler GPIO(%d) get error\n",gpio_value);
spin_unlock_irqrestore(&pMhlDevContext->SilMonRequestIRQ_Lock, flags);
return IRQ_HANDLED;
}
/*
the following is for void wrongly invoke irq, it may be caused by EMI when plug in/out MHL cable;
*/
if((gMhlDevice.SilMonControlReleased&& gpio_value)
||(!gMhlDevice.SilMonControlReleased&&!gpio_value))
{
SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE,"HalSilMonRequestIrqHandler, wrong IRQ coming, please check you board\n");
spin_unlock_irqrestore(&pMhlDevContext->SilMonRequestIRQ_Lock, flags);
return IRQ_HANDLED;
}
if(gpio_value)
{
HalGpioSetPin(GPIO_GNT,1);
HalEnableI2C(true);
enable_irq(pMhlDevContext->pI2cClient->irq);
SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE,"release SiliMon control\n");
gMhlDevice.SilMonControlReleased = true;
}
else
{
disable_irq(pMhlDevContext->pI2cClient->irq);
HalEnableI2C(false);
HalGpioSetPin(GPIO_GNT,0);
SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE,"under SiliMon control \n");
gMhlDevice.SilMonControlReleased = false;
}
spin_unlock_irqrestore(&pMhlDevContext->SilMonRequestIRQ_Lock, flags);
return IRQ_HANDLED;
}
示例12: HalInit
halReturn_t HalInit(void)
{
//halReturn_t status;
if (gHalInitedFlag)
{
SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE,"Error: Hal layer already inited!\n");
return HAL_RET_ALREADY_INITIALIZED;
}
gMhlDevice.driver.driver.name = NULL;
gMhlDevice.driver.id_table = NULL;
gMhlDevice.driver.probe = NULL;
gMhlDevice.driver.remove = NULL;
gMhlDevice.pI2cClient = NULL;
gMhlDevice.irqHandler = NULL;
#ifdef RGB_BOARD
gMhlDevice.ExtDeviceirqHandler = NULL;
#endif
/*
status = HalGpioInit();
if(status != HAL_RET_SUCCESS)
{
return status;
}
*/
gHalInitedFlag = true;
return HAL_RET_SUCCESS;
}
示例13: HalThreadedIrqHandler
/*
* @brief Interrupt handler for MHL transmitter interrupts.
*
* @param[in] irq The number of the asserted IRQ line that caused
* this handler to be called.
* @param[in] data Data pointer passed when the interrupt was enabled,
* which in this case is a pointer to the
* MhlDeviceContext of the I2c device.
*
* @return Always returns IRQ_HANDLED.
*
*****************************************************************************/
static irqreturn_t HalThreadedIrqHandler(int irq, void *data)
{
pMhlDeviceContext pMhlDevContext = (pMhlDeviceContext)data;
// SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE,"HalThreadedIrqHandler called\n");
if (HalAcquireIsrLock() == HAL_RET_SUCCESS)
{
/*
if(pMhlDevContext->CheckDevice &&!pMhlDevContext->CheckDevice(0))//mhl device check;
{
SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE,"mhl device errror\n");
HalReleaseIsrLock();
return IRQ_HANDLED;
}
*/
if(pMhlDevContext->irqHandler)
{
(pMhlDevContext->irqHandler)();
}
HalReleaseIsrLock();
}
else
{
SII_DEBUG_PRINT(MSG_ERR,"------------- irq missing! -------------\n");
}
return IRQ_HANDLED;
}
示例14: ReadDevCap
ssize_t ReadDevCap(struct device *dev, struct device_attribute *attr,
char *buf)
{
uint8_t regValue;
int status = -EINVAL;
SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE, "ReadDevCap called\n");
if(HalAcquireIsrLock() != HAL_RET_SUCCESS)
{
return -ERESTARTSYS;
}
do {
if(gDriverContext.flags & MHL_STATE_FLAG_CONNECTED) {
status = SiiTxGetPeerDevCapEntry(gDriverContext.devCapOffset,
®Value);
if(status != 0) {
status = -EAGAIN;
break;
}
status = scnprintf(buf, PAGE_SIZE, "offset:0x%02x=0x%02x",
gDriverContext.devCapOffset, regValue);
}
} while(false);
HalReleaseIsrLock();
return status;
}
示例15: HalI2cMasterRead
/**
* @brief Read a series of bytes from an I2c device.
*
*****************************************************************************/
halReturn_t HalI2cMasterRead(uint8_t i2cAddr, uint8_t length,
uint8_t *buffer)
{
struct i2c_msg i2cMsg;
halReturn_t retStatus;
int32_t status;
retStatus = I2cAccessCheck();
if (retStatus != HAL_RET_SUCCESS)
{
return retStatus;
}
i2cMsg.addr = (i2cAddr >> 1);
i2cMsg.flags = I2C_M_RD;
i2cMsg.len = length;
i2cMsg.buf = buffer;
status = i2c_transfer(gMhlDevice.pI2cClient->adapter, &i2cMsg, 1);
if (status < 0)
{
SII_DEBUG_PRINT(SII_OSAL_DEBUG_TRACE, "i2c_transfer error: %d\n",status);
return HAL_RET_FAILURE;
}
return HAL_RET_SUCCESS;
}