background image

Interconnectivity

Page 4 of 22

Firmware Programming Guide for PDIUSBD12

Philips Semiconductors - Asia Product Innovation Centre

Visit  

http://www.flexiusb.com

1. Introduction

PDIUSBD12 is a high-speed USB interface device with parallel bus and local DMA transfer capability. The
objective of the recommended firmware design is to enable PDIUSBD12 to achieve the fastest transfer rate over
USB.

Peripheral devices such as the printer, scanner, external mass storage, and digital camera can use PDIUSBD12
in transferring data over USB. The CPUs in these devices are very busy in handling many tasks like device
control and data and image processing. The firmware of PDIUSBD12 is designed to be fully interrupt-driven.
While CPU is doing its foreground task, the USB transfer is being handled in the background. This assures best
transfer rate and better software structure and also simplifies programming and debugging.

The data exchange between the background ISR (Interrupt Service Routine) and the foreground Main Loop is
achieved by event flags and data buffers. For example, the PDIUSBD12 Main bulk out endpoint can  use a
circular data buffer. When PDIUSBD12 receives a data packet from USB, an interrupt request is generated to
the CPU and the CPU will service ISR immediately. Inside the ISR, the firmware moves the data packet to the
circular buffer from PDIUSBD12's internal buffer and then clears the PDIUSBD12's internal buffer to enable
PDIUSBD12 to receive new packet. The CPU can continue its current foreground task until completion, e.g.
printing current page. Then it returns to the main loop, checks the circular buffers for new data, and starts
another foreground task.

With this structure, the Main Loop does not care whether the data source is from USB, serial port, or parallel
port. The Main Loop only checks the circular buffer for new data to be processed. This concept is very
important. Thus, the Main Loop program can target on data processing and the ISR can do the job of data
transfer at the fastest speed possible.

Similarly, the control endpoint uses the same concept in data packet handling. The ISR receives and stores
control transfers in data buffers and sets the corresponding flag registers. The main loop will dispatch the
request to protocol handling routines.  Since all the standard device, class, and vendor requests are processed in
protocol handling routines, ISR can maintain its efficiency. Also, when new request is added, only modification
at the protocol level is needed.

ISR in background

Main loop in foreground

RXWP, Write Pointer maintained by ISR

RXRP, Read Pointer maintained by main loop

Circular data buffer

Содержание PDIUSBD12

Страница 1: ...____________________________________________________________________________________________ Philips Semiconductors Asia Product Innovation Centre Visit http www flexiusb com 23 September 1998 Firmware Programming Guide for PDIUSBD12 Version 1 0 ...

Страница 2: ...HILIPS SEMICONDUCTORS FURTHER DISCLAIMS ALL WARRANTIES INCLUDING WITHOUT LIMITATION ANY IMPLIED WARRANTIES OF MERCHANT ABILITY FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT THE ENTIRE RISK ARISING OUT OF THE USE OR PERFORMANCE OF THE PRODUCT AND DOCUMENTATION REMAINS WITH THE RECIPIENT TO THE MAXIMUM EXTENT PERMITTED BY APPLICABLE LAW IN NO EVENT SHALL PHILIPS SEMICONDUCTORS OR ITS SUPPLIER...

Страница 3: ...ER CPU PLATFORM 6 2 3 USING THE FIRMWARE IN POLLING MODE 6 3 HARDWARE ABSTRACTION LAYER 7 4 PDIUSBD12 COMMAND INTERFACE 7 5 INTERRUPT SERVICE ROUTINE 8 5 1 BUS RESET AND SUSPEND CHANGE 9 5 2 CONTROL ENDPOINT HANDLER 10 5 3 GENERIC ENDPOINT HANDLER 13 5 4 MAIN ENDPOINT HANDLER 13 5 5 EOT HANDLER 13 6 MAIN LOOP 14 7 CHAPTER 9 PROTOCOL 15 7 1 CLEAR FEATURE REQUEST 15 7 2 GET STATUS REQUEST 16 7 3 SET...

Страница 4: ...d to the CPU and the CPU will service ISR immediately Inside the ISR the firmware moves the data packet to the circular buffer from PDIUSBD12 s internal buffer and then clears the PDIUSBD12 s internal buffer to enable PDIUSBD12 to receive new packet The CPU can continue its current foreground task until completion e g printing current page Then it returns to the main loop checks the circular buffe...

Страница 5: ...de always needs modifications or additions 2 1 2 PDIUSBD12 Command Interface D12CI C To further simplify programming with PDIUSBD12 the firmware defines a set of command interfaces which encapsulate all the functions used to access PDIUSBD12 2 1 3 Interrupt Service Routine ISR C This part of the code handles interrupt generated by PDIUSBD12 It retrieves data from PDIUSBD12 s internal FIFO to CPU m...

Страница 6: ...Chapter 9 Only Product Level EPPHAL C Port to hardware specific Port to hardware specific D12CI C No change No change CHAP_9 C No change Product specific USB descriptors PROTODMA C No change Add vendor request supports if necessary ISR C No change Add product specific processing on Generic and Main endpoints MAINLOOP C Depends on the CPU and system ports timer and interrupt initialization need to ...

Страница 7: ...essary to be implemented in target application void eppAwrite unsigned char A_data void program_cpld unsigned short uSize unsigned char bCommand 4 PDIUSBD12 Command Interface The following functions are defined as PDIUSBD12 command interface to simplify device programming They are simple implementations of the PDIUSBD12 command set which is defined in the data sheet void D12_SetAddressEnable unsig...

