UsbCtrlMessage: Difference between revisions
Appearance
	
	
|  Created page with "==Description== Executes synchronous Control Transfer with the default endpoint.  ==Syntax== <pre> UsbCtrlMessage(Handle,ucRequestType,ucRequest,usValue,usIndex,usLength,*pucD..." | mNo edit summary | ||
| (3 intermediate revisions by one other user not shown) | |||
| Line 3: | Line 3: | ||
| ==Syntax== | ==Syntax== | ||
|  ulrc = UsbCtrlMessage(Handle,ucRequestType,ucRequest,usValue,usIndex,usLength,pucData,ulTimeout) | |||
| UsbCtrlMessage(Handle,ucRequestType,ucRequest,usValue,usIndex,usLength, | |||
| ==Parameters== | ==Parameters== | ||
| ; Handle : | ; Handle : the Device Handle received from the previous [[UsbOpen]]. | ||
| ; ucRequestType : the characteristics of the Standard Device Request.  | |||
| ; ucRequestType :   | ; ucRequest : the specific request code of the Standard Device Request. | ||
| ; usValue : the request dependent value of the Standard Device Request. | |||
| ; ucRequest | ; usIndex : the request dependent index of the Standard Device Request. | ||
| ; ulTimeout : the timeout to wait for completion in milliseconds. | |||
| ; usValue :   | ''For device-to-host data transfer:'' | ||
| ; usLength : the number of bytes to be transferred or 0 for no data transfer. | |||
| ;  | ; pucData : the address of the buffer to receive the data bytes transferred.  | ||
| ''For host-to-device data transfer:'' | |||
| ; usLength :   | ; usLength : the number of bytes to be transferred or 0 for no data transfer. | ||
| ; pucData : the address of the buffer with the data bytes to be transferred. | |||
| ;  | |||
| ;  | |||
| ==Return Code== | ==Return Code== | ||
|  0x0000 - NO_ERROR | |||
| ===Errors=== | ===Errors=== | ||
| <pre> | |||
| 0x0006 - ERROR_INVALID_HANDLE | |||
| 0x0008 - ERROR_NOT_ENOUGH_MEMORY | |||
| 0x0057 - ERROR_INVALID_PARAMETER | |||
| 0x005F - ERROR_INTERRUPT | |||
| 0x0122 - ERROR_TOO_MANY_HANDLES | |||
| 0x0280 - ERROR_TIMEOUT | |||
| 0x1B58 - USB_NOT_INIT | |||
| 0x4000 - USB_IORB_REQUEST | |||
| 0x80XX - USB_IORB_FAILED | |||
| 0xFF0D - ERROR_INVALID_DATA | |||
| 0xFF13 - ERROR_I24_INVALID_PARAMETER | |||
| 0xFF13 - USB_IDC_PARMERR | |||
| 0xFF18 - USB_IDC_ADDRINV | |||
| 0xFF37 - ERROR_DEV_NOT_EXIST | |||
| 0xFF5D - EROR_NO_ITEMS | |||
| 0xFFA7 - ERROR_LOCK_FAILED | |||
| </pre> | |||
| ==Remarks== | ==Remarks== | ||
| Line 32: | Line 46: | ||
| ==Example Code== | ==Example Code== | ||
| <pre> | <pre> | ||
| //Code Snippet - UsbCtrlMessage | |||
| { | |||
|   APIRET ulrc; | |||
|   PUCHAR pucReport; | |||
|   UCHAR ucReport[4096]; | |||
|   UCHAR ucRequestType; | |||
|   UCHAR ucRequest; | |||
|   ULONG ulTimeout = 8000; | |||
|   USHORT usIndex; | |||
|   USHORT usLength; | |||
|   USHORT usValue; | |||
|   //device-to-host | |||
|   pucReport = &ucReport[0]; | |||
|   ucRequestType = 0xA1; ucRequest = 0x01; //get interface class report | |||
|   usIndex = 0x0000; usValue = 0x0100; usLength = 8; //hid input report | |||
|   ulrc = UsbCtrlMessage(Handle,ucRequestType,ucRequest,usValue,usIndex,usLength,pucReport,ulTimeout); | |||
|   printf("\nUsbCtrlMessage - ulrc: 0x%04X (%hu)",ulrc,ulrc); | |||
|   if (!ulrc) //success | |||
|   { | |||
|     int i; printf(" - hid input report:\n"); | |||
|     for (i=0;i<usLength;i++) printf("%02X",ucReport[i]); | |||
|   } | |||
|   //host-to-device | |||
|   pucReport = &ucReport[0]; | |||
|   ucRequestType = 0x21; ucRequest = 0x09; //set interface class report | |||
|   usIndex = 0x0000; usValue = 0x0100; usLength = 8; //hid input report | |||
|   ulrc = UsbCtrlMessage(Handle,ucRequestType,ucRequest,usValue,usIndex,usLength,pucReport,ulTimeout); | |||
|   printf("\nUsbCtrlMessage - ulrc: 0x%04X (%hu)",ulrc,ulrc); | |||
|   if (!ulrc) //success | |||
|   { | |||
|     int i; printf(" - hid input report:\n"); | |||
|     for (i=0;i<usLength;i++) printf("%02X",ucReport[i]); | |||
|   } | |||
| } | |||
| </pre> | </pre> | ||
| ==Related Functions== | ==Related Functions== | ||
| * [[UsbDeviceGetDescriptor]] | |||
| * [[UsbConfigurationGetDescriptor]] | |||
| * [[UsbDeviceSetConfiguration]] | |||
| * [[UsbInterfaceSetAltSetting]] | |||
| * [[UsbEndpointClearHalt]] | |||
| * [[UsbQueryDeviceReport]] | |||
| * [[UsbOpen]] | |||
| [[Category:USBCalls]] | [[Category:USBCalls]] | ||
Latest revision as of 20:45, 13 September 2021
Description
Executes synchronous Control Transfer with the default endpoint.
Syntax
ulrc = UsbCtrlMessage(Handle,ucRequestType,ucRequest,usValue,usIndex,usLength,pucData,ulTimeout)
Parameters
- Handle
- the Device Handle received from the previous UsbOpen.
- ucRequestType
- the characteristics of the Standard Device Request.
- ucRequest
- the specific request code of the Standard Device Request.
- usValue
- the request dependent value of the Standard Device Request.
- usIndex
- the request dependent index of the Standard Device Request.
- ulTimeout
- the timeout to wait for completion in milliseconds.
For device-to-host data transfer:
- usLength
- the number of bytes to be transferred or 0 for no data transfer.
- pucData
- the address of the buffer to receive the data bytes transferred.
For host-to-device data transfer:
- usLength
- the number of bytes to be transferred or 0 for no data transfer.
- pucData
- the address of the buffer with the data bytes to be transferred.
Return Code
0x0000 - NO_ERROR
Errors
0x0006 - ERROR_INVALID_HANDLE 0x0008 - ERROR_NOT_ENOUGH_MEMORY 0x0057 - ERROR_INVALID_PARAMETER 0x005F - ERROR_INTERRUPT 0x0122 - ERROR_TOO_MANY_HANDLES 0x0280 - ERROR_TIMEOUT 0x1B58 - USB_NOT_INIT 0x4000 - USB_IORB_REQUEST 0x80XX - USB_IORB_FAILED 0xFF0D - ERROR_INVALID_DATA 0xFF13 - ERROR_I24_INVALID_PARAMETER 0xFF13 - USB_IDC_PARMERR 0xFF18 - USB_IDC_ADDRINV 0xFF37 - ERROR_DEV_NOT_EXIST 0xFF5D - EROR_NO_ITEMS 0xFFA7 - ERROR_LOCK_FAILED
Remarks
Example Code
//Code Snippet - UsbCtrlMessage
{
  APIRET ulrc;
  PUCHAR pucReport;
  UCHAR ucReport[4096];
  UCHAR ucRequestType;
  UCHAR ucRequest;
  ULONG ulTimeout = 8000;
  USHORT usIndex;
  USHORT usLength;
  USHORT usValue;
  //device-to-host
  pucReport = &ucReport[0];
  ucRequestType = 0xA1; ucRequest = 0x01; //get interface class report
  usIndex = 0x0000; usValue = 0x0100; usLength = 8; //hid input report
  ulrc = UsbCtrlMessage(Handle,ucRequestType,ucRequest,usValue,usIndex,usLength,pucReport,ulTimeout);
  printf("\nUsbCtrlMessage - ulrc: 0x%04X (%hu)",ulrc,ulrc);
  if (!ulrc) //success
  {
    int i; printf(" - hid input report:\n");
    for (i=0;i<usLength;i++) printf("%02X",ucReport[i]);
  }
  //host-to-device
  pucReport = &ucReport[0];
  ucRequestType = 0x21; ucRequest = 0x09; //set interface class report
  usIndex = 0x0000; usValue = 0x0100; usLength = 8; //hid input report
  ulrc = UsbCtrlMessage(Handle,ucRequestType,ucRequest,usValue,usIndex,usLength,pucReport,ulTimeout);
  printf("\nUsbCtrlMessage - ulrc: 0x%04X (%hu)",ulrc,ulrc);
  if (!ulrc) //success
  {
    int i; printf(" - hid input report:\n");
    for (i=0;i<usLength;i++) printf("%02X",ucReport[i]);
  }
}