# **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

# User Manual PMC-PARALLEL-TTL-BA16

Digital Parallel Interface PMC Module 2 Byte wide RX/TX ports with programmable rate



Revision A Corresponding Hardware: Revision 1 10-2007-0101 FLASH 0201



**Embedded Solutions** 

# PMC-PARALLEL-TTL-BA16

Digital Parallel Interface PMC Module Dynamic Engineering 150 DuBois St. Suite C, Santa Cruz CA 95060 831-457-8891 831-457-4793 FAX

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.

This product has been designed to operate with PMC Module carriers and compatible user-provided equipment. Connection of incompatible hardware is likely to cause serious damage.

©2007-2008 by Dynamic Engineering. Other trademarks and registered trademarks are owned by their respective manufacturers. Manual Revision A. Revised 9/3/08



# Table of Contents

| PRODUCT DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 6                                                                                                                                                                                                                                                  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| THEORY OF OPERATION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 9                                                                                                                                                                                                                                                  |
| ADDRESS MAP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 13                                                                                                                                                                                                                                                 |
| PROGRAMMING                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 15                                                                                                                                                                                                                                                 |
| Register Definitions<br>pmcparttl_BASE<br>pmcparttl_ID<br>pmcparttl_DirL<br>pmcparttl_DirL<br>pmcparttl_DatL<br>pmcparttl_DatL<br>pmcparttl_DatUreg<br>pmcparttl_COSclk<br>pmcparttl_RisLreg<br>pmcparttl_RisUreg<br>pmcparttl_FallUreg<br>pmcparttl_IntRisLreg<br>pmcparttl_IntRisLreg<br>pmcparttl_IntRisLreg<br>pmcparttl_IntRisLstat<br>pmcparttl_IntRisLstat<br>pmcparttl_IntRisLstat<br>pmcparttl_IntRisUstat<br>pmcparttl_CO,1_base<br>pmcparttl_CO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmcparttl_cO,1_st<br>pmc | 17<br>17<br>19<br>20<br>21<br>21<br>22<br>23<br>23<br>23<br>24<br>25<br>25<br>26<br>26<br>26<br>26<br>26<br>27<br>27<br>27<br>27<br>28<br>28<br>29<br>29<br>30<br>30<br>30<br>31<br>31<br>31<br>32<br>35<br>38<br>39<br>40<br>40<br>41<br>41<br>41 |



| LOOP-BACK                                          | 43 |
|----------------------------------------------------|----|
| PMC MODULE LOGIC INTERFACE PIN ASSIGNMENT          | 44 |
| PMC MODULE LOGIC INTERFACE PIN ASSIGNMENT          | 45 |
| PMC MODULE FRONT PANEL IO INTERFACE PIN ASSIGNMENT | 46 |
| PMC MODULE FRONT PANEL IO INTERFACE PIN ASSIGNMENT | 47 |
| PMC MODULE BACKPLANE IO INTERFACE PIN ASSIGNMENT   | 48 |
| APPLICATIONS GUIDE                                 | 49 |
| Interfacing                                        | 49 |
| Construction and Reliability                       | 50 |
| Thermal Considerations                             | 51 |
| Service Policy                                     | 52 |
| Out of Warranty Repairs                            | 52 |
| SPECIFICATIONS                                     | 53 |
| ORDER INFORMATION                                  | 54 |



# List of Figures

| FIGURE 1  | PMC-PARALLEL-TTL REAR VIEW                           | 7  |
|-----------|------------------------------------------------------|----|
| FIGURE 2  | PMC-PARALLEL-TTL BLOCK DIAGRAM                       | 10 |
| FIGURE 3  | PMC-PARALLEL-TTL INTERNAL ADDRESS MAP BASE FUNCTIONS | 13 |
| FIGURE 4  | PMC-PARALLEL-TTL CHANNEL ADDRESS MAP                 | 14 |
| FIGURE 5  | PMC-PARALLEL-TTL CONTROL PORT 0 BIT MAP              | 17 |
| FIGURE 6  | PMC-PARALLEL-TTL ID AND SWITCH BIT MAP               | 19 |
| FIGURE 7  | PMC-PARALLEL-TTL STATUS PORT BIT MAP                 | 20 |
| FIGURE 8  | PMC-PARALLEL-TTL DIRECTION LOWER BIT MAP             | 21 |
| FIGURE 9  | PMC-PARALLEL-TTL DIRECTION UPPER BIT MAP             | 21 |
| FIGURE 10 | PMC-PARALLEL-TTL DATA IO LOWER BIT MAP               | 22 |
| FIGURE 11 | PMC-PARALLEL-TTL DATA IO UPPER BIT MAP               | 22 |
| FIGURE 12 | PMC-PARALLEL-TTL DATA REG LOWER BIT MAP              | 23 |
| FIGURE 13 | PMC-PARALLEL-TTL DATA REG UPPER BIT MAP              | 23 |
| FIGURE 14 | PMC-PARALLEL-TTL COS CLK CONTROL BIT MAP             | 24 |
| FIGURE 15 | PMC-PARALLEL-TTL RISING LOWER BIT MAP                | 25 |
| FIGURE 16 | PMC-PARALLEL-TTL RISING UPPER BIT MAP                | 25 |
| FIGURE 17 | PMC-PARALLEL-TTL FALLING LOWER BIT MAP               | 26 |
| FIGURE 18 | PMC-PARALLEL-TTL FALLING UPPER BIT MAP               | 26 |
| FIGURE 19 | PMC-PARALLEL-TTL INT RISING LOWER BIT MAP            | 27 |
| FIGURE 20 | PMC-PARALLEL-TTL INT RISING UPPER BIT MAP            | 27 |
| FIGURE 21 | PMC-PARALLEL-TTL INT FALLING LOWER BIT MAP           | 28 |
| FIGURE 22 | PMC-PARALLEL-TTL INT FALLING UPPER BIT MAP           | 28 |
| FIGURE 23 | PMC-PARALLEL-TTL RISING COS STATUS LOWER             | 29 |
| FIGURE 24 | PMC-PARALLEL-TTL RISING COS STATUS UPPER             | 29 |
| FIGURE 25 | PMC-PARALLEL-TTL FALLING COS STATUS LOWER            | 30 |
| FIGURE 26 | PMC-PARALLEL-TTL FALLING COS STATUS UPPER            | 30 |
| FIGURE 27 | PMC-PARALLEL-TTL DMA REG LOWER BIT MAP               | 31 |
| FIGURE 28 | PMC-PARALLEL-TTL DIRECTION UPPER BIT MAP             | 31 |
| FIGURE 29 | PMC-PARALLEL-TTL CHANNEL CONTROL REGISTER            | 32 |
| FIGURE 30 | PMC-PARALLEL-TTL CHANNEL STATUS PORT                 | 35 |
| FIGURE 31 | PMC-PARALLEL-TTL WRITE DMA POINTER REGISTER          | 38 |
| FIGURE 32 | PMC-PARALLEL-TTL READ DMA POINTER REGISTER           | 39 |
| FIGURE 33 | PMC-PARALLEL-TTL RX/TX FIFO PORT                     | 40 |
| FIGURE 34 | PMC-PARALLEL-TTL TX ALMOST EMPTY LEVEL REGISTER      | 40 |
| FIGURE 35 | PMC-PARALLEL-TTL RX ALMOST FULL LEVEL REGISTER       | 41 |
| FIGURE 36 | PMC-PARALLEL-TTL TX FIFO DATA COUNT PORT             | 41 |
| FIGURE 37 | PMC-PARALLEL-TTL RX FIFO DATA COUNT PORT             | 42 |
| FIGURE 38 | PMC-PARALLEL-TTL PN1 INTERFACE                       | 44 |
| FIGURE 39 | PMC-PARALLEL-TTL PN2 INTERFACE                       | 45 |
| FIGURE 40 | PMC-PARALLEL-TTL FRONT PANEL INTERFACE               | 46 |
| FIGURE 41 | PMC-PARALLEL-TTL BA16 FRONT PANEL INTERFACE          | 47 |
| FIGURE 42 | PMC-PARALLEL-TTL PN4 INTERFACE                       | 48 |



# **Product Description**

In embedded systems many of the interconnections are made with single ended TTL or CMOS level signals. Depending on the system architecture an IP or a PMC will be the right choice to make the connection. With most architectures you have a choice as there are carriers for cPCI, PCI, VME, PC/104p and other buses for both PMC and IP mezzanine modules.

Usually the choice is based on other system constraints as both the PMC and IP can provide the IO you require. Dynamic Engineering would be happy to assist in your decision regarding architecture and other trade-offs with the PMC / IP decision. Dynamic Engineering has carriers for IP and PMC modules for most architectures, and is adding more as new solutions are requested and required by our customers.

The PMC compatible PMC-Parallel-TTL has 64 independent digital IO. The high density makes efficient use of PMC slot resources. The IO is available for system connection through the front panel, via the rear [Pn4] connector, or both. A high density 68 pin SCSI III front panel connector provides the front panel IO. The IO lines can be protected with optional transorbs. The rear panel IO has a PIM and PIM Carrier available for rear panel wiring options.

PMC-Parallel-TTL-BA16 is a customerized version of the standard PMC-Parallel-TTL board. "BA16" is set to 3.3V, has front panel IO, and a specific state-machine implementation for two channels [two TX and two RX]. The transmit rate is programmable. The RX rate is expected to be 1 MHz from the customer equipment. The design has enough margin to support rates up to and beyond 8 MHz.

Due to the larger number of channels the TX FIFO has been reduced to 2Kx32 per channel. RX FIFO is 4Kx32 per channel.

The BA16 features are selectable. The standard register based and COS functions are available on unused [by BA16] pins and can be swapped with the BA16 functions under software control.

The HDEterm68 http://www.dyneng.com/HDEterm68.html

can be used as a breakout for the front or rear panel IO. The HDEcabl68 provides a convenient cable. <u>http://www.dyneng.com/HDEcabl68.html</u> Custom cables can be manufactured to your requirements. Please contact Dynamic Engineering with your specifications.

Each channel is programmable to be input or output on a channel-by-channel basis. All 64 IO channels can be used as interrupt generators. Interrupts are programmable to be based on rising, falling and change of state [both] conditions. The interrupts are maskable to allow polled operation as well.



The inputs are available unfiltered and after the transition detection. The transition detection is programmable for clock rate. The local 50 MHz oscillator, PCI or external clocks can be selected as the reference to the clock divider. The clock divider is programmable to use the reference rate or to divide it to a lower frequency.

All of the IO are routed through the FPGA to allow for custom applications that require hardware intervention or specific timing- for example an automatic address or data strobe to be generated. The initial model was register based [FLASH 0101]. The design with revision 2 and later FLASH is DMA capable with a built in programmable parallel data output and input function. The new features are designed to default to "not used" to allow the new cards to be used with older customer software. The DMA function can be used with customer requirements too. Please contact Dynamic Engineering with your custom requirements. BA16 is design number 2 for the PMC-Parallel-TTL with a corresponding FLASH of 02xx.

