& WizChan. Driver Documentation

Similar documents
DYNAMIC ENGINEERING 435 Park Dr., Ben Lomond, Calif Fax Est

DYNAMIC ENGINEERING 435 Park Dr., Ben Lomond, Calif Fax Est

DYNAMIC ENGINEERING 435 Park Dr., Ben Lomond, Calif Fax Est

DYNAMIC ENGINEERING 150 DuBois St., Suite C Santa Cruz, CA (831) Fax (831) Est.

DYNAMIC ENGINEERING 150 DuBois, Suite C, Santa Cruz, CA Fax Est

DYNAMIC ENGINEERING 435 Park Dr., Ben Lomond, Calif Fax Est

DYNAMIC ENGINEERING 150 DuBois, Suite 3 Santa Cruz, CA (831) Fax (831) Est

DYNAMIC ENGINEERING 150 DuBois, Suite 3 Santa Cruz, CA (831) Fax (831) Est

DYNAMIC ENGINEERING 435 Park Dr., Ben Lomond, Calif Fax Est

DYNAMIC ENGINEERING 435 Park Dr., Ben Lomond, Calif Fax Est

DYNAMIC ENGINEERING 435 Park Dr., Ben Lomond, Calif Fax Est

DYNAMIC ENGINEERING 150 DuBois St Suite 3, Santa Cruz CA Fax Est.

DYNAMIC ENGINEERING 435 Park Dr., Ben Lomond, Calif Fax Est

DYNAMIC ENGINEERING 150 DuBois, Suite 3 Santa Cruz, CA (831) Fax (831) Est.

PcieAltBase & PcieAltChan

PHLnkBase & PHLnkChan

ccpmc Parallel TTL BA18 Base & Channel

DYNAMIC ENGINEERING 150 DuBois, Suite C Santa Cruz, CA (831) Fax (831) Est.

PMC Parallel TTL BA17 Base & Channel

DYNAMIC ENGINEERING 150 DuBois St., Suite C Santa Cruz, CA Fax Est.

DYNAMIC ENGINEERING 150 DuBois, Suite C Santa Cruz, CA (831) Fax (831) Est.

DYNAMIC ENGINEERING. 150 DuBois, Suite C Santa Cruz, CA (831) Fax (831) Est.

DYNAMIC ENGINEERING 150 DuBois St. Suite C, Santa Cruz, CA Fax Est.

Pci3Ip, Pci5Ip, Pc104pIp, Pc104p4Ip, cpci2ip, cpci4ip and PcieCar IndustryPack Carrier Device Drivers

spwr_base & spwr_chan

IP-429-II ARINC 429 Interface 1-4 Transmitters 2-8 Receivers

DYNAMIC ENGINEERING 150 DuBois, Suite C Santa Cruz, CA (831) Fax (831) Est

PMC Parallel TTL BA16 Base. Channel Software Manual

DYNAMIC ENGINEERING 150 DuBois Suite C Santa Cruz, CA (831) Fax (831) Est.

DYNAMIC ENGINEERING 435 Park Dr., Ben Lomond, Calif Fax Est

CC Pilot XS. Backlight interface description

Table Of Contents. Rev. 1.0 Page 2

PMC-BiSerial-III SDLC 8-Channel SDLC Interface

PCIeBiSerial-L3com1 One-Channel Half Duplex Interface

DYNAMIC ENGINEERING 150 DuBois St., Suite C Santa Cruz, CA (831) Fax (831) Est.

Stand-Alone-Relay S-A-Relay

DYNAMIC ENGINEERING. 150 DuBois St. #3, Santa Cruz Ca Fax Est

DYNAMIC ENGINEERING 150 DuBois St. Suite 3, Santa Cruz Ca Fax Est

cpci-dart Base-Board & Daughter-Board

UPS25 API Manual for Windows 2000/XP/Vista

PCI-EK01 Driver Level Programming Guide

Software Specification. For. J1708 Driver

DYNAMIC ENGINEERING 150 DuBois St. Suite 3, Santa Cruz, Calif Fax Est.

DYNAMIC ENGINEERING 150 DuBois St. Suite C, Santa Cruz, CA Fax Est.

DYNAMIC ENGINEERING 150 DuBois St. Suite C Santa Cruz CA Fax Est.

DYNAMIC ENGINEERING 150 DuBois St. Suite C Santa Cruz CA Fax Est.

IVI-6.2: VISA Interoperability Requirements for USBTMC Specification

IP-Unidig-E Line Input/Output with LineSafe ESD Protection IndustryPack User s Manual

