RxUsbStringGetDescriptor
Appearance
Description
Executes the Standard Device Request that obtains the String Descriptor.
Syntax
rc = RxUsbStringGetDescriptor(Handle,Index,Language,Length,Descriptor)
Parameters
- Handle
- the Device Handle received from the previous RxUsbOpen.
- Index
- the Descriptor Index or 0 to obtain the array of Language Codes.
- Language
- the Language Code or 0 to use the Language Code for English.
- Length
- the desired number of bytes or 0 for the whole String Descriptor.
- Descriptor
- the name of the variable to receive the String Descriptor.
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
/* add RxUsbStringGetDescriptor */ rc = RxFuncAdd('RxUsbStringGetDescriptor','usbcalls','RxUsbStringGetDescriptor') say '+RxUsbStringGetDescriptor(),RC=0x'd2x(rc) /* invoke RxUsbStringGetDescriptor */ Index=2 /* second string descriptor index */ Language=x2d(0409) /* the english language */ Length=0 /* defaults to receive whole descriptor */ drop Descriptor /* receives string descriptor */ rc = RxUsbStringGetDescriptor(Handle,Index,Language,Length,Descriptor) say '*RxUsbStringGetDescriptor(),RC=0x'd2x(rc) /* drop RxUsbStringGetDescriptor */ rc = RxFuncDrop('RxUsbStringGetDescriptor') say '-RxUsbStringGetDescriptor(),RC=0x'd2x(rc)