The IO are driven with open-drain high current drivers. When enabled, the high side is driven with the device and augmented with pull-up resistors. When disabled the output is pulled high with the resistors unless another device on the line is driving that line low. The low side of the driver can sink 64+ mA. The high side drive is 32 mA plus the pull-up current value. All IO have 2 pull-up locations per line. The default is for 470 ohms installed into one location. The resistors are referenced to either 5V or 3.3V based on a factory installed jumper. The multiple locations allow for pull-up strengths greater than 470 ohms, and to stay within the resistor pack wattage capabilities. The multiple packs also allow for parallel combinations to create more options of specific pull-up values. For custom models with additional pull-ups or alternate values please contact Dynamic Engineering. The two columns of pull-up resistor locations are visible on the rear of the card.



Figure 1 PMC-PARALLEL-TTL REAR VIEW



The registers are mapped as 32 bit words and support byte, word and 32 bit access. All registers are read-writeable. The Linux and Windows® compatible drivers are available to provide the system level interface for this design. Use standard C/C++ to control your hardware or use the Hardware manual to make your own software interface. The software manual is also available on-line. The Linux documentation is provided in-line with the source code.

The basic functions of parallel IO and COS capture are designed into the FLASH 0101 "base" model. Additional features will be added to the base model by using a mux on the output side to allow software to select the base or extended features. Data bit 0 is the first extended feature and is a programmable output for the COS reference clock. With software the output definition can be changed to drive the COS clock onto Data 0. The user can use a scope to check that their set-up is what they want it to be, and then likely return it to being a data bit. You can leave the output defined as a clock if desired.

FLASH 0201 has the additional feature of utilizing the internal block RAM to create FIFO's to support output and input data streams. An additional register is added to allow the user to select on a bit-by-bit basis the programmable data output or the register based output. The input function does not preclude the use of the standard input functions. For example COS can be run on the same inputs as the data capture uses.

PMC-PARALLEL-TTL is part of the PMC Module family of modular I/O components. The PMC-PARALLEL-TTL conforms to the PMC standard. This guarantees compatibility with multiple PMC Carrier boards. Because the PMC may be mounted on different form factors, while maintaining plug and software compatibility, system prototyping may be done on one PMC Carrier board, with final system implementation on a different one.



# **Theory of Operation**

The PMC-PARALLEL-TTL can be used for multiple purposes with applications in telecommunications, control, sensors, IO, test; anywhere multiple independent or coordinated IO are useful.

The PMC-PARALLEL-TTL features a Xilinx FPGA, and high current LVTH driver devices. The FPGA contains the PCI interface and control required for the parallel interface.

The Xilinx design incorporates the "PCI Core" and additional modules for DMA in parallel with a direct register decoded programming model. The initial implementation provides an enhanced feature set based on the PMC Parallel IO design. Additional FLASH updates will provide DMA, pattern generation, pulse generation, and user defined requirements. The first update is complete with the 0102 FLASH model. The DMA and user specified parallel output and input grouping are included.

The drivers are initialized to the off state and pull-ups on board hold the IO lines in the 'high' state. The direction registers are used to program the channel to be a driver or not. The receivers are always enabled allowing local read-back of the transmitted data.

Data written to the IO registers can be placed on the bus. The master enable allows all 64 channels to be synchronized if desired. The master enable can be programmed "on" to allow direct updates if 64 bit synchronization is not required.

For an IO with the direction bit set and master enabled: When a '0' is written to any IO line register position the corresponding line is driven low. When a '1' is written to any IO line register position that line is driven high by the local driver, and the output level will be controlled by the termination resistor. The drivers are asymmetrical with 64 mA sink and 32 mA source. The 470 resistor to 3.3/5 will provide additional "source current", and level control when in "open drain" mode [programmed for receive].

If the direction bit is set to input the level will be controlled by external devices and the attached pull-ups. The control register is read-writeable. The data register read corresponds to the IO side. The register read-back is at an alternate address offset. The register read-back is independent of the bus; the data read will always match the data written. The IO data read will reflect the state of the bus and not necessarily the state of the on-board drivers.

The read-back registers are clocked at a programmable rate with an internal clock generator. If desired the internal clock can be replaced with an external source and an enable. The basic option is available under SW control. If special programming is



needed please contact Dynamic Engineering for a custom FPGA implementation.

All the IO control and registers are instantiated within the FPGA, only the drivers and receivers are separate devices. If desired, the IO lines can be specially programmed to create custom timing pulses etc. For example if the interface is to put out an address and then an address qualifier to strobe the address into the receiving hardware one of the IO lines can be programmed to create a pulse some time after the address for the IO registers is written to. The custom pulse will be more accurate for delay and duration than a SW timing solution. The number of accesses to the card can be reduced as well having the effect of greater through-put. Please contact Dynamic Engineering with your requirements.



## Figure 2 PMC-PARALLEL-TTL Block Diagram



PMC Parallel TTL BA16 features a programmable data path with DMA support. The internal block RAM is configured to provide FIFO's for transmit and receive [4K x 32 RX, 2Kx32 TX]. The PLL is used as a TX state-machine reference. The FIFO's support a loop-back path between them for BIT [built in testing]. The IO is also selectable at the bit level to mask down to the user requirement. 8 bits can be masked down to 5 for example. A reference clock and data strobe are provided for synchronization. Data is valid on the rising edge of the clock. The clock is stopped when data is not being transmitted.

The hardware will pull data from the host memory and store into the transmit FIFO. The FIFO will be kept full with DMA operating at the PCI bus frequency. The output side will operate at the PLL programmed rate [1 MHz for example] and at the selected width [8 bits for example]. The state-machine will take care of reading from the FIFO, converting down or up in width, and outputting on the programmed frequency.

The state-machine supports "run until done" and "pause mode". In Run until Done mode the transmission will continue until the FIFO is emptied. With DMA and lower frequencies of transmission and/or coupled with more narrow data widths this mode can work well. At our 1 MHz example, and byte wide data we have 33x on clock rate and 4x on width for a really large multiplier. In addition the DMA FIFO is 2Kx32 for TX leaving a lot of "rubber band" in the memory chain to support the transmission. As the frequencies are increased and/or the width is increased the multiplier can be reduced to the point where the FIFO may go empty on occasion before the transmission is complete. OS delays are the main culprit. The Pause mode allows the hardware to "keep running" even when the FIFO goes empty. The state-machine interprets the empty FIFO as a pause not a stop. The state-machine cleans up and stops the reference clock along with the data and then restarts when data becomes available.

For longer runs or at smaller multiplier situations it is recommended to use the pause mode. At the end of the run when in pause mode the hardware will be idling waiting for more data to send. A new transmission can be started by loading the FIFO with the next data set or by disabling the transmitter and reinitializing. If the frequency is going to change it is recommended to reinitialize.

The DMA length is 32 bits => longer than most computer OS will allow in one segment of memory. The DMA is scatter gather capable for longer lengths than the OS max and for OS situations where the memory is not contiguous. With Windows lengths of 4K are common while Linux can provide much larger spaces. Larger spaces are slightly more efficient as there are potentially fewer initialization reads and less overhead on the bus. A single interrupt can control the entire transfer. Head to tail operation can also be programmed with two memory spaces with two interrupts per loop.



For reception the hardware samples the received clock and looks for the rising edge. The reference clock used can be the oscillator [50 MHz] or the PLL channel B. 6X oversampling is recommended as a minimum leading to a 8.3 MHz upper frequency limitation on the RX side with the oscillator or user defined if the PLL is used. The oscillator setting is recommended for most applications.

When the rising edge is found the Align bit is checked, and if valid, a reception started. 4 bytes are captured to build up a LW. At the 5<sup>th</sup> byte received the align signal is checked, and if not present an error flagged. The process repeats until SW stops reception. The LW data is moved to the FIFO as it becomes available. If the FIFO is full when it is time to write, an error is flagged. The DMA engine moves the data from the receive FIFO to the host memory.



The RX and TX DMA channels are separate and can run at the same time without software intervention. Full DMA engines are provided on each channel with internal arbitration between the channels to access the PCI bus to retrieve data or write data.

The clock rates for RX and TX are also independent using separate PLL frequencies or the external rate.



# **Address Map**

| Function                        | Offset                                                                |
|---------------------------------|-----------------------------------------------------------------------|
| // PMC Parallel TTL definitions |                                                                       |
| #define pmcparttl_BASE          | 0x0000 // 0 PMC Parallel TTL base control register offset             |
| #define pmcparttl_ID            | 0x0004 // 1 PMC Parallel TTL ID Register offset                       |
| #define pmcparttl_STATUS        | 0x0008 // 2 PMC Parallel TTL status Register offset                   |
| #define pmcparttl_DirL          | 0x000c // 3 PMC Parallel TTL Direction lower Register offset          |
| #define pmcparttl_DirU          | 0x0010 // 4 PMC Parallel TTL Direction upper Register offset          |
| #define pmcparttl_DatL          | 0x0014 // 5 PMC Parallel TTL Data lower Register, line data read      |
| #define pmcparttl_DatU          | 0x0018 // 6 PMC Parallel TTL Data upper Register, line data read      |
| #define pmcparttl_DatLreg       | 0x001c // 7 PMC Parallel TTL Data lower Register read-back            |
| #define pmcparttl_DatUreg       | 0x0020 // 8 PMC Parallel TTL Data upper Register read-back            |
| #define pmcparttl_COSclk        | 0x0024 // 9 PMC Parallel TTL COS Clock definition Register            |
| //#define spare                 | 0x0028 // 10 PMC Parallel TTL                                         |
| #define pmcparttl_RisLreg       | 0x002c // 11 PMC Parallel TTL Rising lower Register                   |
| #define pmcparttl_RisUreg       | 0x0030 // 12 PMC Parallel TTL Rising upper Register                   |
| #define pmcparttl_FallLreg      | 0x0034 // 13 PMC Parallel TTL Falling lower Register                  |
| #define pmcparttl_FallUreg      | 0x0038 // 14 PMC Parallel TTL Falling upper Register                  |
| #define pmcparttl_IntRisLreg    | 0x003c // 15 PMC Parallel TTL Interrupt Enable Rising lower Register  |
| #define pmcparttl_IntRisUreg    | 0x0040 // 16 PMC Parallel TTL Interrupt Enable Rising upper Register  |
| #define pmcparttl_IntFallLreg   | 0x0044 // 17 PMC Parallel TTL Interrupt Enable Falling lower Register |
| #define pmcparttl_IntFallUreg   | 0x0048 // 18 PMC Parallel TTL Interrupt Enable Falling upper Register |
| #define pmcparttl_IntRisLstat   | 0x004c // 19 PMC Par TTL Interrupt Rising LWR Stat Rd, write = clear  |
| #define pmcparttl_IntRisUstat   | 0x0050 // 20 PMC Par TTL Interrupt Rising UPR Stat Rd, write = clear  |
| #define pmcparttl_IntFallLstat  | 0x0054 // 21 PMC Par TTL Interrupt Falling LWR Stat Rd, write = clear |
| #define pmcparttl_IntFallUstat  | 0x0058 // 22 PMC Par TTL Interrupt Falling UPR Stat Rd, write = clear |
| #define pmcparttl_DR_L          | 0x005C // 23 PMC Par TTL DMA - Register bit selection 31-0 R/W        |
| #define pmcparttl_DR_U          | 0x0060 // 24 PMC Par TTL DMA - Register bit selection 63-32 R/W       |
| Figure 3 PMC-PARALLEI           | -TTL Internal Address Map Base Functions                              |