DYNAMIC ENGINEERING 435 Park Dr., Ben Lomond, Calif Fax Est

BBK-PCI. User s Manual. Document: Document No.: Date: File:

DYNAMIC ENGINEERING 150 DuBois St., Suite C Santa Cruz, CA (831) Fax (831) Est.

JetBox 8152 User Manual. WinCE 5.0 Canbus.

PCI LVDS 8T 8 Channel LVDS Serial Interface Dynamic Engineering 435 Park Drive, Ben Lomond, CA

Title: Migrating to Delcom USB HID Chip Set (Generation 2) from the Delcom USB custom driver Chip Set (Generation 1).

tekdxfxsl FibreXtreme I/O Interface

PMC-BiSerial-III SDLC

ADS Windows CE Digital I/O Driver

User Manual UNO-1251G. Windows Embedded Compact7 Software Manual

DM6816 Driver for Windows 98/NT4/2000/XP

Visualization Of Hard Disk Geometry And Master Boot Record

DYNAMIC ENGINEERING 150 DuBois St. Suite C, Santa Cruz, Calif Fax Est.

DYNAMIC ENGINEERING 150 DuBois St. Suite C, Santa Cruz, Ca Fax Est.

S3C6400 HW Mulimedia Codec (MFC) User s Guide. S3C6400 HW Multimedia Codec (MFC) User s Guide

BBK-PCI light. User s Manual

Tape Channel Analyzer Windows Driver Spec.

DM6810/DM6910 Driver for Windows 98/NT4/2000/XP User s Manual version 4.0

NSPI Driver. NetDCU. Windows CE. Native SPI Support. Version 2.0 ( )

AN10955 Full-duplex software UART for LPC111x and LPC13xx

DYNAMIC ENGINEERING 150 DuBois, Suite C Santa Cruz, CA (831) Fax (831) Est

DYNAMIC ENGINEERING 150 DuBois, Suite 3 Santa Cruz, CA (831) Fax (831) Est

IP-QuadUART-485-PLRA

ssj1708 User s Manual Version 1.3 Revised February 2nd, 2009 Created by the J1708 Experts

REAL TIME OPERATING SYSTEM PROGRAMMING-II: II: Windows CE, OSEK and Real time Linux. Lesson-9: WCE Serial Communication, Network, device-to

Artisan Scientific is You~ Source for: Quality New and Certified-Used/Pre:-awned ECJuiflment

DYNAMIC ENGINEERING 150 Dubois St. Suite C, Santa Cruz, CA Fax Est.

APPLICATION NOTE 9.15

DYNAMIC ENGINEERING. 435 Park Dr., Ben Lomond, Calif Fax Est.

DYNAMIC ENGINEERING 435 Park Dr., Ben Lomond, Calif Fax Est

PCMCIA Flash Card User Guide

PCI-ASCB Avionics Bus Tester

USBIO. USB Software Development Kit for Windows. Reference Manual. Version 2.0 January 31, 2003

ExpressCard Serial Card

CM17215HR 100Mb/s Fiber CM17212HR 10/100Mb/s UTP PC/104-Plus Dual Ethernet utilitymodule. User s Manual

Artisan Technology Group is your source for quality new and certified-used/pre-owned equipment

3.5 inch Hard Drive Enclosure. Model #: HDE350U. User s Manual

3.5 inch Hard Drive Enclosure. User s Manual

WinCE6.0 I2C SMDKV210. Revision 1.00 October Samsung Electronics Co., Ltd. All rights reserved.

CE56273 Associated Part Families: CY8C38xx/CY8C55xx Software: PSoC Creator Related Hardware: CY8CKIT-001 Author: Anu M D

Addonics. 4X SATA Multilane PCI/PCI-X RAID5 Controller Card (ADS3GX4R5-ML) User s Guide Revision 1.1 T E C H N O L O G I E S

Addonics. 4-Port SATA II PCI RAID5/JBOD Controller Card (ADSA4R5) User s Guide Revision 1.0 T E C H N O L O G I E S

CM17215HR 100Mb/s Fiber CM17212HR 10/100Mb/s UTP PC/104-Plus Dual Ethernet utilitymodule. User s Manual. BDM Rev. C

PCI GS or PCIe8 LX Time Distribution Board

HIGH PERFORMANCE ECP/EPP PRINTER INTERFACE USING THE PPC34C60 PPIC

Human Interface Devices: Host Application

HumidiProbe User Guide

USB Server User Manual

VMISFT-RFM2G. Drivers for Windows NT, 2000, 2003 Server and XP Operating Systems Installation Guide Document Number # Rev.