Страница 8: ...n to dispatch it to the appropriate subroutines for processing ISR ISR Entry Read D12 Interrupt Register Reset Idle Timer Bus Reset Suspend Change DMA EOT Control In Done Control Out Done Generic In Done Generic Out Done Main In Done Main Out Done Send EOI to Interrupt Controller End of ISR No No No No No No No No No Set Bus Reset Flag Yes Set Suspend Changed Flag DMA EOT handler Subroutine Contro...

Страница 9: ...t unsigned short wValue unsigned short wIndex unsigned short wLength DEVICE_REQUEST typedef struct _control_xfer DEVICE_REQUEST DeviceRequest unsigned short wLength unsigned short wCount unsigned char pData unsigned char dataBuffer MAX_CONTROLDATA_SIZE CONTROL_XFER The task splitting between Main Loop and ISR is that ISR collects data from D12 and Main Loop will process the data The ISR will only ...

Страница 10: ...trol transfer always begins with the SETUP stage and then followed later by an optional DATA stage It then ends with the STATUS stage The diagram below shows the various states of transitions on the Control endpoints The firmware uses these 3 states to handle Control transfer correctly IDLE TRANSMIT RECEIVE No data Control return Status Control Write Status Control Read Status INs OUTs ...

Страница 11: ... to extract the content of the setup packet through Select Control Out Endpoint to determine whether this endpoint is full or empty If the control endpoint is full MCU will then read the content from the buffer and save the content to its memory After that it will validate the host device s request from the memory If it is a valid request MCU must send the Acknowledge Setup command to the Control ...

Страница 12: ... check its current and remaining size of the data to be sent to the host If the remaining bytes are greater than 16 bytes MCU will send the first 16 bytes and then subtract the reference length requested length by 16 When the next Control_In token comes MCU will determine whether the remaining bytes is zero If there is no more data to send MCU will need to send an empty packet to inform the host t...

Страница 13: ...en configured to send the information of the button activity as a byte to the host 5 4 Main Endpoint Handler Since the Main In Out Endpoints are configured to the DMA mode and the interrupts are disabled for these endpoints no ISR services are normally required for these endpoints However for safer code implementation we have put in place clear interrupt routine here 5 5 EOT Handler For more infor...

Страница 14: ... only A 1mSec timer is programmed to activate the routine to check for any button pressed on the evaluation board When the polling reaches the check Setup packet it verifies the setup flag set previously by the interrupt service routine If the setup flag is set it will dispatch a device request to the protocol layer for processing The flowchart above shows the main program executing on the foregro...

Страница 15: ...s an interface Feature selectors are used when enabling or setting features specific to the device or endpoint such as remote wakeup When the recipient is a device MCU will need to disable the remote wakeup function if this function has been enabled If the recipient is the endpoint the MCU will have to unstall the specific endpoint through the Set Endpoint Status command Is recipient a device Is r...

Страница 16: ...ata will be 0x0003 If the recipient is an interface then MCU should return 0x0000 to the host 7 3 Set Address Request In the Set address request the device will get the new address from the content of the setup packet Note that this set address request does not have a data phase Therefore MCU will need to write a zero length data packet to the host as the acknowledgment phase Get_Status Return Dev...

Страница 17: ...e device is configured 7 5 Get Descriptor Request For the Get Descriptor request MCU must return the specific descriptor if the descriptor exists Firstly MCU will determine whether the descriptor type request is for the device or the configuration It will then send the first 16 bytes of device descriptor if the descriptor type is for device The reason for controlling the size of returning bytes is...

Страница 18: ...eed to set the configuration flag Once the flag is set MCU will also need to send the zero data packet to the host for the acknowledgment phase 7 7 Get Set Interface Request or Get Interface request MCU will just need to send one zero data packet to the host as our evaluation board only supports one type of interface For Set Interface request on our evaluation board MCU need not do anything except...

Страница 19: ... to the feature selector on the setup packet Again there is no support for the Interface recipient For example if the feature selector is 0 which means enabling endpoint the D12 specific endpoint will have to be stalled through D12_SetEndpoint status command Is recipient a device Is recipient an Interface Is recipient an endpoint Set device feature according to Feature Selector Yes No Yes No Yes U...

Страница 20: ...and allow the device to program the DMAC with DMA transfer direction start address and size of transfer 2 Send or receive data packets on the main endpoint 8 2 Device s DMA States The Setup DMA Request is sent from the host as vendor request using control pipe The device s response and action depend on its internal states of DMA operation The diagram above shows 3 DMA states in the device IDLE RUN...

Страница 21: ...at the interrupt from endpoints 4 and 5 are disabled in DMA mode Servicing interrupt on these endpoints is unnecessary and has a potential flaw during the DMA transfer DMA can be treated as the highest interrupt that happens between any CPU instructions even inside ISR Any routines that may want to be used to check DMA status are not reliable because the DMA status during the transfer may change a...

Страница 22: ...points with a single thread IOCTL_WRITE_REGISTER and IOCTL_READ_REGISTER use structure IO_BLOCK to exchange data with the device driver Below structure definition is part of Microsoft Still Image USB Interface typedef struct _IO_BLOCK IN unsigned uOffset IN unsigned uLength IN OUT PUCHAR pbyData IN unsigned uIndex IO_BLOCK PIO_BLOCK IO_REQUEST structure is a proprietary definition that contains de...

Отзывы: