我想通过usb建立平板电脑和stm32之间的通信,为此我在代码中添加了usb库。在代码中添加库时,我遇到了这个错误。
错误[Pe167]:类型“uint16_t *”的参数与“unsigned char *”类型的参数不兼容
我正在使用IAR Embedded Workbench EWARM工具进行stm32编码。错误是在下面显示的函数返回行上进行的。
static USBH_Status USBH_ADK_getProtocol ( USB_OTG_CORE_HANDLE *pdev, USBH_HOST *phost)
{
phost->Control.setup.b.bmRequestType = USB_D2H | USB_REQ_TYPE_VENDOR | USB_REQ_RECIPIENT_DEVICE;
phost->Control.setup.b.bRequest = ACCESSORY_GET_PROTOCOL;
phost->Control.setup.b.wValue.w = 0;
phost->Control.setup.b.wIndex.w = 0;
phost->Control.setup.b.wLength.w = 2;
abc= ADK_Machine.protocol;
/* Control Request */
return USBH_CtlReq(pdev, phost, &ADK_Machine.protocol , 2 );
}
功能USBH_CtlReq是
USBH_Status USBH_CtlReq (USB_OTG_CORE_HANDLE *pdev,
USBH_HOST *phost,
uint8_t *buff,
uint16_t length)
{
USBH_Status status;
status = USBH_BUSY;
switch (phost->RequestState)
{
case CMD_SEND:
/* Start a SETUP transfer */
USBH_SubmitSetupRequest(phost, buff, length);
phost->RequestState = CMD_WAIT;
status = USBH_BUSY;
break;
case CMD_WAIT:
if (phost->Control.state == CTRL_COMPLETE )
{
/* Commands successfully sent and Response Received */
phost->RequestState = CMD_SEND;
phost->Control.state =CTRL_IDLE;
status = USBH_OK;
}
else if (phost->Control.state == CTRL_ERROR)
{
/* Failure Mode */
phost->RequestState = CMD_SEND;
status = USBH_FAIL;
}
else if (phost->Control.state == CTRL_STALLED )
{
/* Commands successfully sent and Response Received */
phost->RequestState = CMD_SEND;
status = USBH_NOT_SUPPORTED;
}
break;
default:
break;
}
return status;
}
任何人都可以帮我解决这个问题。谢谢。
答案 0 :(得分:0)
AFAICT,在该行:
return USBH_CtlReq(pdev, phost, &ADK_Machine.protocol , 2 );
ADK_Machine.protocol
是uint16_t
。如果这是真的,那么,取其地址将产生uint16_t *
,该uint8_t*
不能转换为USBH_CtlReq
期望的uint8_t*
。
C中的许多低级“发送”函数将参数声明为unsigned char*
或void*
,以表示它们期望“字节”。原则上,他们也可以声明return USBH_CtlReq(pdev, phost, (uint8_t*)&ADK_Machine.protocol , 2 );
。
但是,在这种情况下,唯一要做的就是施放,比如:
{{1}}
当然,你需要注意这不会照顾到字节序。