Neousys Technology Inc. PCIe-PoE354at/PCIe-PoE352at. User s Manual. Rev. A1

Sensoray Model 627 CompactPCI to PCI Adapter

Small Logger File System

Transcription:

DYNAMIC ENGINEERING 150 DuBois St. Suite C, Santa Cruz, CA 95060 831-457-8891 Fax 831-457-4793 http://www.dyneng.com sales@dyneng.com Est. 1988 PmcWiz & WizChan Driver Documentation Win32 Driver Model Revision B Corresponding Hardware: Revision A/B 10-2005-0501/0502 Corresponding Firmware: Revision B

PmcWiz, WizChan WDM Device Drivers for the PMC-Wizard 2-Channel WizardLink Interface Dynamic Engineering 150 DuBois St. Suite C Santa Cruz, CA 95060 831-457-8891 831-457-4793 FAX 2012 by Dynamic Engineering. Other trademarks and registered trademarks are owned by their respective manufactures. Manual Revision B. Revised February 24, 2012 This document contains information of proprietary interest to Dynamic Engineering. It has been supplied in confidence and the recipient, by accepting this material, agrees that the subject matter will not be copied or reproduced, in whole or in part, nor its contents revealed in any manner or to any person except to meet the purpose for which it was delivered. Dynamic Engineering has made every effort to ensure that this manual is accurate and complete. Still, the company reserves the right to make improvements or changes in the product described in this document at any time and without notice. Furthermore, Dynamic Engineering assumes no liability arising out of the application or use of the device described herein. The electronic equipment described herein generates, uses, and can radiate radio frequency energy. Operation of this equipment in a residential area is likely to cause radio interference, in which case the user, at his own expense, will be required to take whatever measures may be required to correct the interference. Dynamic Engineering s products are not authorized for use as critical components in life support devices or systems without the express written approval of the president of Dynamic Engineering. Connection of incompatible hardware is likely to cause serious damage. Embedded Hardware and Software Solutions Page 2 of 21

Table of Contents Introduction... 4 Note... 4 Driver Installation... 4 Windows 2000 Installation... 5 Windows XP Installation... 5 Driver Startup... 6 IO Controls... 13 IOCTL_PMC_WIZ_GET_INFO... 13 IOCTL_PMC_WIZ_LOAD_PLL_DATA... 13 IOCTL_PMC_WIZ_READ_PLL_DATA... 14 IOCTL_PMC_WIZ_GET_INT_STATUS... 14 IOCTL_PMC_WIZ_REGISTER_EVENT... 14 IOCTL_PMC_WIZ_ENABLE_INTERRUPT... 14 IOCTL_PMC_WIZ_DISABLE_INTERRUPT... 14 IOCTL_PMC_WIZ_FORCE_INTERRUPT... 15 IOCTL_PMC_WIZ_GET_ISR_STATUS... 15 IOCTL_WIZ_CHAN_GET_INFO... 16 IOCTL_WIZ_CHAN_RESET_FIFOS... 16 IOCTL_WIZ_CHAN_SET_CONFIG... 16 IOCTL_WIZ_CHAN_GET_CONFIG... 16 IOCTL_WIZ_CHAN_GET_STATUS... 16 IOCTL_WIZ_CHAN_SET_SYNC_PATTERN... 16 IOCTL_WIZ_CHAN_GET_SYNC_PATTERN... 17 IOCTL_WIZ_CHAN_SET_FIFO_LEVELS... 17 IOCTL_WIZ_CHAN_GET_FIFO_LEVELS... 17 IOCTL_WIZ_CHAN_WRITE_FIFO... 17 IOCTL_WIZ_CHAN_READ_FIFO... 17 IOCTL_WIZ_CHAN_GET_FIFO_COUNTS... 17 IOCTL_WIZ_CHAN_SET_IDLE_CONFIG... 18 IOCTL_WIZ_CHAN_GET_IDLE_CONFIG... 18 IOCTL_WIZ_CHAN_REGISTER_EVENT... 18 IOCTL_WIZ_CHAN_ENABLE_INTERRUPT... 18 IOCTL_WIZ_CHAN_DISABLE_INTERRUPT... 18 IOCTL_WIZ_CHAN_FORCE_INTERRUPT... 19 IOCTL_WIZ_CHAN_GET_ISR_STATUS... 19 Write... 20 Read... 20 Warranty and Repair... 20 Service Policy... 21 Out of Warranty Repairs... 21 For Service Contact:... 21 Embedded Hardware and Software Solutions Page 3 of 21

Introduction The PmcWiz and WizChan drivers are Win32 driver model (WDM) device drivers for the PMC-Wizard from Dynamic Engineering. The PMC-Wizard board has a Spartan3-1500 Xilinx FPGA to implement the PCI interface, FIFOs and protocol control and status for two WizardLink channels. Each channel has two 4k x 32-bit data FIFOs for data transmission and reception. When the PMC-Wizard is recognized by the PCI bus configuration utility it will start the PmcWiz driver. The PmcWiz driver enumerates the two channels and creates a separate WizChan device object for each. This allows the I/O channels to be totally independent while the base driver controls the device items that are common to both channels. IO Control calls (IOCTLs) are used to configure the board and read status. Read and Write calls are used to move blocks of data in and out of the I/O channel devices. Note This documentation will provide information about all calls made to the drivers, and how the drivers interact with the device for each of these calls. For more detailed information on the hardware implementation, refer to the PMC-Wizard user manual (also referred to as the hardware manual). Driver Installation There are several files provided in each driver package. These files include PmcWiz.sys, PmcWiz.inf, DDPmcWiz.h, PmcWizGUID.h, WizChan.sys, WizChan.inf, DDWizChan.h, WizChanGUID.h, PmcWizTest.exe, and PmcWizTest source files. Embedded Hardware and Software Solutions Page 4 of 21

Windows 2000 Installation Copy PmcWiz.inf, WizChan.inf, PmcWiz.sys and WizChan.sys to a floppy disk, CD, or some other accessible location. With the PmcWizard hardware installed, power-on the PCI host computer and wait for the Found New Hardware Wizard dialogue window to appear. Select Next. Select Search for a suitable driver for my device. Select Next. Insert the disk prepared above in the desired drive. Select the appropriate drive e.g. Floppy disk drives. Select Next. The wizard should find the PmcWiz.inf file. Select Next. Select Finish to close the Found New Hardware Wizard. The system should now see the PmcWizard channels and reopen the New Hardware Wizard. Proceed as above for each channel as necessary. Windows XP Installation Copy PmcWiz.inf, WizChan.inf, PmcWiz.sys and WizChan.sys to a floppy disk, CD, or some other accessible location. With the PmcWizard hardware installed, power-on the PCI host computer and wait for the Found New Hardware Wizard dialogue window to appear. Insert the disk prepared above in the desired drive. Select No when asked to connect to Windows Update. Select Next. Select Install the software automatically. Select Next. Select Finish to close the Found New Hardware Wizard. The system should now see the PmcWizard channels and reopen the New Hardware Wizard. Proceed as above for each channel as necessary. Embedded Hardware and Software Solutions Page 5 of 21

DDPmcWiz.h and DDWizChan.h are C header files that define the Application Program Interface (API) to the drivers. PmcWizGUID.h and WizChanGUID.h are C header files that define the device interface identifiers for the PmcWiz and WizChan drivers. These files are required at compile time by any application that wishes to interface with the drivers, but they are not needed for driver installation. The PmcWizTest.exe file is a sample Win32 console application that makes calls into the PmcWiz/WizChan drivers to test each driver call without actually writing any application code. It is not required during the driver installation. To run PmcWizTest.exe, open a command prompt console window and type PmcWizTest -d0 -? to display a list of commands (the PmcWizTest.exe file must be in the directory that the window is referencing). The commands are all of the form PmcWizTest -dn -im where n and m are the device number and driver PmcWiz ioctl number respectively or PmcWizTest -cn -im where n and m are the channel number and WizChan driver ioctl number respectively. This application is intended to test the proper functioning of the driver calls, not for normal operation. Driver Startup Once the driver has been installed it will start automatically when the system recognizes the hardware. A handle can be opened to a specific board by using the CreateFile() function call and passing in the device name obtained from the system. The interface to the device is identified using a globally unique identifier (GUID), which is defined in PmcWizGUID.h and WizChanGUID.h. Below is example code for opening handles for device devnum. // The maximum length of the device name for a given interface #define MAX_DEVICE_NAME 256 // Handles to the device objects HANDLE hpmcwiz = INVALID_HANDLE_VALUE; HANDLE hwizchan[pmc_wiz_num_channels] = INVALID_HANDLE_VALUE, INVALID_HANDLE_VALUE; // PmcWizard device number ULONG devnum; // PmcWizard channel handle array index and interface number ULONG chan, i; // Return status from command LONG status; // Handle to device interface information structure HDEVINFO hdeviceinfo; // The actual symbolic link name to use in the createfile CHAR devicename[max_device_name]; Embedded Hardware and Software Solutions Page 6 of 21