Figure 3 PMC-PARALLEL-TTL Internal Address Map Base Functions

The address map provided is for the local decoding performed within PMC-Parallel-TTL. The addresses are all offsets from a base address. The carrier board that the PMC is installed into provides the base address. Dynamic Engineering prefers a long-word oriented approach because it is more consistent across platforms.

The map is presented with the #define style to allow cutting and pasting into many compilers "include" files.

The host system will search the PCI bus to find the assets installed during power-on initialization. The Vendorld = 0x10EE and the CardId = 0x0036 for the PMC-Parallel-TTL-BA16.



| Function                        | Offset                                                                |
|---------------------------------|-----------------------------------------------------------------------|
| // PMC Parallel TTL definitions |                                                                       |
| #define pmcparttl_ch0_base      | 0x0078 // 30 PMC Par TTL DMA path base control register channel 0     |
| #define pmcparttl_ch0_st        | 0x007C// 31 PMC Par TTL channel 0 status, interrupt clear, data count |
| #define pmcparttl_ch0_brstin    | 0x0080// 32 PMC Par TTL channel 0 burst in control,                   |
| #define pmcparttl_ch0_brstout   | 0x0084// 33 PMC Par TTL channel 0 burst out control,                  |
| #define pmcparttl_ch0_swr       | 0x0088// 34 PMC Par TTL ch 0 FIFO sin read from RX, sin write to TX   |
| #define pmcparttl_ch0_tx_aecnt  | 0x008C// 35 PMC Par TTL ch 0 almost empty count register and rd-bk    |
| #define pmcparttl_ch0_rx_afcnt  | 0x0090 // 36 PMC Par TTL ch 0 almost full count register and rd-bk    |
| #define pmcparttl_ch0_tx_ffcnt  | 0x0094 // 37 PMC Par TTL ch 0 tx fifo word count                      |
| #define pmcparttl_ch0_rx_ffcnt  | 0x0098 // 38 PMC Par TTL ch 0 rx fifo word count                      |
| // #define pmcparttl_ch0_SPARE  | 0x009C // 39 PMC Par TTL ch 0 spare                                   |
| #define pmcparttl_ch1_base      | 0x00A0 // 40 PMC Par TTL DMA path base control register channel 1     |
| #define pmcparttl ch1 st        | 0x00A4 / 41 PMC Par TTL ch 1 status, interrupt clear, data count      |
| #define pmcparttl_ch1_brstin    | 0x00A8 // 42 PMC Par TTL ch 1 burst in control,                       |
| #define pmcparttl ch1 brstout   | 0x00AC // 43 PMC Par TTL ch 1 burst out control,                      |
| #define pmcparttl ch1 swr       | 0x00B0 //44 PMC Par TTL ch 1 FIFO sin read from RX, sin write to TX   |
| #define pmcparttl ch1 tx aecnt  | 0x00B4 // 45 PMC Par TTL ch 1 almost empty count register and rd-bk   |
| #define pmcparttl ch1 rx afcnt  | 0x00B8 // 46 PMC Par TTL ch 1 almost full count register and rd-bk    |
| #define pmcparttl_ch1_tx_ffcnt  | 0x00BC // 47 PMC Par TTL ch 1 tx fifo word count                      |
| #define pmcparttl_ch1_rx_ffcnt  | 0x00C0 // 48 PMC Par TTL ch 1 rx fifo word count                      |
| // #define pmcparttl_ch1_SPARE  | 0x00C4 // 49 PMC Par TTL ch 1 spare                                   |
|                                 |                                                                       |

 Figure 4
 PMC-PARALLEL-TTL Channel Address Map



# Programming

Programming the PMC-PARALLEL-TTL-BA16 requires only the ability to read and write data in the host's PMC space.

Once the initialization process has occurred, and the system has assigned addresses to the PMC-Parallel-TTL-BA16 card the software will need to determine what the address space is for the PCI interface [BAR0]. The offsets in the address table are relative to the system assigned BAR0 base address.

The next step is to initialize the PMC-Parallel-TTL-BA16. If the basic mode of direct read and write operations is to be used then the default settings can be used except for setting the master output enable and the direction bits corresponding to the channels to transmit on.

If COS inputs are to be used the reference and divisor clocks may require programming. In many cases the default settings will work. In addition the Rising, Falling, and Interrupt capabilities need to be programmed. Once the settings are in place it is recommended that the receive state registers are written to for clearing purposes as the programming steps may cause phantom events to be captured.

If the programmable data path is used the DMA\_REG selection will be required plus the initialization of the DMA and channel control registers. The address map is defined with a channel 0 and channel 1 definitions using the standard expandable architecture that Dynamic Engineering employs. Additional channels would be added at offsets with similar channel register definitions for ease of programming. One additional programming step will be to initialize the PLL to the user desired frequency.

For Windows<sup>™</sup> and Linux systems the Dynamic Driver can be used. The driver will take care of finding the hardware and provide an easy to use mechanism to program the hardware. The Driver comes with reference software showing how to use the card and reference frequency files to allow the user to duplicate the test set-up used in manufacturing at Dynamic Engineering. Using simple, known to work routines is a good way to get acquainted with new hardware.

To use the BA16 specific functions the Channel Control, DMA/Reg and Direction registers plus DMA will need to be programmed. To use DMA, memory space from the system should be allocated and the link list stored into memory. The location of the link list is written to the BA16 to start the DMA. Please refer to the Burst IN and Burst Out register discussions. The transmitter for the BA16 is a port from the standard data engine featured in the rev B PMC Parallel TTL with the Align32 and Clock outputs added. The mode should be set to byte and the PLL programmed to 1 MHz to get the correct results if transmitting. Only byte wide data will be transmitted. The



corresponding bits in the Direction and DMA/Reg control registers will need to be set to select output and DMA controlled function.

DMA should be set-up before starting the receiver. The receiver will automatically adjust to the incoming clock rate within the operational parameters. The data will be captured and extended to 32 bit wide words and then DMA'd to host memory. The first byte captured will be stored at the 7-0 location, the second at 15-8 and so forth. Data will continue to be captured until the receiver is stopped with software. The DMA can be programmed with a specific length. The length can be as long as you want within standard memory limitations. At the end of the DMA transfer the Host will receive an interrupt. The receiver can be stopped and the FIFO reset to clear our any extra data captured. For on-the-fly processing multiple shorter DMA segments can be programmed, and at the interrupt restart DMA to point at the alternate segment to allow processing on the previous one.



# **Register Definitions**

# pmcparttl\_BASE

[\$00 parallel-io Control Register Port read/write]

| DATA BIT | DESCRIPTION                                |
|----------|--------------------------------------------|
| 31-21    | spare                                      |
| 20       | bit 19 read-back of pll_dat register bit   |
| 19       | pll_dat [write to PLL, read-back from PLL] |
| 18       | pll_s2                                     |
| 17       | pll_sclk                                   |
| 16       | pll_en                                     |
| 15-5     | spare                                      |
| 4        | Master Parallel Data Enable                |
| 3        | spare                                      |
| 2        | spare                                      |
| 1        | Force Interrupt                            |
| 0        | Master Interrupt Enable                    |

#### Figure 5 PMC-PARALLEL-TTL Control port 0 Bit Map

This is the base control register for the PMC Parallel TTL. The features common to all channels are controlled from this port. Unused bits are reserved for additional new features. Unused bits should be programmed '0' to allow for future commonality.

Master Interrupt Enable when '1' gates active interrupt requesting conditions onto Interrupt Request A. When set to '0' the interrupting functions are available as status but no interrupt request is generated by the card to allow for polled operation.

Force Interrupt when '1' and the master enabled will cause an interrupt request. The interrupt can be cleared by clearing this bit or disabling the master interrupt enable or both. Force Interrupt is used for test and software development purposes.

Master Parallel Data Enable is used to allow the upper and lower data to be synchronized. The upper 32 bits and the lower 32 bits are not accessed at the same time. If the user wants to have the upper and lower data change at the same time the Master enable can be cleared to '0', both halves of the data written and then the enable set '1'. If synchronization is not an issue; program to '1' as part of initialization.

pll\_en: When this bit is set to a one, the signals used to program and read the PLL are enabled.



pll\_sclk/pll\_dat : These signals are used to program the PLL over the I<sup>2</sup>C serial interface. Sclk is always an output whereas Sdata is bi-directional. This register is where the Sdata output value is specified or read-back.

pll\_s2: This is an additional control line to the PLL that can be used to select additional pre-programmed frequencies. Set to '0' for most applications.

The PLL is programmed with the output file generated by the Cypress PLL programming tool. [CY3672 R3.01 Programming Kit or CyberClocks R3.20.00 Cypress may update the revision from time to time.]

The .JED file is used by the Dynamic Driver to program the PLL. Programming the PLL is fairly involved and beyond the scope of this manual. For clients writing their own drivers it is suggested to get the Engineering Kit for this board including software, and to use the translation and programming files ported to your environment. This procedure will save you a lot of time. For those who want to do it themselves the Cypress PLL in use is the 22393. The output file from the Cypress tool can be passed directly to the Dynamic Driver [Linux or Windows] and used to program the PLL without user intervention.

The reference frequency for the PLL is 50 MHz.



# pmcparttl\_ID

[\$04 Switch and Design number port read only]

| DATA BIT | DESCRIPTION            |  |
|----------|------------------------|--|
| 31-24    | spare                  |  |
| 23-8     | Design ID and Revision |  |
| 7-0      | DIP switch             |  |
|          |                        |  |

#### Figure 6 PMC-PARALLEL-TTL ID and Switch Bit Map

The DIP Switch is labeled for bit number and '1' '0' in the silk screen. The DIP Switch can be read from this port and used to determine which PMC Parallel TTL is which in a system with multiple cards installed. The DIPswitch can also be used for other purposes – software revision etc. The switch shown would read back 0x12.



The Design ID and Revision are defined by a 16 bit field allowing for 256 designs and 256 revisions of each. The BA16 design is 0x02 the current revision is 0x01.

The PCI revision is updated in HW to match the design revision. The board ID will be updated for major changes to allow drivers to differentiate between revisions and applications.



## pmcparttl\_STATUS

[\$08 Board level Status Port read only]

| DATA BIT    | DESCRIPTION      |  |
|-------------|------------------|--|
| 31<br>30-18 | Interrupt Status |  |
| 17          | int_stat1        |  |
| 16          | int_stat0        |  |
| 15-6        | spare            |  |
| 5           | INTR Falling     |  |
| 4           | INTR Rising      |  |
| 3-1         | spare            |  |
| 0           | local interrupt  |  |

#### Figure 7 PMC-PARALLEL-TTL Status Port Bit Map

Local Interrupt for the base design, this bit is the same as the Intforce bit – unmasked.

INTR Rising - This is the logical OR of the COS outputs for the Rising Edge condition. The RISING register will select which bits are enabled. If any of the enabled bits are active this bit is set. The status is captured before the master interrupt enable. If the master interrupt enable is set an interrupt will be generated if this condition is true.

INTR Falling - This is the logical OR of the COS outputs for the Falling Edge condition. The Falling register will select which bits can be active [enabled]. If any of the enabled bits capture a falling edge this bit will be set. The status is captured before the master interrupt enable. If the master interrupt enable is set an interrupt will be generated if this condition is true.

Int\_Stat0/1 – This is the local masked not board level masked interrupt from channel 0. Int\_Stat0/1 = DMA Write and DMA Write mask or DMA Read and DMA Read Mask or (IntForce or TX request) and Channel 0/1 mask. This bit will tell the SW if any channel 0/1 asset could be requesting an interrupt. If the master interrupt enable is set an interrupt will be generated if this condition is true.

Interrupt Status – Set if the PCI interrupt is asserted. This bit can be checked to determine if this card is causing an interrupt to the system. If set the other bits can be checked to see which feature(s) of the board need to be serviced. Secondary reads to the COS or Channel will determine the exact type of interrupt.



# pmcparttl\_DirL

[\$0C Direction Register bits 31-0 read – write ]

| DATA BIT | DESCRIPTION |
|----------|-------------|
| 31-0     | DIR31-0     |

#### Figure 8 PMC-PARALLEL-TTL Direction Lower Bit Map

The lower 32 bits of the parallel port direction are controlled with this port. When reset this port is cleared 0x00000000. All IO are set to read [inputs]. To use one or more of the IO for outputs; program the corresponding direction bit(s) to '1'.

## pmcparttl\_DirU

[\$10 Direction Register bits 63-32 read – write ]

| DATA BIT | DESCRIPTION |
|----------|-------------|
| 31-0     | DIR63-32    |

#### Figure 9 PMC-PARALLEL-TTL Direction Upper Bit Map

The upper 32 bits of the parallel port direction are controlled with this port. When reset this port is cleared 0x00000000. All IO are set to read [inputs]. To use one or more of the IO for outputs; program the corresponding direction bit(s) to '1'.

Once a Direction bit is set to output the data in the corresponding output holding register bit is broadcast on that IO line. The data in the holding register will match the data in the data output register if the master parallel enable bit is set. If initial states are important you may want to program the initial data and enable it before enabling the direction bits.



# pmcparttl\_DatL

[\$14 Data IO Port read/write]

| Figure 10 | PMC-PARALLEL-TTL Data IO Lower Bit Map |  |
|-----------|----------------------------------------|--|
| 31-0      | Data IO 31-0                           |  |
| DATA BIT  | DESCRIPTION                            |  |

#### pmcparttl\_DatU

[\$18 Data IO Port read/write]

| Figure 11 | PMC-PARALLEL-TTL Data IO Upper Bit Map |  |
|-----------|----------------------------------------|--|
| 31-0      | Data IO 63-32                          |  |
| DATA BIT  | DESCRIPTION                            |  |

This port is really a combined Data Output port and a Data Input port. The data to be transmitted is written to the Data Output Port side of the Data Register. The data to be read from the IO are read from Data Input side of the Data register. Read back from the Data Output port is done though the separate "datareg" port.

The data read from the data register is a direct read of the state of the IO lines. The bits are not modified for level or transition etc. Some bits may be defined as outputs. The input will match the output definition in this case. Local loop-back can be performed for the bits where outputs are defined. The inputs will match the state of the system when external devices can drive the input lines. The input bits can be masked out of the data word to reduce the data to external inputs.

The output bits are driven onto the IO for the bits that are enabled with the direction control register, and when the master parallel enable is set. For bits without the direction register bit set there are no side effects. The direction register will act as a mask for the data register.



# pmcparttl\_DatLreg

[\$1C Data Reg Port read only]

| DATA BIT | DESCRIPTION  |  |
|----------|--------------|--|
| 31-0     | Data IO 31-0 |  |

Figure 12 PMC-PARALLEL-TTL Data Reg Lower Bit Map

## pmcparttl\_DatUreg

[\$20 Data Reg Port read only]

| DATA BIT | DESCRIPTION   |  |
|----------|---------------|--|
| 31-0     | Data IO 63-32 |  |

Figure 13 PMC-PARALLEL-TTL Data Reg Upper Bit Map

Data written to the Data IO registers can be read back through this port. The register is read back instead of the IO side when accessing this port. The data will match the state of the data output bits written to the output side of the Data IO register.



# pmcparttl\_COSclk

[\$24 COS clock definition port read -write]

| DATA BIT                  | DESCRIPTION                                                               |  |
|---------------------------|---------------------------------------------------------------------------|--|
| 15<br>14-13<br>12<br>11-0 | Data Out 0 Enable<br>CLOCK PRE-SELECTOR<br>CLOCK POST-SELECTOR<br>DIVISOR |  |

#### Figure 14 PMC-PARALLEL-TTL COS Clk Control Bit Map

Data Out 0 Enable when set and the corresponding Direction bit is set will drive the COS clock out on Data bit 0. An oscilloscope can be used to verify the frequency setting that is programmed with the COSclk register.

CLOCK PRE-SELECTOR

- 00 PCI Clock
- 01 Oscillator
- 10 External Clock
- 11 PCI Clock

The clock pre-selector is used to select which reference clock to use with the divisor hardware (clock source). The base design oscillator rate is 50 MHz. The external clock can be any TTL level source driven onto the External Clock input line. The clock should be free running to be used for this purpose.

POST-SELECTOR when '1' sets the output clock to the divided clock, when '0' sets the output clock to the pre-selector reference value (clock source).

DIVISOR[11-0] are the clock divisor select bits. The clock source is divided by a 12-bit counter. The output frequency is {reference / [2(n+1)]}, n $\ge$ 1. The counter divides by N+1 due to counting from 0 to n before rolling over. The output is then divided by 2 to produce a square wave output.

The desired frequency of 1 MHz. Is achieved by selecting Osc reference, divided clock and a factor of 50 with the standard 50 MHz oscillator.  $2(N+1) = 50 \Rightarrow N = 24$ . 0x3018 would be the correct value to write to the COSclk.



# pmcparttl\_RisLreg

\$2C Rising Lower Control Register Port read/write

| DATA BIT | DESCRIPTION |
|----------|-------------|
| 31-0     | Rising 31-0 |

Figure 15 PMC-PARALLEL-TTL Rising Lower Bit Map

#### pmcparttl\_RisUreg

\$30 Rising Upper Control Register Port read/write

| DATA BIT | DESCRIPTION  |
|----------|--------------|
| 31-0     | Rising 63-32 |

Figure 16 PMC-PARALLEL-TTL Rising Upper Bit Map

The Rising control register bits correspond to the input data bits. All IO can be set-up for COS activity even if defined as an output. In most cases the output bits will be set to '0' for the Rising register. When set '1' and the corresponding input bit transitions from low to high the COS register of rising activity will be have the corresponding bit set. If the separate interrupt enable bit is also set then an interrupt can be generated. The Rising register is a control register. The COS data is read back separately.



# pmcparttl\_FallLreg

\$34 Rising Lower Control Register Port read/write

| DATA BIT | DESCRIPTION  |
|----------|--------------|
| 31-0     | Falling 31-0 |

Figure 17 PMC-PARALLEL-TTL Falling Lower Bit Map

## pmcparttl\_FallUreg

\$38 Rising Upper Control Register Port read/write

| DATA BIT | DESCRIPTION   |
|----------|---------------|
| 31-0     | Falling 63-32 |

Figure 18 PMC-PARALLEL-TTL Falling Upper Bit Map

The Falling control register bits correspond to the input data bits. All IO can be set-up for COS activity even if defined as an output. In most cases the output bits will be set to '0' for the Falling register. When set '1' and the corresponding input bit transitions from High to Low the COS register of falling activity will be have the corresponding bit set. If the separate interrupt enable bit is also set then an interrupt can be generated. The Falling register is a control register. The COS data is read back separately.



# pmcparttl\_IntRisLreg

\$3C Rising Interrupt Lower Control Register Port read/write

| DATA BIT | DESCRIPTION        |
|----------|--------------------|
| 31-0     | Rising Int En 31-0 |

Figure 19 PMC-PARALLEL-TTL Int rising Lower Bit Map

#### pmcparttl\_IntRisUreg

\$40 Rising Interrupt Upper Control Register Port read/write

| DATA BIT | DESCRIPTION         |
|----------|---------------------|
| 31-0     | Rising Int En 63-32 |

Figure 20 PMC-PARALLEL-TTL int Rising Upper Bit Map

The Rising Interrupt Enable control register bits correspond to the input data bits. All IO can be set-up for COS activity even if defined as an output. In most cases the output bits will be set to '0' for the Rising Interrupt Enable register. When set '1' and the corresponding Rising bit is captured by the COS register an interrupt can be generated. Please note that the master interrupt enable will also need to be set for the interrupt to be requested.



# pmcparttl\_IntFallLreg

\$44 Falling Interrupt Lower Control Register Port read/write

| DATA BIT | DESCRIPTION         |
|----------|---------------------|
| 31-0     | Falling Int En 31-0 |

Figure 21 PMC-PARALLEL-TTL Int Falling Lower Bit Map

#### pmcparttl\_IntFallUreg

\$48 Falling Interrupt Upper Control Register Port read/write

| DATA BIT | DESCRIPTION          |
|----------|----------------------|
| 31-0     | Falling Int En 63-32 |

#### Figure 22 PMC-PARALLEL-TTL int Falling Upper Bit Map

The Falling Interrupt Enable control register bits correspond to the input data bits. All IO can be set-up for COS activity even if defined as an output. In most cases the output bits will be set to '0' for the Falling Interrupt Enable register. When set '1' and the corresponding falling bit is captured by the COS register an interrupt can be generated. Please note that the master interrupt enable will also need to be set for the interrupt to be requested.



# pmcparttl\_IntRisLstat

| \$4C Rising Status Lower Control Register Port read/write |                      |  |
|-----------------------------------------------------------|----------------------|--|
| DATA BIT                                                  | DESCRIPTION          |  |
| 31-0                                                      | Rising COS bits 31-0 |  |

Figure 23 PMC-PARALLEL-TTL Rising COS Status Lower

#### pmcparttl\_IntRisUstat

\$50 Rising Status Upper Control Register Port read/write

| DATA BIT | DESCRIPTION           |
|----------|-----------------------|
| 31-0     | Rising COS bits 63-32 |

#### Figure 24 PMC-PARALLEL-TTL Rising COS status upper

The COS captured for those bits enabled with the Rising register are held in this register. The bits are held until cleared. Bits are cleared by writing to the register with the corresponding bit or bits set. Writing to the register with the data read will clear the bits the software has read, and not clear the bits not set at the time of reading. This is the recommended practice to avoid conflicts. It is recommended to write to all bits [clear] after setting the COS Rising and Direction bits to clear any potential COS status generated by set-up.



# pmcparttl\_IntRisLstat

\$54 Falling Status Lower Control Register Port read/write

| DATA BIT | DESCRIPTION                  |
|----------|------------------------------|
| 31-0     | Falling COS Status bits 31-0 |

Figure 25 PMC-PARALLEL-TTL Falling COS Status Lower

#### pmcparttl\_IntRisUstat

\$58 Falling Status Upper Control Register Port read/write

| DATA BIT | DESCRIPTION                   |
|----------|-------------------------------|
| 31-0     | Falling COS Status bits 63-32 |

Figure 26 PMC-PARALLEL-TTL Falling COS status upper

The COS captured for those bits enabled with the Falling register are held in this register. The bits are held until cleared. Bits are cleared by writing to the register with the corresponding bit or bits set. Writing to the register with the data read will clear the bits the software has read, and not clear the bits not set at the time of reading. This is the recommended practice to avoid conflicts. It is recommended to write to all bits [clear] after setting the COS Falling and Direction bits to clear any potential COS status generated by set-up.



# pmcparttl\_DR\_L

[\$0x5C DMA Register bits 31-0 read – write ]

| DATA BIT | DESCRIPTION                  |
|----------|------------------------------|
| 31-0     | DMA or Register control 31-0 |

#### Figure 27 PMC-PARALLEL-TTL DMA Reg Lower Bit Map

The lower 32 bits of the DMA / Register selection are controlled with this port. When reset this port is cleared 0x00000000. All IO are set to register control. To use one or more of the IO for DMA controlled functions; program the corresponding direction bit(s) to '1'.

## pmcparttl\_DR\_U

[\$60 DMA Register bits 63-32 read – write ]

| DATA BIT | DESCRIPTION                   |
|----------|-------------------------------|
| 31-0     | DMA or Register control 63-32 |

## Figure 28 PMC-PARALLEL-TTL Direction Upper Bit Map

The upper 32 bits of the DMA / Register selection are controlled with this port. When reset this port is cleared 0x00000000. All IO are set to register control. To use one or more of the IO for DMA controlled functions; program the corresponding direction bit(s) to '1'.

To use the DMA function of programmed parallel data output, the direction register bits and DR register bits corresponding to those outputs must be set to '1'. The Direction bits enable the IO, and the DR bits select the State Machine output path instead of the Register path. Please note that the bits are selected on a bit by bit basis. Pick the closest larger size with the state-machine and the actual size with the DR and Direction bits. Any unused bits [by the state machine with masking] can be used as registered IO or COS inputs.



# pmcparttl\_ch0,1\_base

| [0x78, A0] Channel Control Register (read/ | write)                                  |
|--------------------------------------------|-----------------------------------------|
|                                            | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |

| Channel Control Register |                            |
|--------------------------|----------------------------|
| Data Bit                 | Description                |
| 19                       | BIIDLE                     |
| 18                       | BO IDLE                    |
| 17                       | TX IDLE                    |
| 16                       | RX IDLE                    |
| 15                       | RX Endian                  |
| 14                       | CLK RX Sel                 |
| 13                       | CLK TX Sel                 |
| 12                       | TX MT Mode                 |
| 11                       | spare                      |
| 10                       | TX Endian                  |
| 9                        | TX Mode 1                  |
| 8                        | TX Mode 0                  |
| 7                        | Enable RX                  |
| 6                        | Enable TX                  |
| 5                        | Force Interrupt            |
| 4                        | Channel Interrupt Enable   |
| 3                        | Read DMA Interrupt Enable  |
| 2                        | Write DMA Interrupt Enable |
| 1                        | FIFO Bypass Enable         |
| 0                        | FIFO Reset                 |
|                          |                            |

#### Figure 29 PMC-PARALLEL-TTL channel Control Register

<u>FIFO Reset</u>: When set to a one, the transmit and receive FIFOs will be reset. When these bits are zero, normal FIFO operation is enabled. In addition the TX and RX State Machine is also reset.

<u>FIFO Bypass Enable</u>: When this bit is set to a one, any data written to the transmit FIFO will be transferred to the receive FIFO. This allows for fully testing the data FIFOs without using the I/O. When this bit is zero, normal FIFO operation is enabled. The rate at which the data is transferred depends on the clock selection. It is recommended to operate with the clock set to the default oscillator selection when using the bypass mode. Bypass should be set before moving data into the TX FIFO. DMA can be used with Bypass mode.

Write/Read DMA Interrupt Enable: These two bits, when set to one, enable the



interrupts for DMA writes and reads respectively. The DMA interrupts are not affected by the Master Interrupt Enable.

<u>Channel Interrupt Enable</u>: When this bit is set to a one, all enabled interrupts (except the DMA interrupts) will be gated through to the PCI interface level of the design; when this bit is a zero, the interrupts can be used for status without interrupting the host. The channel interrupt enable is for the channel level interrupt sources only. An additional board level master interrupt enable is located in the Base register. The board level master must also be enabled to gate the interrupt through to the host.

<u>Force Interrupt</u>: When this bit is set to a one, a system interrupt will occur provided the Channel Interrupt and master interrupt enables are set. This is useful for interrupt testing.

<u>Enable TX:</u> When set '1' will start the TX function. The control bits for the TX operation should be selected first to guarantee correct operation as the TX output rate may be different from the PCI clock rate. The transmitter function will read data from the TX FIFO and output that data from the TTL outputs.

Enable TX will be cleared by the State-machine when the end conditions are met or can be cleared by software to stop transmission at the next LW boundary. For example if byte mode is selected and the enable is cleared by software mid word, the rest of the word will be sent and then the HW will stop.

<u>Enable RX:</u> When set '1' will start the RX function. The control bits for the RX operation should be selected first to guarantee correct operation as the RX reference rate may be different from the PCI clock rate. The receiver function will write data to the RX FIFO until software disables the data capture.

TX Mode 1:0 The size of the output data is selected with this 2 bit field. 00 Byte [8 bits] 01 Word [16 bits] 10 LW [32 bits] 11 QW [64 bits]

Please note Byte mode should be used with the BA16 design.

TX Endian is used to select the order that the data output is pulled from the FIFO.

The standard pattern for Byte Mode is to load the output pipeline from the bottom so that 7-0 appear on 7-0 first, 15-8 appear on 7-0 second, 23-16 appear on 7-0 third 31-24 last. Then repeat for the next 32 bit word. If Endian = '1' is selected the order is



reversed to pull from the top. 31-24 appears on IO 7-0 first, 23-16 on 7-0 second and so forth.

<u>TX Empty Mode</u> when '0' causes the transmission process to stop when the FIFO becomes empty. For small transfers or when the rate of transfer is low compared to the PCI capability this mode is recommended. The data will burst out until the FIFO goes empty at which time the transmission will stop and the TX Enable will be cleared by the state machine.

When <u>TX Empty Mode</u> is set to '1' the state-machine uses the MT signal to determine that the hardware needs to pause rather than stop. The pipeline is paused with the last value remaining on the IO until data is present in the TX FIFO. The reference output clock is halted when data is not being transmitted to allow a receiver to determine when new data is available. This mode is recommended when the FIFO might become empty prior to completion.

<u>Clock TX Select</u> when '1' selects the PLL A reference clock to be used for transmission. When '0' the oscillator [50 MHz] is selected. For most systems the PLL channel A will be used for speed control. Set the PLL channel A to the transmission rate desired. The PLL is controlled through the base register. The clock reference controls the TX FIFO read side reference clock and the state machine reference rate. Set to oscillator for Bypass mode.

<u>Clock RX Select</u> when '1' Selects PLL B reference clock to be used for reception. When '0' the oscillator [50 MHz] is selected. For most systems the oscillator will be used for speed control. Set the PLL channel B to the sampling rate desired for the receiver if frequencies higher than 8 MHz are expected. 6x the expected frequency [or more]. The PLL is controlled through the base register. Set to oscillator for Bypass mode.

<u>RX and TX IDLE</u> are set when the respective state-machines are in the idle states. When clock rates other than PCI are used it may take a while to clean-up and return to the idle state – waiting for the next command. For example if a 1 MHz output clock is used and the transmission is in byte mode then several clocks will be required to finish the transmission, clear the start bit and return to idle. If SW has cleared the start bit to finish the transmission off then the SW will not have a flag to determine when the clearing action has completed. When the IDLE bit is set the HW has completed its task and returned.



<u>BO and BI Idle</u> are Burst Out and Burst In IDLE state status for the Receive and Transmit DMA actions. The bits will be 1 when in the IDLE state and 0 when processing a DMA. A new DMA should not be launched until the State machine is back in the IDLE state. Please note that the direction implied in the name has to do with the DMA direction – Burst data into the card for TX and burst data out of the card for Receive.

# pmcparttl\_ch0,1\_st

[0x7C,A4] Channel Status Read/Clear Latch Write Port

| Channel Status Register |                                  |
|-------------------------|----------------------------------|
| Data Bit                | Description                      |
| 31                      | Channel Interrupt Active         |
| 30-16                   | data count                       |
| 15                      | Read DMA Interrupt Occurred      |
| 14                      | Write DMA Interrupt Occurred     |
| 13                      | Read DMA Error Occurred          |
| 12                      | Write DMA Error Occurred         |
| 11                      | spare                            |
| 10                      | spare                            |
| 9                       | Receive Done Interrupt Occurred  |
| 8                       | Transmit Done Interrupt Occurred |
| 7                       | Receive Data Valid               |
| 6                       | Receive FIFO Full                |
| 5                       | Receive FIFO Almost Full         |
| 4                       | Receive FIFO Empty               |
| 3                       | spare                            |
| 2                       | Transmit FIFO Full               |
| 1                       | Transmit FIFO Almost Empty       |
| 0                       | Transmit FIFO Empty              |

#### Figure 30 PMC-Parallel-TTL Channel STATUS PORT

<u>Transmit FIFO Empty</u>: When a one is read, the transmit data FIFO contains no data; when a zero is read, there is at least one data word in the FIFO.

<u>Transmit FIFO Almost Empty</u>: When a one is read, the number of data words in the transmit data FIFO is less than or equal to the value written to the TX\_AMT\_LVL register; when a zero is read, the FIFO level is more than that value.

