# TIM: PLDs

### Device Type

• Lattice (formerly Vantis/AMD) Mach4 and Mach5.

• Electrically, erasable, CPLDs. Programmed in-circuit via JTAG pins.

#### Design Environment

- Proprietary Vantis/AMD compiler.
- Text files:
  - Source (.src): "the design."
  - Stimulation (.stm): expected inputs.
  - Physical information (.pi): maps signals to pins. are used to generate device simulation results (.sim) and programming files (.jed)
- Only Mach devices can be fitted.

## Design, Simulation & Fitting Process

- Write .src file. Compile until no errors. (eg, pld5.src)
- Write .stm file. Simulate and check results (eg, pld5.sim)
- Fit device using chosen part fixing particular signals to pins (.pi) if required.
- Fix all signals to fitter assigned pins (.pi). Compile again.
- Add spare pins (.pi) and final compile.

## Code Design Management

- Version control same as used for CLOAC boards.
- Differing versions stored in separate date labelled directories.
- All files associated with that version stored together.
- We are considering migration to CVS use in future.



# TIM: PLD Fitting and Programming

#### **Pin Assignment Strategies**

• Register clocks fitted to clock pins where possible.

• Some busses were initial fitted in byte blocks but it was found this limited fitting resources.

### Fitting

- First fit without any constraints.
- Then, fit with important signals eg clocks.
- Refit, fixing all pins to fitter defaults.
- Add 48 spare lines (4 x 8bit global + 2 x 8bit selected.)

#### **Device** Utilisation

| PLD1<br>PLD2<br>PLD3<br>PLD4a<br>PLD4b<br>PLD5<br>PLD6<br>PLD7 | Pins<br>88<br>60<br>66<br>61<br>67<br>80<br>88<br>88 | <u>Macrocells</u><br>17<br>68<br>44<br>21<br>23<br>24<br>23<br>38 | Routing<br>35<br>61<br>49<br>53<br>56<br>40<br>20<br>63 | Device<br>M5-384/184-7HC<br>M5 512/256-7AC<br>M5-384/184-7HC<br>M5-384/184-7HC<br>M5-384/184-7HC<br>M5-384/184-7HC<br>M4 256/128-7YC<br>M5-384/184-7HC |
|----------------------------------------------------------------|------------------------------------------------------|-------------------------------------------------------------------|---------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| -                                                              |                                                      |                                                                   |                                                         |                                                                                                                                                        |

### Programming

- Devices programmed in accordance with Lattice guidelines.
- Lattice software used to program devices via a 2m lead connected to a PC parallel port.
- All JTAG signals buffered in/out of the board.



## TIM: Other PLD Issues

#### **Timing Verification**

- Limited timing verification is possible post-fitting.
- Timing report can be generated showing all signal propagation times through PLD.
- The report is not interactive and can be difficult to interpret.

#### **Reset Philosophy**

• All registers (flip-flops) connected with a global reset line.

### ESD Reduction

• No direct connection of any PLD pin to the outside world. (to help address ESD concerns)





# TIM: PLD5 & FRIENDS









## TIM: PLD8