// Size of buffer reguired to get the symbolic link name DWORD requiredsize; // Interface data structures for this device SP_DEVICE_INTERFACE_DATA interfacedata; PSP_DEVICE_INTERFACE_DETAIL_DATA pdevicedetail; // The base device information structure PMC_WIZ_DRIVER_DEVICE_INFO info; // The channel device information structure WIZ_CHAN_DRIVER_DEVICE_INFO cinfo; // Flag indicating success finding correct device BOOLEAN found = FALSE; hdeviceinfo = SetupDiGetClassDevs( (LPGUID)&GUID_DEVINTERFACE_PMC_WIZ, DIGCF_PRESENT DIGCF_DEVICEINTERFACE); if(hdeviceinfo == INVALID_HANDLE_VALUE) printf("**error: couldn't get class info, (%d)\n", GetLastError()); interfacedata.cbsize = sizeof(interfacedata); i = 0; while(!found) // Find the interface for device devnum if(!setupdienumdeviceinterfaces(hdeviceinfo, (LPGUID)&GUID_DEVINTERFACE_PMC_WIZ, i, &interfacedata)) status = GetLastError(); if(status == ERROR_NO_MORE_ITEMS) printf("**error: couldn't find device(no more items), (%d)\n", i); else printf("**error: couldn't enum device, (%d)\n", status); Embedded Hardware and Software Solutions Page 7 of 21

// Get the details data to obtain the symbolic link name if(!setupdigetdeviceinterfacedetail(hdeviceinfo, &interfacedata, 0, &requiredsize, NULL)) if(getlasterror()!= ERROR_INSUFFICIENT_BUFFER) printf("**error: couldn't get interface detail, (%d)\n", GetLastError()); // Allocate a buffer to get detail pdevicedetail = (PSP_DEVICE_INTERFACE_DETAIL_DATA)malloc(requiredSize); if(pdevicedetail == NULL) printf("**error: couldn't allocate interface detail\n"); pdevicedetail->cbsize = sizeof(sp_device_interface_detail_data); // Get the detail info if(!setupdigetdeviceinterfacedetail(hdeviceinfo, &interfacedata, pdevicedetail, requiredsize, NULL)) printf("**error: couldn't get interface detail(2), (%d)\n", GetLastError()); free(pdevicedetail); // Save the name lstrcpyn(devicename, pdevicedetail->devicepath, MAX_DEVICE_NAME); // Cleanup search free(pdevicedetail); Embedded Hardware and Software Solutions Page 8 of 21

// Open driver - Create the handle to the device hpmcwiz = CreateFile(deviceName, GENERIC_READ GENERIC_WRITE, FILE_SHARE_READ FILE_SHARE_WRITE, OPEN_EXISTING, NULL); if(hpmcwiz == INVALID_HANDLE_VALUE) printf("**error: couldn't open %s, (%d)\n", devicename, GetLastError()); // Read info if(!deviceiocontrol(hpmcwiz, IOCTL_PMC_WIZ_GET_INFO, 0, &info, sizeof(info), &length, NULL)) printf("ioctl_pmc_wiz_get_info failed: %d\n", GetLastError()); if(info.instancenumber == devnum) found = TRUE; else i++; hdeviceinfo = SetupDiGetClassDevs( (LPGUID)&GUID_DEVINTERFACE_WIZ_CHAN, DIGCF_PRESENT DIGCF_DEVICEINTERFACE); if(hdeviceinfo == INVALID_HANDLE_VALUE) status = GetLastError(); printf("**error: couldn't get class info, (%d)\n", status); interfacedata.cbsize = sizeof(interfacedata); Embedded Hardware and Software Solutions Page 9 of 21

i = 0; chan = 0; while(chan < PMC_WIZ_NUM_CHANNELS) // Find the interface for device if(!setupdienumdeviceinterfaces(hdeviceinfo, (LPGUID)&GUID_DEVINTERFACE_WIZ_CHAN, i, &interfacedata)) status = GetLastError(); if(status == ERROR_NO_MORE_ITEMS) printf("**error: couldn't find device(no more items), (%d)\n", i); else printf("**error: couldn't enum device, (%d)\n", status); // Get the details data to obtain the symbolic link name if(!setupdigetdeviceinterfacedetail(hdeviceinfo, &interfacedata, 0, &requiredsize, NULL)) if(getlasterror()!= ERROR_INSUFFICIENT_BUFFER) printf("**error: couldn't get interface detail, (%d)\n", GetLastError()); // Allocate a buffer to get detail pdevicedetail = (PSP_DEVICE_INTERFACE_DETAIL_DATA)malloc(requiredSize); if(pdevicedetail == NULL) printf("**error: couldn't allocate interface detail\n"); Embedded Hardware and Software Solutions Page 10 of 21

