UsbDataTransfer: Difference between revisions
Appearance
Created page with "==Description== Executes synchronous Bulk or Interrupt Transfer with a specific endpoint. ==Syntax== <pre> ulrc=UsbDataTransfer(Handle,Endpoint,AltInterface,*pulNumBytes,*puc..." |
|||
(4 intermediate revisions by the same user not shown) | |||
Line 4: | Line 4: | ||
==Syntax== | ==Syntax== | ||
<pre> | <pre> | ||
ulrc=UsbDataTransfer(Handle, | ulrc = UsbDataTransfer(Handle,ucEndpoint,ucAltSetting,pulNumBytes,pucData,ulTimeout,usFlags) | ||
</pre> | </pre> | ||
==Parameters== | ==Parameters== | ||
; Handle : | ; Handle : the Device Handle received from the previous UsbOpen. | ||
; ucEndpoint : the Endpoint Number appropriate for the data transfer. | |||
; ucAltSetting : the Alternate Setting of the interface having this endpoint. | |||
; ulTimeout : the timeout to wait for completion in milliseconds. | |||
; | ; usFlags : use 1 to transfer all data or 0 to allow less transferred. | ||
''For device-to-host data transfer:'' | |||
; | ; pulNumBytes : the address of the variable to specify/receive the number of bytes. | ||
; | ; pucData : the address of the buffer to receive the data bytes transferred. | ||
''For host-to-device data transfer:'' | |||
; | ; pulNumBytes : the address of the variable to specify/receive the number of bytes. | ||
; pucData : the address of the buffer with the data bytes to be transferred. | |||
==Return Code== | ==Return Code== | ||
<pre> | |||
0x0000 - NO_ERROR | |||
</pre> | |||
===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 | |||
0x1B5B - USB_ERROR_INVALID_ENDPOINT | |||
0x1B5C - USB_ERROR_LESSTRANSFERED | |||
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 43: | Line 60: | ||
==Example Code== | ==Example Code== | ||
<pre> | <pre> | ||
//Code Snippet - UsbDataTransfer | |||
{ | |||
APIRET ulrc; | |||
PUCHAR pucData; | |||
PULONG pulNumBytes; | |||
UCHAR ucAltSetting = 0; | |||
UCHAR ucData[4096]; | |||
UCHAR ucEndpoint; | |||
ULONG ulNumBytes; | |||
ULONG ulTimeout = 8000; | |||
USHORT usFlags; | |||
//device-to-host | |||
ucEndpoint = 0x81; usFlags = 0; | |||
pucData = &ucData[0]; pulNumBytes = &ulNumBytes; ulNumBytes = sizeof(ucData); | |||
ulrc = UsbDataTransfer(Handle,ucEndpoint,ucAltSetting,pulNumBytes,pucData,ulTimeout,usFlags); | |||
printf("\nUsbDataTransfer - ulrc: 0x%04X (%hu)",ulrc,ulrc); | |||
if (!ulrc) //success | |||
{ | |||
int i; printf(" - bulk/interrupt data:\n"); | |||
for (i=0;i<ulNumBytes;i++) printf("%02X",ucData[i]); | |||
} | |||
//host-to-device | |||
ucEndpoint = 0x02; usFlags = USB_TRANSFER_FULL_SIZE; | |||
pucData = &ucData[0]; pulNumBytes = &ulNumBytes; ulNumBytes = sizeof(ucData); | |||
ulrc = UsbDataTransfer(Handle,ucEndpoint,ucAltSetting,pulNumBytes,pucData,ulTimeout,usFlags); | |||
printf("\nUsbDataTransfer - ulrc: 0x%04X (%hu)",ulrc,ulrc); | |||
if (!ulrc) //success | |||
{ | |||
int i; printf(" - bulk/interrupt data:\n"); | |||
for (i=0;i<ulNumBytes;i++) printf("%02X",ucData[i]); | |||
} | |||
} | |||
</pre> | </pre> | ||
==Related Functions== | ==Related Functions== | ||
* [[UsbBulkRead]] | |||
* [[UsbBulkWrite]] | |||
* [[UsbIrqRead]] | |||
* [[UsbIrqWrite]] | |||
* [[UsbStartDataTransfer]] | |||
* [[UsbOpen]] | |||
[[Category:USBCalls]] | [[Category:USBCalls]] |
Latest revision as of 17:35, 12 February 2017
Description
Executes synchronous Bulk or Interrupt Transfer with a specific endpoint.
Syntax
ulrc = UsbDataTransfer(Handle,ucEndpoint,ucAltSetting,pulNumBytes,pucData,ulTimeout,usFlags)
Parameters
- Handle
- the Device Handle received from the previous UsbOpen.
- ucEndpoint
- the Endpoint Number appropriate for the data transfer.
- ucAltSetting
- the Alternate Setting of the interface having this endpoint.
- ulTimeout
- the timeout to wait for completion in milliseconds.
- usFlags
- use 1 to transfer all data or 0 to allow less transferred.
For device-to-host data transfer:
- pulNumBytes
- the address of the variable to specify/receive the number of bytes.
- pucData
- the address of the buffer to receive the data bytes transferred.
For host-to-device data transfer:
- pulNumBytes
- the address of the variable to specify/receive the number of bytes.
- 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 0x1B5B - USB_ERROR_INVALID_ENDPOINT 0x1B5C - USB_ERROR_LESSTRANSFERED 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 - UsbDataTransfer { APIRET ulrc; PUCHAR pucData; PULONG pulNumBytes; UCHAR ucAltSetting = 0; UCHAR ucData[4096]; UCHAR ucEndpoint; ULONG ulNumBytes; ULONG ulTimeout = 8000; USHORT usFlags; //device-to-host ucEndpoint = 0x81; usFlags = 0; pucData = &ucData[0]; pulNumBytes = &ulNumBytes; ulNumBytes = sizeof(ucData); ulrc = UsbDataTransfer(Handle,ucEndpoint,ucAltSetting,pulNumBytes,pucData,ulTimeout,usFlags); printf("\nUsbDataTransfer - ulrc: 0x%04X (%hu)",ulrc,ulrc); if (!ulrc) //success { int i; printf(" - bulk/interrupt data:\n"); for (i=0;i<ulNumBytes;i++) printf("%02X",ucData[i]); } //host-to-device ucEndpoint = 0x02; usFlags = USB_TRANSFER_FULL_SIZE; pucData = &ucData[0]; pulNumBytes = &ulNumBytes; ulNumBytes = sizeof(ucData); ulrc = UsbDataTransfer(Handle,ucEndpoint,ucAltSetting,pulNumBytes,pucData,ulTimeout,usFlags); printf("\nUsbDataTransfer - ulrc: 0x%04X (%hu)",ulrc,ulrc); if (!ulrc) //success { int i; printf(" - bulk/interrupt data:\n"); for (i=0;i<ulNumBytes;i++) printf("%02X",ucData[i]); } }