Merge pull request #101 from ferrous-systems/add-device-index

setup-stage.md: add values for DEVICE descriptor, clarify instructions
This commit is contained in:
Jonas Schievink 2020-08-24 12:34:49 +02:00 committed by GitHub
commit 0a6cdf4216
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -21,23 +21,29 @@ Start with the GET_DESCRIPTOR request, which is described in detail in section 9
[usb_spec]: https://www.usb.org/document-library/usb-20-specification [usb_spec]: https://www.usb.org/document-library/usb-20-specification
The fields of a GET_DESCRIPTOR request are as follows: We can recognize a GET_DESCRIPTOR request by the following properties:
- `bmRequestType` is **0b10000000** - `bmRequestType` is **0b10000000**
- `bRequest` is **6** (i.e. the GET_DESCRIPTOR Request Code, see table 9-4 in the USB spec) - `bRequest` is **6** (i.e. the GET_DESCRIPTOR Request Code, defined in table 9-4 in the USB spec)
- the high byte of `wValue` contains the descriptor type, whereas the low byte contains the descriptor index
- `wIndex` is set to 0 for our purposes In this task, we only want to parse DEVICE descriptor requests. They have the following properties:
- the descriptor type is **1** (i.e. DEVICE, defined in table 9-5 of the USB spec)
- the descriptor index is **0**
- the wIndex is **0** for our purposes
- ❗you need to fetch the descriptor type from the high byte of `wValue`, and the descriptor index from the the low byte of `wValue`
You will also find this information in the `// TODO implement ...` comment in the `Request::parse()` function of `lib.rs` file. You will also find this information in the `// TODO implement ...` comment in the `Request::parse()` function of `lib.rs` file.
> NOTE: If you'd like to learn more, take a look at Section 9.4.3 Get Descriptor of the USB specification. > NOTE: If you'd like to learn more, take a look at Section 9.4.3 Get Descriptor of the USB specification.
To complete the task, proceed like this: To complete the task, proceed like this:
1. **Parse GET_DESCRIPTOR requests:** 1. **Parse GET_DESCRIPTOR requests for DEVICE descriptors:**
Modify `Request::parse()` in `advanced/common/usb/src/lib.rs` to recognize a GET_DESCRIPTOR request so that the `get_descriptor_device` test passes. Note that the parser already handles SET_ADDRESS requests. Modify `Request::parse()` in `advanced/common/usb/src/lib.rs` to recognize a GET_DESCRIPTOR request of type DEVICE so that the `get_descriptor_device` test passes. Note that the parser already handles SET_ADDRESS requests.
- remember the GET_DESCRIPTOR fields described at the start of this section - remember the GET_DESCRIPTOR fields described at the start of this section
- remember that you can define binary literals by prefixing them with `0b` - remember that you can define binary literals by prefixing them with `0b`
- you can use bit shifts (`>>`) and casts (`as u8`) to get the high/low bytes of a `u16` - you can use bit shifts (`>>`) and casts (`as u8`) to get the high/low bytes of `wValue`
See `advanced/common/usb/solution-get-descriptor-device.rs` for a solution. See `advanced/common/usb/solution-get-descriptor-device.rs` for a solution.