pdevicedetail->cbsize = sizeof(sp_device_interface_detail_data); // Get the detail info if(!setupdigetdeviceinterfacedetail(hdeviceinfo, &interfacedata, pdevicedetail, requiredsize, NULL)) printf("**error: couldn't get interface detail(2), (%d)\n", GetLastError()); free(pdevicedetail); // Save the name lstrcpyn(devicename, pdevicedetail->devicepath, MAX_DEVICE_NAME); // Cleanup search free(pdevicedetail); // Open driver - Create the handle to the device hwizchan[chan] = CreateFile(deviceName, GENERIC_READ GENERIC_WRITE, FILE_SHARE_READ FILE_SHARE_WRITE, OPEN_EXISTING, NULL); if(hwizchan[chan] == INVALID_HANDLE_VALUE) printf("**error: couldn't open %s, (%d)\n", devicename, GetLastError()); Embedded Hardware and Software Solutions Page 11 of 21

if(!deviceiocontrol(hwizchan[chan], IOCTL_WIZ_CHAN_GET_INFO, 0, &cinfo, sizeof(cinfo), &length, NULL) ) printf("ioctl_wiz_chan_get_info failed: %d\n", GetLastError()); if(cinfo.instancenumber / 2 == devnum && cinfo.instancenumber % 2 == chan) chan++; i++; Embedded Hardware and Software Solutions Page 12 of 21