<u>Transmit FIFO Full</u>: When a one is read, the transmit data FIFO is full; when a zero is read, there is room for at least one more data word in the FIFO.



Please note with the Receive side status; the status reflects the state of the FIFO and does not take the 4 deep pipeline into account. For example the FIFO may be empty and there may be valid data within the pipeline. The valid flag can be used to monitor the last few accesses. The data count is the combined FIFO and pipeline value and can also be used for read size control.

<u>Receive FIFO Empty</u>: When a one is read, the receive data FIFO contains no data; when a zero is read, there is at least one data word in the FIFO.

<u>Receive FIFO Almost Full</u>: When a one is read, the number of data words in the receive data FIFO is greater or equal to the value written to the RX\_AFL\_LVL register; when a zero is read, the FIFO level is less than that value.

<u>Receive FIFO Full</u>: When a one is read, the receive data FIFO is full; when a zero is read, there is room for at least one more data-word in the FIFO.

<u>Receive Data Valid</u>: When a one is read, there is at least one valid receive data word left. This bit can be set even if the receive FIFO is empty, because as soon as the first four words are written into the FIFO, they are read out to fill the receive data pipe-line to be ready for a PCI read DMA or single word access. When this bit is a zero, it indicates that there is no valid receive data remaining.

<u>Transmit Done Interrupt Occurred</u>: When a one is read, it indicates that the transmit state-machine has completed. A zero indicates that a transmit message has not been completed. This bit is latched and can be cleared by writing back to the Status register with a one in this bit position.

<u>Receive Done Interrupt Occurred</u>: When a one is read, it indicates that the receive state-machine has received at least one complete message. At least one byte must have been received and then the receive data line must be idle for at least eight bit-periods for a message be considered completed. A zero indicates that a complete message has not been received. This bit is latched and can be cleared by writing back to the Status register with a one in this bit position.

<u>Write/Read DMA Error Occurred</u>: When a one is read, a write or read DMA error has been detected. This will occur if there is a target or master abort or if the direction bit in the next pointer of one of the chaining descriptors is incorrect. A zero indicates that no write or read DMA error has occurred. These bits are latched and can be cleared by writing back to the Status register with a one in the appropriate bit position.



<u>Write/Read DMA Interrupt Occurred</u>: When a one is read, a write/read DMA interrupt is latched. This indicates that the scatter-gather list for the current write or read DMA has completed, but the associated interrupt has yet to be processed. A zero indicates that no write or read DMA interrupt is pending.

<u>Channel Interrupt Active</u>: When a one is read, it indicates that a system interrupt is potentially asserted caused by an enabled channel interrupt condition. A zero indicates that no system interrupt is pending from an enabled channel interrupt condition. The Board level master interrupt enable will also need to be asserted to allow the active channel interrupt to become an interrupt request.



### pmcparttl\_ch0,1\_brstin

[0x80,A8] Write DMA Pointer (write only)

| DMA Pointer Address Register |                                            |  |  |  |
|------------------------------|--------------------------------------------|--|--|--|
| Data Bit                     | Description                                |  |  |  |
| 31-2                         | First Chaining Descriptor Physical Address |  |  |  |
| 1                            | direction [0]                              |  |  |  |
| 0                            | end of chain                               |  |  |  |

#### Figure 31 PMC-Parallel-TTL Write DMA pointer register

This write-only port is used to initiate a scatter-gather write [TX] DMA. When the address of the first chaining descriptor is written to this port, the DMA engine reads three successive long words beginning at that address. Essentially this data acts like a chaining descriptor value pointing to the next value in the chain.

The first is the address of the first memory block of the DMA buffer containing the data to read into the device, the second is the length in bytes of that block, and the third is the address of the next chaining descriptor in the list of buffer memory blocks. This process is continued until the end-of-chain bit in one of the next pointer values read indicates that it is the last chaining descriptor in the list.

All three values are on LW boundaries and are LW in size. Addresses for successive parameters are incremented. The addresses are physical addresses the HW will use on the PCI bus to access the Host memory for the next descriptor or to read the data to be transmitted. In most OS you will need to convert from virtual to physical. The length parameter is a number of bytes, and must be on a LW divisible number of bytes.

Status for the DMA activity can be found in the channel control register and channel status register.

Notes:

- 1. Writing a zero to this port will abort a write DMA in progress.
- 2. End of chain should not be set for the address written to the DMA Pointer Address Register. End of chain should be set when the descriptor follows the last length parameter.
- 3. The Direction should be set to '0' for Burst In DMA in all chaining descriptor locations.



### pmcparttl\_ch0,1\_brstout

[0x84,AC] Read DMA Pointer (write only)

| DMA Pointer Address Register                                           |               |  |  |  |
|------------------------------------------------------------------------|---------------|--|--|--|
| Data Bit Description<br>31-2 First Chaining Descriptor Physical Addres |               |  |  |  |
| 1                                                                      | direction [1] |  |  |  |
| 0                                                                      | end of chain  |  |  |  |

#### Figure 32 PMC-Parallel-TTL Read DMA pointer register

This write-only port is used to initiate a scatter-gather read [RX] DMA. When the address of the first chaining descriptor is written to this port, the DMA engine reads three successive long words beginning at that address. Essentially this data acts like a chaining descriptor value pointing to the next value in the chain.

The first is the address of the first memory block of the DMA buffer to write data from the device to, the second is the length in bytes of that block, and the third is the address of the next chaining descriptor in the list of buffer memory blocks. This process is continued until the end-of-chain bit in one of the next pointer values read indicates that it is the last chaining descriptor in the list.

All three values are on LW boundaries and are LW in size. Addresses for successive parameters are incremented. The addresses are physical addresses the HW will use on the PCI bus to access the Host memory for the next descriptor or to read the data to be transmitted. In most OS you will need to convert from virtual to physical. The length parameter is a number of bytes, and must be on a LW divisible number of bytes.

Status for the DMA activity can be found in the channel control register and channel status register.

Notes:

- 1. Writing a zero to this port will abort a write DMA in progress.
- 2. End of chain should not be set for the address written to the DMA Pointer Address Register. End of chain should be set when the descriptor follows the last length parameter.
- 3. The Direction should be set to '1' for Burst Out DMA in all chaining descriptor locations.



| RX and TX FIFO Port |                               |  |  |
|---------------------|-------------------------------|--|--|
| Data Bit<br>31-0    | Description<br>FIFO data word |  |  |

#### Figure 33 PMC-Parallel-TTL RX/TX FIFO Port

This port is used to make single-word accesses into the TX and out of the RX FIFO. Please note that reading is from the RX FIFO and writing is to the TX FIFO. Unless Bypass mode is established the data will not match.

#### pmcparttl\_ch0,1\_tx\_aecnt

[0x8C,B4] TX almost-empty level (read/write)

| TX Almost-Empty Level Register |                                                    |  |  |
|--------------------------------|----------------------------------------------------|--|--|
| Data Bit<br>31-16<br>15-0      | Description<br>Spare<br>TX FIFO Almost-Empty Level |  |  |

#### Figure 34 PMC-Parallel-TTL TX ALMOST EMPTY LEVEL register

This read/write port accesses the transmitter almost-empty level register. When the number of data words in the transmit data FIFO is equal or less than this value, the almost-empty status bit will be set. The register is R/W for 16 bits. The mask is valid for a size matching the depth of the FIFO. 2k x32 is the TX FIFO for an 11 bit valid count range [10-0].



### pmcparttl\_ch0,1\_rx\_afcnt

[0x90,B8] RX almost-full level (read/write)

| RX Almost-Full Level Register |                           |  |
|-------------------------------|---------------------------|--|
| Data Bit                      | Description               |  |
| 31-16                         | Spare                     |  |
| 15-0                          | RX FIFO Almost-Full Level |  |

#### Figure 35 PMC-Parallel-TTL RX ALMOST FULL LEVEL register

This read/write port accesses the receiver almost-full level register. When the number of data words in the receive data FIFO is equal or greater than this value, the almost-full status bit will be set. The register is R/W for 16 bits. The mask is valid for a size matching the depth of the FIFO. 4k x32 is the RX FIFO for a 12 bit valid count range [11-0].

### pmcparttl\_ch0,1\_tx\_ffcnt

[0x94,BC] TX FIFO data count (read only)

| TX FIFO Data Count Port   |                                              |  |  |
|---------------------------|----------------------------------------------|--|--|
| Data Bit<br>31-12<br>11-0 | Description<br>Spare<br>TX Data Words Stored |  |  |

#### Figure 36 PMC-Parallel-TTL TX fifo data count Port

This read-only register port reports the number of 32-bit data words in the transmit FIFO. The TX FIFO has a maximum of 2047 locations.



### pmcparttl\_ch0\_rx\_ffcnt

[0x98, C0] RX FIFO data count (read only)

| RX FIFO Data Count Port   |                                              |  |
|---------------------------|----------------------------------------------|--|
| Data Bit<br>31-12<br>11-0 | Description<br>Spare<br>RX Data Words Stored |  |

Figure 37 PMC-Parallel-TTL RX fifo data count Port

This read-only register port reports the number of 32-bit data words in the receive FIFO. The channel status register contains the combined pipeline and FIFO count. The size depends on the FIFO size. This design has 4095 locations possible in the FIFO.



# Loop-back

The Engineering kit has reference software, which includes external loop-back tests. The PMC-Parallel-TTL has a 68 pin SCSI II front panel connector. The tests require an external cable with the following pins connected.

External BA16 function Loop-Back

| Signal          | From        | То          | Signal |
|-----------------|-------------|-------------|--------|
| RX              |             |             | TX     |
| IO 0 [D00]      | pin 33      | pin 67      | IO 32  |
| IO 1 [D01]      | ,<br>pin 32 | pin 66      | IO 33  |
| IO 2 [D02]      | pin 31      | ,<br>pin 65 | IO_34  |
| IO_3 [D03]      | pin 30      | ,<br>pin 64 | IO_35  |
| IO 4 [D04]      | pin 29      | pin 63      | IO 36  |
| IO 5 [D05]      | pin 28      | ,<br>pin 62 | IO_37  |
| IO_6 [D06]      | pin 27      | pin 61      | IO_38  |
| IO_7 [D07]      | pin 26      | pin 60      | IO_39  |
| IO_8 [ALGN320]  | ,<br>pin 25 | pin 59      | IO_40  |
| IO_9 [CLK0]     | pin 24      | pin 58      | IO_41  |
| IO_16 [D10]     | pin 17      | pin 51      | IO_48  |
| IO_17 [D11]     | pin 16      | pin 50      | IO_49  |
| IO_18 [D12]     | pin 15      | pin 49      | IO_50  |
| IO_19 [D13]     | pin 14      | pin 48      | IO_51  |
| IO_20 [D14]     | pin 13      | pin 47      | IO_52  |
| IO_21 [D15]     | pin 12      | pin 46      | IO_53  |
| IO_22 [D16]     | pin 11      | pin 45      | IO_54  |
| IO_23 [D17]     | pin 10      | pin 44      | IO_55  |
| IO_24 [ALGN321] | pin 9       | pin 43      | IO_56  |
| IO_25 [CLK1]    | pin 8       | pin 42      | IO_57  |



