Cypress Ez Usb Driver Xp
I have this board Cypress CY7C68013A EZ-USB FX2LP USB2.0. I need its driver for windows xp sp3. I have downloaded its CY7C68013Adevelopment_board kit but its doesnt run with windows xp. Kindly help me to install it.
page_type | description | languages | products |
---|---|---|---|
Demonstrates how to use KMDF to perform bulk and interrupt data transfers to a USB device. |
|
The kmdf_fx2 sample is a Kernel-Mode Driver Framework (KMDF) driver for the OSR USB-FX2 device. It includes a test app and sample device metadata.
In the Windows Driver Kit (WDK), the osrusbfx2 sample demonstrated how to perform bulk and interrupt data transfers to an USB device. The sample was written for the OSR USB-FX2 Learning Kit.
The specification for the device is at http://www.osronline.com/hardware/OSRFX2_32.pdf. The driver and sample device metadata also work with the Custom driver access sample.
Universal Windows Driver Compliant
This sample builds a Universal Windows Driver. It uses only APIs and DDIs that are included in OneCoreUAP.
Overview
Here is the overview of the device:
- The device is based on the development board supplied with the Cypress EZ-USB FX2 Development Kit (CY3681).
- It contains 1 interface and 3 endpoints (Interrupt IN, Bulk Out, Bulk IN).
- Firmware supports vendor commands to query or set LED Bar graph display and 7-segment LED display, and to query toggle switch states.
- Interrupt endpoint:
- Sends an 8-bit value that represents the state of the switches.
- Sent on startup, resume from suspend, and whenever the switch pack setting changes.
- Firmware does not de-bounce the switch pack.
- One switch change can result in multiple bytes being sent.
- Bits are in the reverse order of the labels on the pack (for example, bit 0x80 is labeled 1 on the pack).
- Bulk endpoints are configured for loopback:
- The device moves data from IN endpoint to OUT endpoint.
- The device does not change the values of the data it receives nor does it internally create any data.
- Endpoints are always double buffered.
- Maximum packet size depends on speed (64 full speed, 512 high speed).
- Event Tracing for Windows (ETW) events:
- Included osrusbfx2.man, which describes events added.
- Three events are targeted to the event log:
- Failure during the add device routine.
- Failure to start the OSR device on a USB 1.1 controller.
- Invocation of the 're-enumerate device' IOCTL.
- Read/write start/stop events can be used to measure the time taken.
- For more information, see Unified Tracing later in this document.
Code tour
usbkmdf_fx2driver
This directory contains driver code that demonstrates the following functionality:
- Loads the driver and responds to PnP and Power events. You can install, uninstall, disable, enable, suspend, and resume the system.
- Creates a context with the WDFDEVICE object.
- Initializes the USB device by registering a EvtPrepareHardware callback.
- Marks the interface restricted so that it can be accessed by a privileged UWP device app.
- Creates a default parallel queue to receive an IOCTL request to set bar graph display.
- Retrieves memory handle from the requests and uses it to send a vendor command to the USB device.
- Registers read and write events on the default queue.
- Retrieves memory from read and write requests, formats the requests, and sends it to a USB target.
- Creates two separate sequential queues and configures them to dispatch read and write requests directly. (*kmdf_fx2 only)
- Enables wait-wake and selective suspend support. (*kmdf_fx2 only)
- Configures a USB target continuous reader to read toggle switch states asynchronously from the interrupt endpoint. (*kmdf_fx2 only)
- Supports additional IOCTLs to get and set the 7-segment display and toggle switches, and to reset and re-enumerate the device. (*kmdf_fx2 only)
- Creates ETW provider to log two events to the event log, and read/write start stop events. (*kmdf_fx2 only)
- WPP tracing.
usbkmdf_fx2exe
This directory contains a test application that can be used to drive the KMDF driver and FX2 device.
usbkmdf_fx2deviceMetadata
This directory contains the device metadata package for the sample. You must copy the device metadata to the system before installing the device. For information on how to update and deploy device metadata, see the Custom driver access sample.
Testing the driver
You can use the Custom driver access sample as a testing method.
The sample also includes a test application, osrusbfx2.exe, that you can use to test the device. This console application enumerates the interface registered by the driver and opens the device to send read, write, or IOCTL requests based on the command line options.
Usage for Read/Write test:
- -r [n], where n is number of bytes to read.
- -w [n], where n is number of bytes to write.
- -c [n], where n is number of iterations (default = 1).
- -v, shows verbose read data.
- -p, plays with Bar Display, Dip Switch, 7-Segment Display.
- -a, performs asynchronous I/O operation.
- -u, dumps USB configuration and pipe information.
Playing with the 7 segment display, toggle switches, and bar graph display
Use the command, osrusbfx2.exe -p options 1-9, to set and clear bar graph display, set and get 7 segment state, and read the toggle switch states. The following shows the function options:
Reset and re-enumerate the device
Use the command, osrusbfx2.exe -p with option 10 and 11, to either reset the device or re-enumerate the device.
Ez Usb Driver Xp
Read and write to bulk endpoints
The following commands send read and write requests to the device's bulk endpoint.
osrusbfx2.exe -r 64
The preceding command reads 64 bytes to the bulk IN endpoint.
osrusbfx2.exe -w 64
The preceding command writes 64 bytes to the bulk OUT endpoint.
osrusbfx2.exe -r 64 -w 64 -c 100 -v
The preceding command first writes 64 bytes of data to bulk OUT endpoint (Pipe 1), then reads 64 bytes from bulk IN endpoint (Pipe 2), and then compares the read buffer with write buffer to see if they match. If the buffer contents match, it repeats this operation 100 times.
osrusbfx2.exe -a
The preceding command reads and writes to the device asynchronously in an infinite loop.
The bulk endpoints are double buffered. Depending on the operational speed (full or high), the buffer size is either 64 bytes or 512 bytes, respectively. A request to read data does not complete if the buffers are empty. If the buffers are full, a request to write data does not complete until the buffers are emptied. When you are doing a synchronous read, make sure the endpoint buffer has data (for example, when you send a 512 bytes write request to the device operating in full speed mode). Because the endpoints are double buffered, the total buffer capacity is 256 bytes. The first 256 bytes fills the buffer, and the write request waits in the USB stack until the buffers are emptied. If you run another instance of the application to read 512 bytes of data, both write and read requests complete successfully.
Displaying descriptors
The following command displays all the descriptors and endpoint information.
osrusbfx2.exe -u
If the device is operating in high speed mode, you will get the following information:
Unified tracing
To view events the provider manifest must be installed. As part of the installation, from an elevated prompt run the following: wevtutil im osrusbfx2.man
Registering the manifest sets up the appropriate paths where the system can find information for decoding the events. The OSR event log can be found in the system event viewer under Event ViewerApplications and Services LogsOSRUSBFx2Operational channel eventlog. Triggering a device re-enumeration through osrusbfx2.exe sends an event to this log.
Cypress Usb Driver
To trace, you can use the in-box tools, logman and tracerpt, or download XPerf (Windows Performance Toolkit) from Microsoft.
Using in-box tools
To start/stop the trace by using logman:
Start tracing by using the following command:
logman start sample -o osrusbfx2.etl -ets -p OSRUSBFX2
Generate activity through the osrusbfx2 test application, such as
osrusbfx2.exe -a
.Stop tracing by using the following command:
Logman stop sample
View the trace file using tracerpt:
tracerpt -of csv OSRUSBFX2.etl
Xp Usb Driver Download
To start/stop the trace by using Xperf (Windows Performance Toolkit):
Start tracing by using the following command:
xperf -start sample -f osrusbfx2.etl -on OSRUSBFX2
Generate activity through the osrusbfx2 test application, such as
osrusbfx2.exe -a
.Stop tracing by using the following command:
xperf -stop sample
View the trace file using Xperf:
xperfview OSRUSBFX2.etl