IO Controls The drivers use IO Control calls (IOCTLs) to configure the device. IOCTLs refer to a single Device Object, which controls a single board or I/O channel. IOCTLs are called using the Win32 function DeviceIoControl() (see below), and passing in the handle to the device opened with CreateFile() (see above). IOCTLs generally have input parameters, output parameters, or both. Often a custom structure is used. BOOL DeviceIoControl( HANDLE hdevice, // Handle opened with CreateFile() DWORD dwiocontrolcode, // Control code defined in API header file LPVOID lpinbuffer, // Pointer to input parameter DWORD ninbuffersize, // Size of input parameter LPVOID lpoutbuffer, // Pointer to output parameter DWORD noutbuffersize, // Size of output parameter LPDWORD lpbytesreturned, // Pointer to return length parameter LPOVERLAPPED lpoverlapped, // Optional pointer to overlapped structure ); // used for asynchronous I/O The IOCTLs defined for the PmcWiz driver are described below: IOCTL_PMC_WIZ_GET_INFO Function: Returns the Driver version, Xilinx flash revision, Switch value, Instance number and PLL device ID. Output: PMC_WIZ_DRIVER_DEVICE_INFO structure Notes: Switch value is the configuration of the onboard dipswitch that has been selected by the User (see the board silk screen for bit position and polarity). Instance number is the zero-based device number. The PLL ID is the device address of the PLL. This value, which is set at the factory, is usually 0x69 but may also be 0x6A. See DDPmcWiz.h for the definition of PMC_WIZ_DRIVER_DEVICE_INFO. IOCTL_PMC_WIZ_LOAD_PLL_DATA Function: Loads the internal registers of the PLL. Input: PMC_WIZ_PLL_DATA structure Notes: The PMC_WIZ_PLL_DATA structure has only one field: Data an array of 40 bytes containing the data to write. Embedded Hardware and Software Solutions Page 13 of 21

IOCTL_PMC_WIZ_READ_PLL_DATA Function: Returns the contents of the PLL s internal registers Output: PMC_WIZ_PLL_DATA structure Notes: The register data is output in the PMC_WIZ_PLL_DATA structure in an array of 40 bytes. IOCTL_PMC_WIZ_GET_INT_STATUS Function: Returns the interrupt status. Output: Interrupt status value (unsigned long integer) Notes: This command returns the individual interrupt status bits and the interrupt active status bit. See the bit definitions in DDPmcWiz.h for information on interpreting this value. IOCTL_PMC_WIZ_REGISTER_EVENT Function: Registers an event to be signaled when an interrupt occurs. Input: Handle to the Event object Notes: The caller creates an event with CreateEvent() and supplies the handle returned from that call as the input to this IOCTL. The driver then obtains a system pointer to the event and signals the event when a user interrupt is serviced. The user interrupt service routine waits on this event, allowing it to respond to the interrupt. IOCTL_PMC_WIZ_ENABLE_INTERRUPT Function: Enables the master interrupt. Notes: This command must be run to allow the board to respond to local interrupts. The master interrupt enable is disabled in the driver interrupt service routine. Therefore this command must be run after each interrupt occurs to re-enable it. IOCTL_PMC_WIZ_DISABLE_INTERRUPT Function: Disables the master interrupt. Notes: This call is used when local interrupt processing is no longer desired. Embedded Hardware and Software Solutions Page 14 of 21

IOCTL_PMC_WIZ_FORCE_INTERRUPT Function: Causes a system interrupt to occur. Notes: Causes an interrupt to be asserted on the PCI bus as long as the master interrupt is enabled. This IOCTL is used for development, to test interrupt processing. IOCTL_PMC_WIZ_GET_ISR_STATUS Function: Returns the interrupt status that was read in the ISR from the last user interrupt. Output: Interrupt status value (unsigned long integer) Notes: Returns the interrupt status that was read in the interrupt service routine of the last interrupt serviced. Embedded Hardware and Software Solutions Page 15 of 21

The IOCTLs defined for the WizChan driver are described below: IOCTL_WIZ_CHAN_GET_INFO Function: Returns the Driver version and Instance number. Output: WIZ_CHAN_DRIVER_DEVICE_INFO structure Notes: See DDWizChan.h for the definition of WIZ_CHAN_DRIVER_DEVICE_INFO. IOCTL_WIZ_CHAN_RESET_FIFOS Function: Resets the channel s FIFOs. Notes: Resets the Tx and Rx FIFOs for the referenced channel. IOCTL_WIZ_CHAN_SET_CONFIG Function: Writes to the channel s control register. Input: Value of the control register (unsigned long integer) Notes: Only the bits in the CNTRL_MASK are controlled by this command. See the bit definitions in DDWizChan.h for information on determining this value. IOCTL_WIZ_CHAN_GET_CONFIG Function: Returns the configuration of the control register. Output: Value of the control register (unsigned long integer) Notes: The return value includes the bits in CNTRL_MASK and CNTRL_DMA_WREN, CNTRL_DMA_RDEN and CNTRL_MINTEN. This command is used mainly for testing. IOCTL_WIZ_CHAN_GET_STATUS Function: Returns the channel s status word and clears the latched bits. Output: Value of the channel s status register (unsigned long integer) Notes: See DDWizChan.h for the status bit definitions. IOCTL_WIZ_CHAN_SET_SYNC_PATTERN Function: Sets the channel s receive sync pattern. Input: Sync pattern to detect (unsigned long integer) Notes: In order to detect the start of a message, the receiver looks for this pattern to match the four-byte header. Embedded Hardware and Software Solutions Page 16 of 21

IOCTL_WIZ_CHAN_GET_SYNC_PATTERN Function: Returns the channel s receive sync pattern. Output: (unsigned long integer) Notes: Returns the pattern written by the previous call. IOCTL_WIZ_CHAN_SET_FIFO_LEVELS Function: Sets the channel s receiver almost full and transmitter almost empty levels. Input: WIZ_CHAN_FIFO_LEVELS structure Notes: The FIFO levels are used to determine at what data count the TX almost empty and RX almost full status bits are asserted. See DDWizChan.h for the definition of WIZ_CHAN_FIFO_LEVELS. IOCTL_WIZ_CHAN_GET_FIFO_LEVELS Function: Returns the channel s receiver almost full and transmitter almost empty levels. Output: WIZ_CHAN_FIFO_LEVELS structure Notes: Returns the values written in the previous call. See DDWizChan.h for the definition of WIZ_CHAN_FIFO_LEVELS. IOCTL_WIZ_CHAN_WRITE_FIFO Function: Writes a data word to the channel s transmit FIFO. Input: FIFO data word (unsigned long integer) Notes: IOCTL_WIZ_CHAN_READ_FIFO Function: Reads a data word from the channel s receive FIFO. Output: FIFO data word (unsigned long integer) Notes: IOCTL_WIZ_CHAN_GET_FIFO_COUNTS Function: Returns the number of data words in the transmit and receive FIFOs. Output: WIZ_CHAN_FIFO_COUNTS structure Notes: Returns the current FIFO data counts. See DDWizChan.h for the definition of WIZ_CHAN_FIFO_COUNTS. Embedded Hardware and Software Solutions Page 17 of 21

IOCTL_WIZ_CHAN_SET_IDLE_CONFIG Function: Sets the channel s transmit idle configuration. Input: WIZ_CHAN_IDLE_CONFIG structure Notes: Between messages the transmitter will insert a specified number of two-byte idle words. This call specifies both the value and number of these idle words. See DDWizChan.h for the definition of WIZ_CHAN_IDLE_CONFIG. IOCTL_WIZ_CHAN_GET_IDLE_CONFIG Function: Returns the channel s transmit idle configuration. Output: WIZ_CHAN_IDLE_CONFIG structure Notes: Returns the values written in the previous call. See DDWizChan.h for the definition of WIZ_CHAN_IDLE_CONFIG. IOCTL_WIZ_CHAN_REGISTER_EVENT Function: Registers an event to be signaled when an interrupt occurs. Input: Handle to the Event object Notes: The caller creates an event with CreateEvent() and supplies the handle returned from that call as the input to this IOCTL. The driver then obtains a system pointer to the event and signals the event when a user interrupt is serviced. The user interrupt service routine waits on this event, allowing it to respond to the interrupt. The DMA interrupts do not cause the event to be signaled. IOCTL_WIZ_CHAN_ENABLE_INTERRUPT Function: Enables the master interrupt. Notes: This command must be run to allow the board to respond to local interrupts. The master interrupt enable is disabled in the driver interrupt service routine. Therefore this command must be run after each interrupt occurs to re-enable it. IOCTL_WIZ_CHAN_DISABLE_INTERRUPT Function: Disables the master interrupt. Notes: This call is used when local interrupt processing is no longer desired. Embedded Hardware and Software Solutions Page 18 of 21

IOCTL_WIZ_CHAN_FORCE_INTERRUPT Function: Causes a system interrupt to occur. Notes: Causes an interrupt to be asserted on the PCI bus as long as the master interrupt is enabled. This IOCTL is used for development, to test interrupt processing. IOCTL_WIZ_CHAN_GET_ISR_STATUS Function: Returns the interrupt status read in the ISR from the last user interrupt. Output: Interrupt status value (unsigned long integer) Notes: Returns the interrupt status that was read in the interrupt service routine for the last interrupt serviced. Embedded Hardware and Software Solutions Page 19 of 21

Write PMC-Wizard DMA data is written to the device using the write command. Writes are executed using the Win32 function WriteFile() and passing in the handle to the device opened with CreateFile(), a pointer to a pre-allocated buffer containing the data to be written, an unsigned long integer that represents the size of that buffer in bytes, a pointer to an unsigned long integer to contain the number of bytes actually written, and a pointer to an optional Overlapped structure for performing asynchronous IO. Read PMC-Wizard DMA data is read from the device using the read command. Reads are executed using the Win32 function ReadFile() and passing in the handle to the device opened with CreateFile(), a pointer to a pre-allocated buffer that will contain the data read, an unsigned long integer that represents the size of that buffer in bytes, a pointer to an unsigned long integer to contain the number of bytes actually read, and a pointer to an optional Overlapped structure for performing asynchronous IO. Warranty and Repair Dynamic Engineering warrants this product to be free from defects under normal use and service and in its original, unmodified condition, for a period of one year from the time of purchase. If the product is found to be defective within the terms of this warranty, Dynamic Engineering's sole responsibility shall be to repair, or at Dynamic Engineering's sole option to replace, the defective product. Dynamic Engineering's warranty of and liability for defective products is limited to that set forth herein. Dynamic Engineering disclaims and excludes all other product warranties and product liability, expressed or implied, including but not limited to any implied warranties of merchandisability or fitness for a particular purpose or use, liability for negligence in manufacture or shipment of product, liability for injury to persons or property, or for any incidental or consequential damages. Dynamic Engineering s products are not authorized for use as critical components in life support devices or systems without the express written approval of the president of Dynamic Engineering. Embedded Hardware and Software Solutions Page 20 of 21

Service Policy Before returning a product for repair, verify as well as possible that the driver is at fault. The driver has gone through extensive testing and in most cases it will be cockpit error rather than an error with the driver. When you are sure or at least willing to pay to have someone help then call the Customer Service Department and arrange to speak with an engineer. We will work with you to determine the cause of the issue. If the issue is one of a defective driver we will correct the problem and provide an updated module(s) to you [no cost]. If the issue is of the customer s making [anything that is not the driver] the engineering time will be invoiced to the customer. Pre-approval may be required in some cases depending on the customer s invoicing policy. Out of Warranty Repairs Out of warranty support will be billed. The current minimum repair charge is $125. An open PO will be required. For Service Contact: Customer Service Department Dynamic Engineering 150 DuBois St. Suite C Santa Cruz, CA 95060 831-457-8891 831-457-4793 Fax support@dyneng.com All information provided is Copyright Dynamic Engineering. Embedded Hardware and Software Solutions Page 21 of 21