# **PMC Module Logic Interface Pin Assignment**

The figure below gives the pin assignments for the PMC Module PCI Pn1 Interface on the PMC-Parallel-TTL. See the User Manual for your carrier board for more information. Unused pins may be assigned by the specification and not needed by this design.

| ( ) (     |              |             | •        |  |
|-----------|--------------|-------------|----------|--|
| -12V      |              | 1           | 2        |  |
| GND       | INTA#        | 3           | 4        |  |
|           |              | 3<br>5<br>7 | 6        |  |
| BUSMODE1# | +5V          |             | 8        |  |
|           |              | 9           | 10       |  |
| GND -     |              | 11          | 12       |  |
| CLK       | GND          | 13          | 14       |  |
| GND -     |              | 15          | 16       |  |
|           | +5V          | 17          | 18       |  |
|           | AD31         | 19          | 20       |  |
| AD28-     | AD27         | 21          | 22       |  |
| AD25-     | GND          | 23          | 24       |  |
| GND -     | C/BE3#       | 25          | 26       |  |
| AD22-     | AD21         | 27          | 28       |  |
| AD19      | +5V          | 29          | 30       |  |
| 1.010     | AD17         | 31          | 32       |  |
| FRAME#-   | GND          | 33          | 34       |  |
| GND       | IRDY#        | 35          | 36       |  |
| DEVSEL#   | +5V          | 37          | 38       |  |
| GND       | LOCK#        | 39          | 40       |  |
| OND       |              | 41          | 42       |  |
| PAR       | GND          | 43          | 44       |  |
| 1744      | AD15         | 45          | 46       |  |
| AD12-     | AD13<br>AD11 | 47          | 48       |  |
| AD9-      | +5V          | 49          | 50       |  |
| GND -     | C/BE0#       | 51          | 52       |  |
| AD6-      | AD5          | 53          | 52       |  |
| AD4       | GND          | 55          | 56       |  |
| AD4       | AD3          | 57          | 58       |  |
| AD2-      | AD3<br>AD1   | 57          | 50<br>60 |  |
| ADZ-      | 401<br>+5V   | 59<br>61    |          |  |
|           | VC+          |             | 62       |  |
| GND       |              | 63          | 64       |  |
|           |              |             |          |  |

Figure 38 PMC-PARALLEL-TTL Pn1 Interface



# **PMC Module Logic Interface Pin Assignment**

The figure below gives the pin assignments for the PMC Module PCI Pn2 Interface on the PMC-Parallel-TTL. See the User Manual for your carrier board for more information. Unused pins may be assigned by the specification and not needed by this design.

| 101/                        |           | 4           | 0  |  |
|-----------------------------|-----------|-------------|----|--|
| +12V                        |           | 1           | 2  |  |
|                             |           | 3<br>5<br>7 | 4  |  |
|                             | GND       | 5           | 6  |  |
| GND                         |           |             | 8  |  |
|                             |           | 9           | 10 |  |
|                             |           | 11          | 12 |  |
| RST#                        | BUSMODE3# | 13          | 14 |  |
|                             | BUSMODE4# | 15          | 16 |  |
|                             | GND       | 17          | 18 |  |
| AD30                        | AD29      | 19          | 20 |  |
| GND                         | AD26      | 21          | 22 |  |
| AD24                        | 7,820     | 23          | 24 |  |
| IDSEL                       | AD23      | 25          | 26 |  |
| IDOLL                       | AD20      | 27          | 28 |  |
| AD18                        | AD20      | 29          | 30 |  |
| AD16                        | C/BE2#    | 31          | 32 |  |
| GND                         | C/BE2#    | 33          | 32 |  |
| TRDY#                       |           |             |    |  |
|                             | OTOD#     | 35          | 36 |  |
| GND                         | STOP#     | 37          | 38 |  |
| PERR#                       | GND       | 39          | 40 |  |
| ~ · <b>-</b> - <i>· · ·</i> | SERR#     | 41          | 42 |  |
| C/BE1#                      | GND       | 43          | 44 |  |
| AD14                        | AD13      | 45          | 46 |  |
| GND                         | AD10      | 47          | 48 |  |
| AD8                         |           | 49          | 50 |  |
| AD7                         |           | 51          | 52 |  |
|                             |           | 53          | 54 |  |
|                             | GND       | 55          | 56 |  |
|                             |           | 57          | 58 |  |
| GND                         |           | 59          | 60 |  |
|                             |           | 61          | 62 |  |
| GND                         |           | 63          | 64 |  |
| 0.10                        |           | 00          | 0. |  |
| <b>E</b> :                  |           |             |    |  |



# PMC Module Front Panel IO Interface Pin Assignment

The figure below gives the pin assignments for the PMC Module IO Interface on the PMC-Parallel-TTL. Installed for –FP and –FRP models. Also see the User Manual for your carrier board for more information.

|              |                | 4           | 25       |  |
|--------------|----------------|-------------|----------|--|
| EXT_CLK_EN   | EXT_CLK        | 1           | 35       |  |
| IO_31        | IO_63          | 2<br>3<br>4 | 36       |  |
| IO_30        | IO_62          | 3           | 37       |  |
| IO_29        | IO_61          | 4           | 38       |  |
| IO_28        | IO_60          | 5           | 39       |  |
| 10_27        | IO_59          | 5<br>6<br>7 | 40       |  |
| IO_26        | IO_58          | 7           | 41       |  |
| IO_25        | IO_57          | 8           | 42       |  |
| 10_24        | IO_56          | 9           | 43       |  |
| 10_23        | IO_55          | 10          | 44       |  |
| 10_22        | IO 54          | 11          | 45       |  |
| IO_21        | IO_53          | 12          | 46       |  |
| IO_20        | IO_52          | 13          | 47       |  |
| IO_19        | IO_51          | 14          | 48       |  |
| IO_18        | IO_50          | 15          | 49       |  |
| IO_17        | IO_49          | 16          | 50       |  |
| IO 16        | IO 48          | 17          | 51       |  |
| IO_15        | IO_47          | 18          | 52       |  |
| IO_14        | IO_46          | 19          | 53       |  |
| IO_13        | IO_45          | 20          | 54       |  |
| 10_12        | IO_44          | 21          | 55       |  |
| IO_11        | IO_43          | 22          | 56       |  |
| 10_10        | 10_10          | 23          | 57       |  |
| IO_9         | IO_41          | 24          | 58       |  |
| IO_8         | IO_40          | 25          | 59       |  |
| IO_7         | IO_39          | 26          | 60       |  |
| IO_6         | IO_38          | 27          | 61       |  |
| IO_5         | IO_37          | 28          | 62       |  |
| IO_3<br>IO_4 | IO_37<br>IO_36 | 29          | 63       |  |
| IO_4<br>IO_3 | IO_35          | 30          | 64       |  |
| IO_3<br>IO_2 | IO_33<br>IO_34 | 30          | 65       |  |
|              |                | 32          |          |  |
| IO_1         | IO_33          |             | 66<br>67 |  |
|              | IO_32          | 33          | 67       |  |
| GND          | GND            | 34          | 68       |  |
|              |                |             |          |  |
|              |                |             |          |  |

Figure 40

PMC-PARALLEL-TTL FRONT PANEL Interface



## PMC Module Front Panel IO Interface Pin Assignment

The figure below gives the pin assignments for the PMC Module IO Interface on the PMC-Parallel-TTL-BA16. See the User Manual for your carrier board for more information.

| RESERVED           | RESERVED           | 1                | 35 |
|--------------------|--------------------|------------------|----|
| IO 31              | IO_63              | 1                | 36 |
| IO_31<br>IO_30     | IO_83<br>IO_62     | 2<br>3           | 37 |
| IO_30<br>IO_29     | IO_61              | 3                | 38 |
| IO_29<br>IO_28     | IO_60              | 4                | 39 |
| IO_20<br>IO_27     | IO_59              | 5                | 40 |
| IO_27<br>IO_26     | IO_58              | 4<br>5<br>6<br>7 | 40 |
| CLK IN1            |                    | 8                | 42 |
| ALIGN32 IN1        | ALIGN32 OUT1       | 9                | 43 |
| DATA IN 17         | DATA OUT 17        | 10               | 44 |
| DATA IN 16         | DATA OUT 16        | 11               | 45 |
| DATA IN 15         | DATA OUT 15        | 12               | 46 |
| DATA IN 14         | DATA_OUT_14        | 13               | 47 |
| DATA_IN_13         | DATA_OUT_13        | 14               | 48 |
| DATA IN 12         | DATA OUT 12        | 15               | 49 |
| DATA IN 11         | DATA OUT 11        | 16               | 50 |
| DATA IN 10         | DATA OUT 10        | 17               | 51 |
| IO 15 <sup></sup>  | IO 47 <sup>–</sup> | 18               | 52 |
| IO <sup>-</sup> 14 | IO <sup>-</sup> 46 | 19               | 53 |
| IO_13              | IO_45              | 20               | 54 |
| IO_12              | IO_44              | 21               | 55 |
| IO_11              | IO_43              | 22               | 56 |
| IO_10              | IO_42              | 23               | 57 |
| CLK_IN0            | CLK_OUT0           | 24               | 58 |
| ALIGN32_IN0        | ALIGN32_OUT0       | 25               | 59 |
| DATA_IN_07         | DATA_OUT_07        | 26               | 60 |
| DATA_IN_06         | DATA_OUT_06        | 27               | 61 |
| DATA_IN_05         | DATA_OUT_05        | 28               | 62 |
| DATA_IN_04         | DATA_OUT_04        | 29               | 63 |
| DATA_IN_03         | DATA_OUT_03        | 30               | 64 |
| DATA_IN_02         | DATA_OUT_02        | 31               | 65 |
| DATA_IN_01         | DATA_OUT_01        | 32               | 66 |
| DATA_IN_00         | DATA_OUT_00        | 33               | 67 |
| GND                | GND                | 34               | 68 |
|                    |                    |                  |    |
|                    |                    |                  |    |

Figure 41 PMC-PARALLEL-TTL BA16 FRONT PANEL Interface

 $_IN = RX$ ,  $_OUT = TX$ ,  $_0x =$  channel 0, 1x = channel 1 IOxx are un-committed IO that can be used for registered IO or COS.



# PMC Module Backplane IO Interface Pin Assignment

The figure below gives the pin assignments for the PMC Module IO Interface on the PMC-Parallel-TTL and routed to Pn4. Pn4 installed for –RP and –FRP models. Not installed for BA16. Also see the User Manual for your carrier board for more information.

| $\begin{array}{c} \text{IO}\_0\\ \text{IO}\_2\\ \text{IO}\_4\\ \text{IO}\_6\\ \text{IO}\_8\\ \text{IO}\_10\\ \text{IO}\_12\\ \text{IO}\_14\\ \text{IO}\_16\\ \text{IO}\_20\\ \text{IO}\_22\\ \text{IO}\_24\\ \text{IO}\_26\\ \text{IO}\_28\\ \text{IO}\_30\\ \text{IO}\_32\\ \text{IO}\_34\\ \text{IO}\_36\\ \text{IO}\_38\\ \text{IO}\_40\\ \text{IO}\_42\\ \text{IO}\_44\\ \text{IO}\_46\\ \text{IO}\_48\\ \text{IO}\_50\\ \text{IO}\_52\\ \text{IO}\_54\\ \text{IO}\_56\\ \text{IO}\_58\\ \text{IO}\_60\\ \text{IO}\_62\\ \end{array}$ | $\begin{array}{c} \text{IO}\_1\\ \text{IO}\_3\\ \text{IO}\_5\\ \text{IO}\_7\\ \text{IO}\_9\\ \text{IO}\_11\\ \text{IO}\_13\\ \text{IO}\_15\\ \text{IO}\_17\\ \text{IO}\_19\\ \text{IO}\_21\\ \text{IO}\_23\\ \text{IO}\_25\\ \text{IO}\_27\\ \text{IO}\_29\\ \text{IO}\_31\\ \text{IO}\_33\\ \text{IO}\_35\\ \text{IO}\_37\\ \text{IO}\_39\\ \text{IO}\_41\\ \text{IO}\_43\\ \text{IO}\_43\\ \text{IO}\_45\\ \text{IO}\_47\\ \text{IO}\_49\\ \text{IO}\_51\\ \text{IO}\_53\\ \text{IO}\_55\\ \text{IO}\_57\\ \text{IO}\_59\\ \text{IO}\_57\\ \text{IO}\_59\\ \text{IO}\_61\\ \text{IO}\_63\\ \end{array}$ | $     \begin{array}{c}       1 \\       3 \\       5 \\       7 \\       9 \\       11 \\       13 \\       15 \\       17 \\       19 \\       21 \\       23 \\       25 \\       27 \\       29 \\       31 \\       33 \\       35 \\       37 \\       39 \\       41 \\       43 \\       45 \\       47 \\       49 \\       51 \\       53 \\       55 \\       57 \\       59 \\       61 \\       63 \\     \end{array} $ | $\begin{array}{c} 2\\ 4\\ 6\\ 8\\ 10\\ 12\\ 14\\ 16\\ 18\\ 20\\ 22\\ 24\\ 26\\ 28\\ 30\\ 32\\ 34\\ 36\\ 38\\ 40\\ 42\\ 44\\ 46\\ 48\\ 50\\ 52\\ 54\\ 56\\ 58\\ 60\\ 62\\ 64\\ \end{array}$ |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|

Figure 42

PMC-PARALLEL-TTL PN4 Interface



# **Applications Guide**

### Interfacing

The pin-out tables are displayed with the pins in the same relative order as the actual connectors. Some general interfacing guidelines are presented below. Do not hesitate to contact the factory if you need more assistance.

Watch the system grounds. All electrically connected equipment should have a fail-safe common ground that is large enough to handle all current loads without affecting noise immunity. Power supplies and power-consuming loads should all have their own ground wires back to a common point.

Power all system power supplies from one switch. Open Drain interface devices provide some immunity from, and allow operation when part of the circuit is powered on and part is not. It is better to avoid the issue of going past the safe operating areas by powering the equipment together and by having a good ground reference.

Keep cables short. Flat cables, even with alternate ground lines, are not suitable for long distances. The PMC-Parallel-TTL has optional transorbs for input protection. In addition series resistors are used and can be specified to be something other than the 22 ohm standard value. The connector is pinned out for a standard SCSI II/III cable to be used. It is suggested that this standard cable be used for most of the cable run.

Terminal Block. We offer a high quality 68 screw terminal block that directly connects to the SCSI II/III cable. The terminal block can mount on standard DIN rails. HDEterm68 [http://www.dyneng.com/HDEterm68.html]

We provide the components. You provide the system. Safety and reliability can be achieved only by careful planning and practice. Inputs can be damaged by static discharge, or by applying voltage outside of the particular device's rated voltages.



## **Construction and Reliability**

PMC Modules were conceived and engineered for rugged industrial environments. The PMC-Parallel-TTL is constructed out of 0.062 inch thick high temperature ROHS compliant material.

The traces are matched length from the FPGA ball to the IO pin. The options for front panel and rear panel are isolated with series resistor packs to eliminate bus stubs when one of the connectors is not in use.

Surface mounted components are used.

The PMC Module connectors are keyed and shrouded with Gold plated pins on both plugs and receptacles. They are rated at 1 Amp per pin, 100 insertion cycles minimum. These connectors make consistent, correct insertion easy and reliable.

The PMC is secured against the carrier with the connectors and front panel. If more security against vibration is required the stand-offs can be secured against the carrier.

The PMC Module provides a low temperature coefficient of 2.17 W/<sup>o</sup>C for uniform heat. This is based upon the temperature coefficient of the base FR4 material of 0.31 W/m-<sup>o</sup>C, and taking into account the thickness and area of the PMC. The coefficient means that if 2.17 Watts are applied uniformly on the component side, then the temperature difference between the component side and solder side is one degree Celsius.



## **Thermal Considerations**

The PMC-PARALLEL-TTL design consists of CMOS circuits. The power dissipation due to internal circuitry is very low. It is possible to create higher power dissipation with the externally connected logic. If more than one Watt is required to be dissipated due to external loading; forced air cooling is recommended. With the one degree differential temperature to the solder side of the board external cooling is easily accomplished.



### Warranty and Repair

Please refer to the warranty page on our website for the current warranty offered and options. <u>http://www.dyneng.com/warranty.html</u>

## **Service Policy**

Before returning a product for repair, verify as well as possible that the suspected unit is at fault. Then call the Customer Service Department for a RETURN MATERIAL AUTHORIZATION (RMA) number. Carefully package the unit, in the original shipping carton if this is available, and ship prepaid and insured with the RMA number clearly written on the outside of the package. Include a return address and the telephone number of a technical contact. For out-of-warranty repairs, a purchase order for repair charges must accompany the return. Dynamic Engineering will not be responsible for damages due to improper packaging of returned items. For service on Dynamic Engineering Products not purchased directly from Dynamic Engineering contact your reseller. Products returned to Dynamic Engineering for repair by other than the original customer will be treated as out-of-warranty.

## **Out of Warranty Repairs**

Out of warranty repairs will be billed on a material and labor basis. The current minimum repair charge is \$125. Customer approval will be obtained before repairing any item if the repair charges will exceed one half of the quantity one list price for that unit. Return transportation and insurance will be billed as part of the repair and is in addition to the minimum charge.

### 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



# **Specifications**

| Logic Interface:         | PMC Logic Interface [PCI] 32/33                                                                                                                                                                                                       |
|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Digital Parallel IO:     | 64 discrete IO channels. Each has a separate<br>enable to control output. Inputs are maskable and<br>always available. Two channels of "BA16" IO each<br>with programmable rate TX. 8 bit parallel with<br>reference clock and align. |
| CLK rates supported:     | Osc, PLL, PCI, External reference rates coupled<br>with 12 bit divider to allow user programmed<br>sample rate for COS., Osc and PLL programmed<br>TX rate for BA16 interface. Programmed<br>bandwidth on RX [PLLB]                   |
| Software Interface:      | Control Registers, IO registers, IO Read-Back registers                                                                                                                                                                               |
| Initialization:          | Programming procedure documented in this manual                                                                                                                                                                                       |
| Access Modes:            | LW to registers, read-write to most registers                                                                                                                                                                                         |
| Access Time:             | Frame to TRDY 121 nS [4 PCI clocks] or burst mode DMA – 1 word per PCI clock transferred.                                                                                                                                             |
| Interrupt:               | All IO lines can be used as interrupt sources with programmable rising and or falling activity on IO line "COS", DMA interrupts, TX function [BA16]                                                                                   |
| Onboard Options:         | All Options are Software Programmable                                                                                                                                                                                                 |
| Interface Options:       | 68 Pin SCSI III connector at front bezel<br>User IO routed to Pn4 – not installed BA16                                                                                                                                                |
| Dimensions:              | Standard Single PMC Module.                                                                                                                                                                                                           |
| Construction:            | Multi-Layer Printed Circuit, Through Hole and Surface Mount Components.                                                                                                                                                               |
| Temperature Coefficient: | 2.17 W/ <sup>0</sup> C for uniform heat across PMC                                                                                                                                                                                    |
| Power:                   | TBD mA @ 5V outputs off<br>Add 10 mA per active low output for pull-up current<br>drivers support -32/+64 mA per IO line, higher<br>currents are possible depending on load.                                                          |



# **Order Information**

standard temperature range 0-70<sup>ø</sup>C

PMC-Parallel-TTL-BA16 PMC Module with 64 IO channels, COS and direct IO, 2 channels of "BA16" parallel data interface – 8 bits parallel, reference clock, align [strobe], front panel IO, 3.3V reference voltage to pull-ups, DMA support, 4Kx32 FIFO RX, 2Kx32 FIFO TX per channel.

http://www.dyneng.com/pmc parallel TTL.html

### **Order Options:**

Pick One -FP for front panel IO only [default if no selection made] -RP for rear panel IO PN4 only -FRP for both IO connections Shown for reference. BA16 selection determines [-FP]

### Pick any combination to go with IO

-TRANS to add transorbs -CC to add conformal coating -ET to add Industrial Temp [-40 +85] -TS to add thumbscrew option – standard is latch block -3V to change from 5V IO reference to 3.3V IO reference Shown for reference. BA16 selection determines [-3V]

#### Related:

PCI2PMC: PCI to PMC adapter to allow installation of PMC-Parallel-TTL into a PCI system.

http://www.dyneng.com/pci2pmc.html

PCIeBPMCX1: PCIe to PMC adapter to allow installation of PMC-Parallel-TTL into a PCIe system.

http://www.dyneng.com/pciebpmcx1.html

HDEterm68: 68 position terminal block with two SCSI II/III connectors. PMC-Parallel-TTL compatible.

http://www.dyneng.com/HDEterm68.html

HDEcabl68: SCSI II/III cable compatible with FPIO on PMC Parallel IO. http://www.dyneng.com/HDEcabl68.html

**PIM Parallel IO:** PMC IO Module for PMC Parallel TTL design. Provides FPIO in cPCI systems when used with a PIM Carrier http://www.dyneng.com/pim parallel io.shtml



**PMC Parallel IO Eng Kit :** HDEterm68-MP, HDEcabl68, Linux Driver software, reference schematics. Recommended for first time purchases. http://www.dyneng.com/pmc\_parallel\_TTL.html

All information provided is Copyright Dynamic Engineering

