### **XStend Board Manual**

**XESS** Corporation

Copyright ©1998 by X Engineering Software Systems Corporation.

All XS-prefix product designations are trademarks of X Engineering Software Systems.

All XC-prefix product designations are trademarks of Xilinx

ABEL is a trademark of DATA I/O Corporation.

All rights reserved. No part of this publication may be reproduced, stored in a retrieval system, or transmitted, in any form or by any means, electronic, mechanical, photocopying, recording, or otherwise, without the prior written permission of the publisher. Printed in the United States of America.

### **Limited Warranty**

X Engineering Software Systems Corp. (XESS) warrants that the Product, in the course of its normal use, will be free from defects in material and workmanship for a period of one (1) year and will conform to XESS's specification therefor. This limited warranty shall commence on the date appearing on your purchase receipt.

XESS shall have no liability for any Product returned if XESS determines that the asserted defect a) is not present, b) cannot reasonably be rectified because of damage occurring before XESS receives the Product, or c) is attributable to misuse, improper installation, alteration, accident or mishandling while in your possession. Subject to the limitations specified above, your sole and exclusive warranty shall be, during the period of warranty specified above and at XESS's option, the repair or replacement of the product. The foregoing warranty of XESS shall extend to repaired or replaced Products for the balance of the applicable period of the original warranty or thirty (30) days from the date of shipment of a repaired or replaced Product, whichever is longer.

THE FOREGOING LIMITED WARRANTY IS XESS'S SOLE WARRANTY AND IS APPLICABLE ONLY TO PRODUCTS SOLD AS NEW. THE REMEDIES PROVIDED HEREIN ARE IN LIEU OF a) ANY AND ALL OTHER REMEDIES AND WARRANTIES, WHETHER EXPRESSED OR IMPLIED OR STATUTORY, INCLUDING BUT NOT LIMITED TO, ANY IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE, AND b) ANY AND ALL OBLIGATIONS AND LIABILITIES OF XESS FOR DAMAGES INCLUDING, BUT NOT LIMITED TO ACCIDENTAL, CONSEQUENTIAL, OR SPECIAL DAMAGES, OR ANY FINANCIAL LOSS, LOST PROFITS OR EXPENSES, OR LOST DATA ARISING OUT OF OR IN CONNECTION WITH THE PURCHASE, USE OR PERFORMANCE OF THE PRODUCT, EVEN IF XESS HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.

In the United States, some statutes do not allow exclusion or limitations of incidental or consequential damages, so the limitations above may not apply to you. This warranty gives you specific legal rights, and you may also have other rights which vary from state to state.

### **Table of Contents**

| 1 X | Stend Overview                    |
|-----|-----------------------------------|
| 2 X | (Stend Board Features             |
| 2.1 | 1 XS40/XS95 Board Mounting Area 4 |
| 2.2 | 2 LEDs                            |
| 2.3 | 3 Switches                        |
| 2.4 | 4 VGA Interface                   |

| 2.5  | PS/2 Keyboard Interface 8                   |
|------|---------------------------------------------|
| 2.6  | RAMs                                        |
| 2.7  | Stereo Codec                                |
| 2.8  | Prototyping Area                            |
| 2.9  | Daughterboard Connector                     |
| 3 Ex | ample Designs for the XStend Board12        |
| 3.1  | Using the LEDs and Switches12               |
| 3.2  | Using the VGA Interface                     |
| 3.3  | Using the PS/2 Keyboard Interface           |
| 3.4  | Using the RAMs                              |
| 3.5  | Using the Stereo Codec 24                   |
| 4 Co | nnections between XStend/XS Board resources |

## **Getting Help!**

If you follow the instructions in this manual and you encounter problems, here are some places to get help:

- If you can't get the XS Board hardware to work, send an e-mail message describing your problem to fpga-bugs@xess.com or check our web site at <a href="http://www.xess.com/FPGA">http://www.xess.com/FPGA</a>.
- If you can't get your XILINX software tools installed properly, send an e-mail message describing your problem to hotline@xilinx.com or check their web site at <a href="http://www.xilinx.com/support/searchtd.htm">http://www.xilinx.com/support/searchtd.htm</a>.

### 1 XStend Overview

The XS40 and XS95 Boards offer a flexible, low-cost method of prototyping FPGA and CPLD designs. However, their small physical size limits the amount of support circuitry they can hold. The XStend Board removes this limitation by providing additional support circuitry that the XS40 and XS95 Boards can access through their breadboard interfaces.

The XStend Board contains resources that extend the range of applications of the XS Boards into three areas:

- The pushbuttons, DIP switches, LEDs, and prototyping area are useful for basic lab experiments. These features in combination with the XS Boards replicates the functionality of the older HW/UW FPGABOARD.
- The VGA monitor interface, PS/2 keyboard/mouse interface, and static RAM let the XS Boards be used in video and computing experiments.
- The stereo codec and dual-channel analog input/output circuitry are useful for processing of audio signals in combination with DSP circuits synthesized with XILINX's CORE generation software.

### 2 XStend Board Features

The XStend Board extends the capabilities of the XS40 and XS95 Boards by providing

- mounting receptacles for both an XS40 and an XS95 Board;
- a 3"×3" prototyping area;
- a 42×2 connector for add-on daughterboards.
- additional LEDs and LED displays;

- pushbutton and DIP switches;
- an interface to VGA monitors;
- an interface to a PS/2-style keyboard or mouse;
- an additional 64 Kbytes of static RAM;
- a stereo codec with left/right input and output channels;

Each of these resources will be described below.

### 2.1 XS40/XS95 Board Mounting Area

An XS40 or XS95 Board is mounted on the XStend Board using mounting receptacle J1 or J2, respectively. These receptacles mate with the breadboard interface of the XS Boards to give them access to all the resources of the XStend Board. The XS Boards also provide power to the XStend Board through these receptacles.

# Warning: Version 1.0 of the XS40 Board with a 3.3V XC4000XL FPGA will not work with the XStend Board! You must replace the XC4000XL FPGA with an XC4000E FPGA and remove the J8 jumper to switch the board to 5V operation.

To use an XS40 Board with the XStend Board, insert it into the right-most columns of the mounting receptacles. When using an XS95 Board, however, you should insert it into the left-most columns. There are markings on the XStend Board to indicate which column is ocuppied by each type of XS Board.

### **2.2 LEDs**

The XStend Board provides an additional eight LEDs (D1—D8) and two more LED displays (U1 and U2) for use by the XS Boards. All of these LEDs are active-low meaning that an LED or LED display segment will glow when a logic-low is applied to it.

The LEDs are disabled by removing the shunts on the following jumpers:

| Jumper | Setting                                                                             |
|--------|-------------------------------------------------------------------------------------|
| J8     | Removing the shunt on this jumper disconnects the power from LEDs D1—D8.            |
| J4     | Removing the shunt on this jumper disconnects the power to the left LED display U1. |

### **Table 1:** Jumper settings for XStend LEDs.

| J7 | Removing the shunt on this jumper disconnects the |
|----|---------------------------------------------------|
|    | power to the right LED display U2.                |

Here are the connections from the XS40 and XS95 Boards to the LEDs on the XStend Board (expressed as UCF constraints):

Listing 1: Connections between the XStend LEDs and the XS40.

```
# LEFT LED DIGIT SEGMENT CONNECTIONS (ACTIVE-LOW)
NET LS 0
                  LOC=P3;
NET LS_1
                  LOC=P4;
NET LS_2
                  LOC=P5;
NET LS_3
                  LOC=P78;
                  LOC=P79;
NET LS_4
NET LS_5
                  LOC=P82;
NET LS_6
                  LOC=P83;
NET LDP_
                  LOC=P84;
#
# RIGHT LED DIGIT SEGMENT CONNECTIONS (ACTIVE-LOW)
NET RS 0
                 LOC=P59;
NET RS_1
                  LOC=P57;
NET RS_2
                  LOC=P51;
NET RS_3
                 LOC=P56;
NET RS_4
                  LOC=P50;
NET RS_5
                  LOC=P58;
NET RS_6
                  LOC=P60;
NET RDP_
                  LOC=P28;
#
# INDIVIDUAL LED CONNECTIONS (ACTIVE-LOW)
NET D 1
                  LOC=P41;
NET D 2
                  LOC=P40;
NET D_3
                  LOC=P39;
NET D_4
                  LOC=P38;
NET D_5
                  LOC=P35;
NET D_6
                  LOC=P81;
NET D_7
                  LOC=P80;
NET D_8
                  LOC=P10;
```

Listing 2: Connections between the XStend LEDs and the XS95.

```
# LEFT LED DIGIT SEGMENT CONNECTIONS (ACTIVE-LOW)
NET LS_0 LOC=P1;
NET LS_1
                           LOC=P2;
NET LS 2
                           LOC=P3;
NET LS_3
                           LOC=P75;
NET LS 4
                           LOC=P79;
                           LOC=P82;
NET LS 5
NET LS_6
                           LOC=P83;
NET LDP
                            LOC=P84;
#
# RIGHT LED DIGIT SEGMENT CONNECTIONS (ACTIVE-LOW)
NET RS_0 LOC=P58;
                           LOC=P56;
NET RS_1
NET RS_2
                           LOC=P54;
                           LOC=P55;
NET RS_3
                           LOC=P53;
NET RS 4
NET RS_5
                           LOC=P57;
NET RS_6
                           LOC=P61;
NET RDP_
                           LOC=P34;
#
# INDIVIDUAL LED CONNECTIONS (ACTIVE-LOW)

      m
      INDIVIDUAL
      IED
      CONNECTION

      NET
      D_1
      LOC=P44;

      NET
      D_2
      LOC=P43;

      NET
      D_3
      LOC=P41;

      NET
      D_4
      LOC=P40;

      NET
      D_5
      LOC=P39;

      NET
      D_6
      LOC=P37;

      NET
      D_7
      LOC=P36:

NET D_7 LOC=P36;
NET D_8 LOC=P35;
```

### 2.3 Switches

The XStend has a bank of eight DIP switches and two pushbuttons (labelled SPARE and RESET) that are accessible from the XS Boards. (There is a third pushbutton labelled PROGRAM which is used to initiate the programming of the XS40 Board. It is not intended to be a general-purpose input.)

When closed, each DIP switch pulls the connected pin of the XS Board to ground. When the DIP switch is open, the pin is pulled high through a 10KWresistor.

When not being used, the DIP switches should be left in the open configuration so the pins of the XS Board are not tied to ground and can freely move between logic low and high levels.

When pressed, each pushbutton pulls the connected pin of the XS Board to ground. Otherwise, the pin is pulled high through a 10 KW resistor.

Here are the connections from the XS40 and XS95 Boards to the switches on the XStend Board expressed as UCF constraints (for the UCF syntax and usage tips, check out http://www.xilinx.com/techdocs/2449.htm):

Listing 3: Connections between the XStend DIP and pushbutton switches and the XS40.

```
# DIP SWITCH CONNECTIONS
NET DIPSW1
              LOC=P7;
NET DIPSW2
                 LOC=P8;
NET DIPSW3
                 LOC=P9;
NET DIPSW4
                 LOC=P6;
NET DIPSW5
                 LOC=P77;
NET DIPSW6
                 LOC=P70;
NET DIPSW7
                 LOC=P66;
NET DIPSW8
                 LOC=P69;
#
# PUSHBUTTON SWITCH CONNECTIONS (ACTIVE-LOW)
NET PUSH_SPARE_ LOC=P67;
                LOC=P37;
NET PUSH_RESET_
```

Listing 4: Connections between the XStend DIP and pushbutton switches and the XS95.

```
# DIP SWITCH CONNECTIONS
NET DIPSW1
                LOC=P6;
NET DIPSW2
                LOC=P7;
NET DIPSW3
                LOC=P11;
NET DIPSW4
                LOC=P5;
NET DIPSW5
                LOC=P72;
NET DIPSW6
NET DIPSW6
NET DIPSW7
                LOC=P71;
                 LOC=P66;
NET DIPSW8
                 LOC=P70;
#
# PUSHBUTTON SWITCH CONNECTIONS (ACTIVE-LOW)
NET PUSH_SPARE_ LOC=P67;
NET PUSH RESET
                 LOC=P10;
```

### 2.4 VGA Interface

The XStend Board provides the XS Board with an interface to a VGA monitor through connector J5. The XS Board can drive the active-low horizontal and vertical sync signals and control the width and height of the video frame. The XS Board also has access to two bits each of red, green, and blue color signals so it can generate pixels in any of  $2^2 \times 2^2 \times 2^2 = 64$  different colors.

Here are the connections from the XS40 and XS95 Boards to the VGA interface of the XStend Board (expressed as UCF constraints):

Listing 5: Connections between the XStend VGA interface and the XS40.

| # V( | GA CONNECTIONS |          |
|------|----------------|----------|
| NET  | VSYNC_         | LOC=P67; |
| NET  | HSYNC_         | LOC=P19; |
| NET  | RED1           | LOC=P18; |
| NET  | red0           | LOC=P23; |
| NET  | GREEN1         | LOC=P20; |
| NET  | GREEN0         | LOC=P24; |
| NET  | BLUE1          | LOC=P26; |
| NET  | BLUE0          | LOC=P25; |

Listing 6: Connections between the XStend VGA interface and the XS95.

| # VC | A CONNECTIONS |          |
|------|---------------|----------|
| NET  | VSYNC_        | LOC=P24; |
| NET  | HSYNC_        | LOC=P15; |
| NET  | RED1          | LOC=P14; |
| NET  | red0          | LOC=P18; |
| NET  | GREEN1        | LOC=P17; |
| NET  | GREEN0        | LOC=P19; |
| NET  | BLUE1         | LOC=P23; |
| NET  | BLUE0         | LOC=P21; |

### 2.5 PS/2 Keyboard Interface

The XStend Board provides the XS Board with a PS/2-style interface (mini-DIN connector J6) to either a keyboard or a mouse. The XS Board receives two signals from the PS/2 interface: a clock signal and a serial data stream that is synchronized with the falling edges on the clock signal.

Here are the connections from the XS40 and XS95 Boards to the PS/2 interface of the XStend Board (expressed as UCF constraints):

Listing 7: Connections between the XStend PS/2 interface and the XS40.

```
# PS/2 KEYBOARD CONNECTIONS
NET KB_DATA LOC=P69;
NET KB_CLK LOC=P68;
```

Listing 8: Connections between the XStend PS/2 interface and the XS95.

# PS/2 KEYBOARD CONNECTIONS
NET KB\_DATA LOC=P70;
NET KB\_CLK LOC=P26;

### 2.6 RAMs

The XStend Board adds an additional 64 KBytes of RAM to the 32 KBytes already on the XS Board. The XStend RAM connects to the same pins as the XS Board RAM for the address bus, data bus, write-enable, and output-enable. The chip-selects of the XStend Board RAMs are connected to different pins so all the RAMs can be individually selected.

The XStend RAMs are disabled by removing the shunts on the following jumpers:

### **Table 2:** Jumper settings for XStend RAMs.

| Jumper | Setting                                                                                            |
|--------|----------------------------------------------------------------------------------------------------|
| J16    | Removing the shunt on this jumper disables the left<br>RAM U5 by pulling its chip-select pin high. |
| J17    | Removing the shunt on this jumper disables the right RAM U6 by pulling its chip-select pin high.   |

Here are the connections from the XS40 and XS95 Boards to their own RAMs and the RAMs of the XStend Board (expressed as UCF constraints):

Listing 9: Connections between the XStend RAMs and the XS40.

| NET | AD0  | LOC=P41; | # | DATA BUS   |                                  |
|-----|------|----------|---|------------|----------------------------------|
| NET | AD1  | LOC=P40; |   |            |                                  |
| NET | AD2  | LOC=P39; |   |            |                                  |
| NET | AD3  | LOC=P38; |   |            |                                  |
| NET | AD4  | LOC=P35; |   |            |                                  |
| NET | AD5  | LOC=P81; |   |            |                                  |
| NET | AD6  | LOC=P80; |   |            |                                  |
| NET | AD7  | LOC=P10; |   |            |                                  |
| NET | A0   | LOC=P3;  | # | LOWER BYTE | OF ADDRESS                       |
| NET | A1   | LOC=P4;  |   |            |                                  |
| NET | A2   | LOC=P5;  |   |            |                                  |
| NET | A3   | LOC=P78; |   |            |                                  |
| NET | A4   | LOC=P79; |   |            |                                  |
| NET | A5   | LOC=P82; |   |            |                                  |
| NET | Аб   | LOC=P83; |   |            |                                  |
| NET | A7   | LOC=P84; |   |            |                                  |
| NET | A8   | LOC=P59; | # | UPPER BYTE | OF ADDRESS                       |
| NET | A9   | LOC=P57; |   |            |                                  |
| NET | A10  | LOC=P51; |   |            |                                  |
| NET | A11  | LOC=P56; |   |            |                                  |
| NET | A12  | LOC=P50; |   |            |                                  |
| NET | A13  | LOC=P58; |   |            |                                  |
| NET | A14  | LOC=P60; |   |            |                                  |
| NET | A15  | LOC=P28; |   |            |                                  |
| NET | WR_  | LOC=P62; | # | ACTIVE-LOW | WRITE-ENABLE FOR ALL RAMS        |
| NET | OE_  | LOC=P61; | # | ACTIVE-LOW | OUTPUT-ENABLE FOR ALL RAMS       |
| NET | CE_  | LOC=P65; | # | ACTIVE-LOW | CHIP-ENABLE FOR XS40 RAM         |
| NET | LCE_ | LOC=P7;  | # | ACTIVE-LOW | CHIP-ENABLE FOR LEFT XSTEND RAM  |
| NET | RCE_ | LOC=P8;  | # | ACTIVE-LOW | CHIP-ENABLE FOR RIGHT XSTEND RAM |

Listing 10: Connections between the XStend RAMs and the XS95.

| NET | AD0 | LOC=P44; | # | DATA BUS |
|-----|-----|----------|---|----------|
| NET | AD1 | LOC=P43; |   |          |
| NET | AD2 | LOC=P41; |   |          |
| NET | AD3 | LOC=P40; |   |          |
| NET | AD4 | LOC=P39; |   |          |
| NET | AD5 | LOC=P37; |   |          |

| NET | AD6  | LOC=P36; |   |        |      |     |                                |
|-----|------|----------|---|--------|------|-----|--------------------------------|
| NET | AD7  | LOC=P35; |   |        |      |     |                                |
| NET | A0   | LOC=P1;  | # | LOWER  | BYTE | OF  | ADDRESS                        |
| NET | A1   | LOC=P2;  |   |        |      |     |                                |
| NET | A2   | LOC=P3;  |   |        |      |     |                                |
| NET | A3   | LOC=P75; |   |        |      |     |                                |
| NET | A4   | LOC=P79; |   |        |      |     |                                |
| NET | A5   | LOC=P82; |   |        |      |     |                                |
| NET | Аб   | LOC=P83; |   |        |      |     |                                |
| NET | A7   | LOC=P84; |   |        |      |     |                                |
| NET | A8   | LOC=P58; | # | UPPER  | BYTE | OF  | ADDRESS                        |
| NET | A9   | LOC=P56; |   |        |      |     |                                |
| NET | A10  | LOC=P54; |   |        |      |     |                                |
| NET | A11  | LOC=P55; |   |        |      |     |                                |
| NET | A12  | LOC=P53; |   |        |      |     |                                |
| NET | A13  | LOC=P57; |   |        |      |     |                                |
| NET | A14  | LOC=P61; |   |        |      |     |                                |
| NET | A15  | LOC=P34; |   |        |      |     |                                |
| NET | WR_  | LOC=P63; | # | ACTIVE | -LOW | WR1 | ITE-ENABLE FOR ALL RAMS        |
| NET | OE_  | LOC=P62; | # | ACTIVE | -LOW | OUT | FPUT-ENABLE FOR ALL RAMS       |
| NET | CE_  | LOC=P65; | # | ACTIVE | -LOW | CHI | IP-ENABLE FOR XS95 RAM         |
| NET | LCE_ | LOC=P6;  | # | ACTIVE | -LOW | CHI | IP-ENABLE FOR LEFT XSTEND RAM  |
| NET | RCE_ | LOC=P7;  | # | ACTIVE | -LOW | CHI | IP-ENABLE FOR RIGHT XSTEND RAM |
|     |      |          |   |        |      |     |                                |

### 2.7 Stereo Codec

The XStend Board has a stereo codec that accepts two analog input channels from jack J9, digitizes the analog values, and sends the digital values to the XS Board as a serial bit stream. The codec also accepts a serial bit stream from the XS Board and converts it into two analog output signals which exit the XStend Board through jack J10.

The codec is configured by placing shunts on the following jumpers:

| Table 3: Jumper settings for XStend codec | :. |
|-------------------------------------------|----|
|-------------------------------------------|----|

| Jumper |     | Setting                                                                                                                          |  |  |  |  |
|--------|-----|----------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| J11    |     | Placing a shunt on this jumper disables the codec by holding it in the reset state.                                              |  |  |  |  |
| J13,   | J15 | Placing shunts across two of the three pins of these<br>jumpers selects the digital de-emphasis for different<br>sampling rates: |  |  |  |  |
| 0      | 0   | De-emphasis for 32 KHz                                                                                                           |  |  |  |  |
| 0      | 1   | De-emphasis for 44.1 KHz                                                                                                         |  |  |  |  |
| 1      | 0   | De-emphasis for 48 KHz                                                                                                           |  |  |  |  |
| 1      | 1   | De-emphasis off                                                                                                                  |  |  |  |  |



Figure 1: Jumper settings for codec sampling rate de-emphasis

Here are the connections from the XS40 Board to the codec interface on the XStend Board (expressed as UCF constraints):

Listing 11: Connections between the XStend stereo codec and the XS40.

| #  | SI | EREO  | CODEC | CONNECTIONS |
|----|----|-------|-------|-------------|
| NE | т  | SDOUT | [     | LOC=P66;    |
| NE | т  | MCLK  |       | LOC=P9;     |
| NE | т  | LRCK  |       | LOC=P6;     |
| NE | т  | SCLK  |       | LOC=P77;    |
| NE | т  | SDIN  |       | LOC=P70;    |
| NE | т  | CCLK  |       | LOC=P44;    |
| NE | т  | CDIN  |       | LOC=P45;    |
| NE | т  | CS_   |       | LOC=P46;    |

Listing 12: Connections between the XStend codec and the XS95.

| # S1 | FEREO | CODEC | CONNECTIONS |
|------|-------|-------|-------------|
| NET  | SDOUT | ſ     | LOC=P66;    |
| NET  | MCLK  |       | LOC=P11;    |
| NET  | LRCK  |       | LOC=P5;     |
| NET  | SCLK  |       | LOC=P72;    |
| NET  | SDIN  |       | LOC=P71;    |
| NET  | CCLK  |       | LOC=P46;    |
| NET  | CDIN  |       | LOC=P47;    |
| NET  | CS_   |       | LOC=P48;    |

### 2.8 Prototyping Area

The XStend Board has a prototyping area consisting of component through-holes on an  $0.1"\times0.1"$  grid interspersed with a network of +5V and GND buses.

# To prevent damage, remove the XS40 or XS95 Board from the XStend Board when constructing circuitry in the prototyping area.

Connections from the XS Board to the prototyping area are made through connector J3. The arrangement of pins on this connector exactly matches the arrangement of pins on the XS40 Board. For example, the pin at the bottom-left of J3 on the XStend Board corresponds to pin 21 at the bottom-left of the XS40 Board.

The XS95 Board has a completely different pin arrangement than the XS40. Therefore each pin on J3 is explicitly labelled with the corresponding pin number on the XS95 Board. For example, the pin at the bottom-left of J3 on the XStend Board is connected to pin 68 near the top-left of the XS95 Board.

### 2.9 Daughterboard Connector

Daughterboards with specialized circuitry can be connected to the XStend board through connector J18. This  $42 \times 2$  connector brings all the I/O and power/GND from the XS40 or XS95 Board to the daughterboard.

### **3** Example Designs for the XStend Board

Here are several examples of designs built using the XStend Board coupled with an XS40 or XS95 Board.

### 3.1 Using the LEDs and Switches

This example creates a circuit that displays the settings of the DIP switches on the LEDs and LED displays. The particular set of LEDs which is activated is selected by the SPARE and RESET pushbuttons. The ABEL code for this example is shown in **Listing 13**; **Listing 14** and **Listing 15** show the UCF files for using the XS40 and XS95 Boards with the XStend Board, respectively.

The design files for this example should be found in C:\XST-PROJ\EXP1. The steps for compiling and testing the design using an XS40 combined with an XStend Board are as follows:

- Synthesize the ABEL code in the EXP1.ABL for an XC4005XL FPGA.
- Compile the synthesized netlist using the EXP1\_40.UCF constraint file.
- Mount an XS40 Board in the XStend Board and attach the downloading cable from the XS40 to the PC parallel port. Apply 9VDC though jack J9 of the XS40. Place shunts on jumpers J4, J7, and J8 of the XStend Board to enable the LED displays. Place a shunt on jumper J11 to keep the XStend codec disabled.
- Download the EXP1.BIT file into the XS40/XStend combination with the command: XSLOAD EXP1.BIT.

• Set the DIP switches and press the SPARE and RESET pushbuttons. Observe the results on the LEDs.

The steps for compiling and testing the design using an XS95 combined with an XStend Board are as follows:

- Synthesize the ABEL code in the EXP1.ABL for an XC95108 CPLD.
- Compile the synthesized netlist using the EXP1\_95.UCF constraint file.
- Generate an SVF file for the design.
- Mount an XS95 Board in the XStend Board and attach the downloading cable from the XS95 to the PC parallel port. Apply 9VDC though jack J9 of the XS95. Place shunts on jumpers J4, J7, and J8 of the XStend Board to enable the LED displays. Place a shunt on jumper J11 to keep the XStend codec disabled.
- Download the EXP1.SVF file into the XS95/XStend combination with the command: XSLOAD EXP1.SVF.
- Set the DIP switches and press the SPARE and RESET pushbuttons. Observe the results on the LEDs.

Listing 13: ABEL code for testing the XStend LEDs and switches.

```
001- MODULE EXP1
002- TITLE 'EXP1'
003-
004- // This example shows the settings of the DIP switches using each
005- // of the LED displays as selected by the SPARE and RESET pushbuttons
006-
007- DECLARATIONS
008-
009- OE_ PIN;
                                    // output enable for the RAMs
010- RST PIN;
                                    // uC reset
011- DIPSW8..DIPSW1 PIN;
                                    // DIP switch inputs
012- DIPSW = [DIPSW8..DIPSW1];
013- PUSH_SPARE_ PIN;
                                   // SPARE pushbutton input
                                    // RESET pushbutton input
014- PUSH_RESET_ PIN;
015- S6..S0 PIN;
                                    // LED display on XS Board
016 - S = [S6..S0];
                                   // left LED display on XStend Board
017- LS_6..LS_0 PIN;
018 - LS = [LS_6..LS_0];
019- LDP_ PIN;
                                    // decimal point on left LED display
020- RS_6..RS_0 PIN;
                                    // right LED display on Xstend board
021 - RS_ = [RS_6..RS_0];
022- RDP_ PIN;
                                    // decimal point on right LED display
023- D_8..D_1 PIN;
                                    // string of LEDs on XStend Board
024 - D_{=} [D_{8..}D_{1}];
025-
026- EQUATIONS
027-
028- RST = 1; // keep the uC in the reset state
```

```
029- OE_ = 1; // disable the outputs from all the RAMs
030-
031- // the state of the pushbuttons will select which LED display will
032- // show the settings of the DIP switches. A bright LED corresponds
033- // to a DIP switch which is set to '1'.
034-
035- // When both pushbuttons are pressed, the DIP switch settings are
036- // shown on the LED display of the XS Board.
037- WHEN ((PUSH_SPARE_==0) & (PUSH_RESET_==0)) THEN {
038-
            S = [DIPSW7..DIPSW1];
039-
            [LDP_,RS_6..RS_0] = ^B11111111;
040-
            [RDP_,LS_6..LS_0] = ^B11111111;
041-
            D_ = ^B11111111;
042 -
            }
043- // When only the RESET pushbutton is pressed, the DIP switch settings
044- // are shown on the left LED display on the XStend Board.
045- ELSE WHEN ((PUSH SPARE ==1) & (PUSH RESET ==0)) THEN {
046-
           S = ^{B0000000};
047-
           [LDP, LS 6..LS 0] = !(DIPSW);
048-
            [RDP ,RS 6..RS 0] = ^B11111111;
049-
            D_ = ^B11111111;
050-
            }
051- // When only the SPARE pushbutton is pressed, the DIP switch settings
052- // are shown on the right LED display on the XStend Board.
053- ELSE WHEN ((PUSH_SPARE_==0) & (PUSH_RESET_==1)) THEN {
            S = ^B0000000;
054-
            [LDP_,LS_6..LS_0] = ^B11111111;
055-
            [RDP_,RS_6..RS_0] = !(DIPSW);
056-
            D_ = ^B11111111;
057-
            }
058-
059- // When neither pushbuttons is pressed, the DIP switch settings are
060- // shown on the string of LEDs of the XStend Board.
061- ELSE WHEN ((PUSH_SPARE_==1) & (PUSH_RESET_==1)) THEN {
062-
            S = ^B0000000;
063-
            [LDP_,LS_6..LS_0] = ^B11111111;
064-
            [RDP_,RS_6..RS_0] = ^B11111111;
065-
            D_ = !(DIPSW);
066-
            }
067-
068- END EXP1
```

Listing 14: UCF file for LED/switch XStend example with XS40.

```
001- # XS40 BOARD LED CONNECTIONS (ACTIVE HIGH)
002- NET SO
              LOC=P25;
003- NET S1
                 LOC=P26;
004- NET S2
                 LOC=P24;
005- NET S3
                 LOC=P20;
006- NET S4
                 LOC=P23;
007- NET S5
                 LOC=P18;
008- NET S6
                 LOC=P19;
009- #
010- # MICROCONTROLLER PINS
011- NET RST
                LOC=P36; # ACTIVE-HIGH RESET
012- #
013- # XS40 BOARD RAM CONTROL PINS
014- NET OE_
                LOC=P61; # ACTIVE-LOW OUTPUT ENABLE
015- #
016- #
```

```
017- # XSTEND BOARD CONNECTIONS
018- #
019- # DIP SWITCH CONNECTIONS
020- NET DIPSW1 LOC=P7;
021- NET DIPSW2
                LOC=P8;
                LOC=P9;
022- NET DIPSW3
023- NET DIPSW4 LOC=P6;
024- NET DIPSW5
                  LOC=P77;
025- NET DIPSW6
                  LOC=P70;
026- NET DIPSW7
                  LOC=P66;
027- NET DIPSW8
                 LOC=P69;
028- #
029- # PUSHBUTTON SWITCH CONNECTIONS (ACTIVE-LOW)
030- NET PUSH_SPARE_ LOC=P67;
031- NET PUSH_RESET_
                       LOC=P37;
032- #
033- # LEFT LED DIGIT SEGMENT CONNECTIONS (ACTIVE-LOW)
034- NET LS_0 LOC=P3;
035- NET LS 1
                 LOC=P4;
036- NET LS 2
                 LOC=P5;
037- NET LS_3
                 LOC=P78;
038- NET LS 4
                 LOC=P79;
039- NET LS_5
                LOC=P82;
040- NET LS_6
                LOC=P83;
041- NET LDP_
                 LOC=P84;
042- #
043- # RIGHT LED DIGIT SEGMENT CONNECTIONS (ACTIVE-LOW)
044- NET RS_0 LOC=P59;
045- NET RS 1
                  LOC=P57;
046- NET RS_2
                 LOC=P51;
047- NET RS_3
                  LOC=P56;
048- NET RS_4
                  LOC=P50;
049- NET RS_5 LOC=P58;
050- NET RS_6 LOC=P60;
051- NET RDP_
                 LOC=P28;
052- #
053- # INDIVIDUAL LED CONNECTIONS (ACTIVE-LOW)
054- NET D_1 LOC=P41;
               LOC=P40;
LOC=P39;
055- NET D 2
056- NET D 3
057- NET D 4
                LOC=P38;
               LOC=P35;
LOC=P81;
LOC=P80;
LOC=P10;
058- NET D 5
059- NET D 6
060- NET D 7
061- NET D 8
```

Listing 15: UCF file for LED/switch XStend example with XS95.

001- # XS95 BOARD LED CONNECTIONS (ACTIVE HIGH) 002- NET SO LOC=P21; 003- NET S1 LOC=P23; 004- NET S2 LOC=P19; 005- NET S3 LOC=P17; LOC=P18; 006- NET S4 007- NET S5 LOC=P14; 008- NET S6 LOC=P15; 009- # 010- # MICROCONTROLLER PINS 011- NET RST LOC=P45; # ACTIVE-HIGH RESET

```
012- #
 013- # XS95 BOARD RAM CONTROL PINS
 014- NET OE_ LOC=P62; # ACTIVE-LOW OUTPUT ENABLE
 015- #
 016- #
 017- # XSTEND BOARD CONNECTIONS
 018- #
 019- # DIP SWITCH CONNECTIONS
                                      LOC=P6;
 020- NET DIPSW1
 021- NET DIPSW2
                                          LOC=P7;
                                       LOC=P11;
 022- NET DIPSW3
                                       LOC=P5;
 023- NET DIPSW4
                                       LOC=P72;
 024- NET DIPSW5
 025- NET DIPSW6 LOC=P71;
 026- NET DIPSW7
                                      LOC=P66;
 027- NET DIPSW8 LOC=P70;
 028- #
 029- # PUSHBUTTON SWITCH CONNECTIONS (ACTIVE-LOW)
 030- NET PUSH SPARE LOC=P67;
 031- NET PUSH RESET
                                                      LOC=P10;
 032- #
 033- # LEFT LED DIGIT SEGMENT CONNECTIONS (ACTIVE-LOW)
 034- NET LS_0 LOC=P1;
 035- NET LS 1
                                        LOC=P2;
 036- NET LS_2
                                      LOC=P3;

      036-
      NE1
      LO_

      037-
      NET
      LS_3
      LOC=P75;

      038-
      NET
      LS_4
      LOC=P79;

      039-
      NET
      LS_5
      LOC=P82;

      040-
      NET
      LS_6
      LOC=P83;

      041-
      NET
      LDP_
      LOC=P84;

 042- #
 043- # RIGHT LED DIGIT SEGMENT CONNECTIONS (ACTIVE-LOW)
 044- NET RS_0 LOC=P58;

      041-
      NET
      RS_0
      LOC=P58;

      045-
      NET
      RS_1
      LOC=P56;

      046-
      NET
      RS_2
      LOC=P54;

      047-
      NET
      RS_3
      LOC=P55;

      048-
      NET
      RS_4
      LOC=P53;

      049-
      NET
      RS_5
      LOC=P57;

      050-
      NET
      RS_6
      LOC=P61;

      051-
      NET
      RDP_
      LOC=P34;

 052- #
 053- # INDIVIDUAL LED CONNECTIONS (ACTIVE-LOW)
 054- NET D_1 LOC=P44;

      054-
      NET
      D_1
      LOC=P44;

      055-
      NET
      D_2
      LOC=P43;

      056-
      NET
      D_3
      LOC=P41;

      057-
      NET
      D_4
      LOC=P40;

      058-
      NET
      D_5
      LOC=P39;

      059-
      NET
      D_6
      LOC=P37;

      060-
      NET
      D_7
      LOC=P36;

      061-
      NET
      D_8
      LOC=P35;
```

### 3.2 Using the VGA Interface

This example creates a circuit that displays the contents of the XS Board RAM on a monitor through the VGA interface of the XStend Board. The ABEL code for this example is shown in **Listing 16**; **Listing 17** and **Listing 18** show the UCF files for using the XS40 and XS95 Boards with the XStend Board, respectively.

The design files for this example should be found in C:\XST-PROJ\EXP2. The steps for compiling and testing the design using an XS40 combined with an XStend Board are as follows:

- Synthesize the ABEL code in the VGACORE.ABL for an XC4005XL FPGA.
- Compile the synthesized netlist using the EXP2\_40.UCF constraint file.
- Mount an XS40 Board in the XStend Board and attach the downloading cable from the XS40 to the PC parallel port. Apply 9VDC though jack J9 of the XS40. Place a shunt on jumper J11 to keep the XStend codec disabled. Attach a video monitor to the VGA connector of the XStend Board.
- Download the EXP2.BIT file into the XS40/XStend combination and initialize the RAM with a pattern to display on the monitor with the command: XSLOAD TESTPATT.HEX EXP2.BIT.
- Observe the results on the video monitor.

The steps for compiling and testing the design using an XS95 combined with an XStend Board are as follows:

- Synthesize the ABEL code in the EXP2.ABL for an XC95108 CPLD.
- Compile the synthesized netlist using the EXP2\_95.UCF constraint file.
- Generate an SVF file for the design.
- Mount an XS95 Board in the XStend Board and attach the downloading cable from the XS95 to the PC parallel port. Apply 9VDC though jack J9 of the XS95. Place a shunt on jumper J11 to keep the XStend codec disabled. Attach a video monitor to the VGA connector of the XStend Board.
- Download the EXP2.SVF file into the XS95/XStend combination and initialize the RAM with a pattern to display on the monitor with the command: XSLOAD TESTPATT.HEX EXP2.SVF.
- Observe the results on the video monitor.

Listing 16: ABEL code for testing the XStend VGA.

```
001- MODULE VGACORE

002- TITLE 'VGA signal generator'

003-

004- " This implementation does a 256x240 screen with 4-bit pixels

005-

006- DECLARATIONS

007- "----- external signals -----

008- rst PIN; "uC reset control

009- push_reset_ PIN; "reset
```

```
010- clk
                       PIN;
                                          "VGA dot clk
                       PIN ISTYPE 'REG'; "horizontal sync
011- hsync_
012- vsync_
                       PIN ISTYPE 'REG'; "vertical (frame) sync
013- red1..red0
                       PIN ISTYPE 'REG'; "red component
014- green1..green0 PIN ISTYPE 'REG'; "green component
                                          "blue component
015- blue1..blue0 PIN ISTYPE 'REG';
016- a14..a0
                       PIN;
                                          "address into video RAM
017- ad7..ad0
                       PIN;
                                          "data from video RAM
018- ce_
                       PIN;
                                          "video RAM chip select
019- oe_
                       PIN;
                                          "video RAM output enable
020- wr_
                       PIN;
                                          "video RAM write enable
021- "----- internal storage and signals ------
022- hcnt8..hcnt0 NODE ISTYPE 'REG'; "horizontal column counter
023- vcnt9..vcnt0
                       NODE ISTYPE 'REG'; "vertical line counter
024- pixrg7..pixrg0
                      NODE ISTYPE 'REG'; "byte register for four pixels
                     NODE ISTYPE 'COM'; "video blanking signal
025- video_blank
                       NODE ISTYPE 'REG'; "delayed video blanking signal
026- delayed blank
027- "----- synonyms for various items ------
028- hcnt = [hcnt8..hcnt0];
029- vcnt = [vcnt9..vcnt0];
030- vram_addr = [a14..a0];
031- vram data = [ad7..ad0];
032- pixrg = [pixrg7..pixrg0];
033- pixel = [pixrg3..pixrg0];
034- rgb = [red1..red0,green1..green0,blue1..blue0];
035 - X = .X.i
036-
037- EQUATIONS
038-
039- @CARRY 1;
040-
041 - rst = 1;
                  " keep uC in reset state so it doesn't interfere
042-
043- hcnt.ACLR = !push_reset_; "clear counter on active-low reset
044- vcnt.ACLR = !push_reset_; "clear counter on active-low reset
045- hcnt.CLK = clk;
                             "horiz cnt increments on each dot clk
046- vcnt.CLK = hsync_;
                             "inc vert line cnt after every horizontal line
047-
048- hsync_.ASET = !push_reset_;
049- vsync_.ASET = !push_reset_;
050- hsync_.CLK = clk;
051- vsync .CLK = hsync ;
052-
053- "column counter rolls-over after 379
054- WHEN (hcnt<380) THEN hcnt:=hcnt+1 ELSE hcnt:=0;
055- "horiz sync is low during this interval to signal the start of new line
056- WHEN ((hcnt>=291)&(hcnt<337)) THEN hsync_:=0 ELSE hsync_:=1;
057- "horizontal counter rolls-over after 524
058- WHEN (vcnt<524) THEN vcnt:=vcnt+1 ELSE vcnt:=0;
059- "vert sync is low during this interval to signal the start of a frame
060- WHEN ((vcnt>=492)&(vcnt<494)) THEN vsync_:=0 ELSE vsync_:=1;
061- "blank video outside of visible region: (0,0)->(255,479)
062- WHEN ((hcnt>=256)#(vcnt>=480)) THEN video_blank=1 ELSE video_blank=0;
063 -
064- "video RAM control signals
065 - ce_{-} = 0;
                        "enable the RAM
066- oe_ = video_blank; "enable the RAM output when video is not blanked
067 - wr_{=} 1;
                       "disable writing to the RAM
068- "the video RAM address is built from the bits 8-1 of the vert line cnt
069- "and bits 7-1 of the horiz column cnt. Each RAM byte contains two
```

```
070- "4-bit pixels so make a new RAM address every two dot clks and ignore
071- "hcnt0 when addressing the RAM. Also repeat each line of pixels twice
072- "(so the pixels are approximately square on the screen), so ignore vcnt0
073- "when addressing the RAM.
074- vram_addr = [vcnt8..vcnt1,hcnt7..hcnt1];
075-
076- pixrg.ACLR = !push_reset_;
                                 "clear pixel register on reset
077- pixrg.CLK = clk;
                             "pixel clk controls changes in pixel register
078- "the pixel reg is loaded with from the RAM when the lower bit of the
079- "horizontal counter is zero. The active pixel is in the lower four
080- "bits of the pixel reg. On the next clk, the pixel reg is left-shifted
081- "by four bits to bring the other pixel into the active position.
082 - WHEN (hcnt0==0)
083- THEN pixrg := vram_data
                                             "load 2 pixels from RAM
084- ELSE pixrg := [0,0,0,0,pixrg7..pixrg4]; "left-shift pixel reg four bits
085-
086- "delay the video blanking by one clk to account for RAM access delay
087- delayed_blank.ACLR = !push_reset_;
088- delayed blank.CLK = clk;
089- delayed blank := video blank;
090-
091- "color mapper that translates each 4-bit pixel into a 6-bit RGB value.
092- "when the video signal is blanked, the RGB value is forced to 0.
093- rgb.ACLR = !push_reset_;
094- rgb.CLK = clk;
095- TRUTH_TABLE ([delayed_blank, pixel] :>
                                             rgb)
                            ,^b0000 ] :> ^b000000; "black
096-
                       0
                 [
                            ,^b0001 ] :> ^b101010; "light-gray
097-
                        0
                 [
                            ,^b0010 ] :> ^b111111; "white
098-
                 [
                        0
                            ,^b0011 ] :> ^b110000; "red
099-
                 [
                       0
                            ,^b0100 ] :> ^b001100; "green
100-
                 [
                       0
                       0
                            ,^b0101 ] :> ^b000011; "blue
101-
                 [
                      0
                 [
                            ,^b0110 ] :> ^b111100; "yellow
102-
                      0
                 [
                            ,^b0111 ] :> ^b110011; "magenta
103-
                      0
                 [
                            ,^b1000 ] :> ^b001111; "cyan
104-
                      0
                 [
                            ,^b1001 ] :> ^b100000; "dark-red
105-
                      0
                            ,^b1010 ] :> ^b001000; "dark-green
106-
                 [
107-
                      0
                             ,^b1011 ] :> ^b000010; "dark-blue
                 [
                             ,^b1100 ] :> ^b101000; "tan
                      0
108-
                [
                             ,^b1101 ] :> ^b100010; "purple
109-
                      0
                 [
                             ,^b1110 ] :> ^b001010; "teal
110-
                 [
                      0
                             ,^b1111 ] :> ^b010101; "dark-gray
111-
                 [
                      0
                             ,X
112-
                      1
                                   ] :> ^b000000; "black during blanking
                 [
113 -
114- END VGACORE
```

### Listing 17: UCF file for VGA XStend example with XS40.

| 001- | # CLC | OCK FROM  | XS40 03 | SCILI | LATOR                               |
|------|-------|-----------|---------|-------|-------------------------------------|
| 002- | NET C | LK        | LOC=P13 | 3;    |                                     |
| -200 | #     |           |         |       |                                     |
| 004- | # MIC | CROCONTRO | LLER PI | INS   |                                     |
| 005- | NET R | RST       | LOC=P36 | 5; #  | ACTIVE-HIGH RESET                   |
| 006- | NET W | IR_       | LOC=P62 | 2; #  | ACTIVE-LOW WRITE (ALSO CONTROLS RAM |
| 007- | NET A | AD0       | LOC=P41 | ; #   | MULTIPLEXED ADDRESS/DATA BUS        |
| -800 | NET A | AD1       | LOC=P40 | );    |                                     |
| 009- | NET A | AD2       | LOC=P39 | );    |                                     |
| 010- | NET A | AD3       | LOC=P38 | 3;    |                                     |
| 011- | NET A | AD4       | LOC=P35 | 5;    |                                     |

```
LOC=P81;
012- NET AD5
013- NET AD6
                LOC=P80;

LOC=P10;

LOC=P3; # DEMUXED LOWER BYTE OF ADDRESS

LOC=P4;

LOC=P5;

LOC=P78;

LOC=P79;

LOC=P82;

LOC=P83;

LOC=P84;

LOC=P59; # UPPER BYTE OF ADDRESS

LOC=P57;

LOC=P56;
                  LOC=P80;
014- NET AD7
015- NET A0
016- NET A1
017- NET A2
018- NET A3
019- NET A4
020- NET A5
021- NET A6
022- NET A7
023- NET A8
024- NET A9
025- NET A10
                  LOC=P56;
026- NET All
027- NET A12
                  LOC=P50;
028- NET A13
                  LOC=P58;
029- NET A14
                  LOC=P60;
030- #
031- # XS40 BOARD RAM CONTROL PINS
032- NET OE_ LOC=P61; # ACTIVE-LOW OUTPUT ENABLE
033- NET CE_
                  LOC=P65; # ACTIVE-LOW CHIP ENABLE
034- #
035- #
036- # XSTEND BOARD CONNECTIONS
037- #
038- # VGA CONNECTIONS
039- NET VSYNC_ LOC=P67;
040- NET HSYNC_
                    LOC=P19;
041- NET RED1
                    LOC=P18;
042- NET RED0
                    LOC=P23;
043- NET GREEN1 LOC=P20;
044- NET GREEN0 LOC=P24;
045- NET BLUE1 LOC=P26;
046- NET BLUE0
                   LOC=P25;
047- #
048- # PUSHBUTTON SWITCH CONNECTIONS (ACTIVE-LOW)
049- NET PUSH_RESET_ LOC=P37;
```

Listing 18: UCF file for VGA XStend example with XS95.

```
001- # CLOCK FROM XS95 OSCILLATOR
002- NET CLK LOC=P9;
003- #
004- # MICROCONTROLLER PINS
005- NET RST LOC=P45; # ACTIVE-HIGH RESET
006- NET WR_
               LOC=P63; # ACTIVE-LOW WRITE (ALSO CONTROLS RAM)
               LOC=P44; # MULTIPLEXED ADDRESS/DATA BUS
007- NET AD0
008- NET AD1
                LOC=P43;
009- NET AD2
                LOC=P41;
010- NET AD3
                LOC=P40;
011- NET AD4
                LOC=P39;
012- NET AD5
                 LOC=P37;
013- NET AD6
                LOC=P36;
014- NET AD7
                LOC=P35;
015- NET A0
                LOC=P1; # DEMUXED LOWER BYTE OF ADDRESS
                LOC=P2;
016- NET A1
017- NET A2
                LOC=P3;
018- NET A3
                LOC=P75;
```

```
019- NET A4
                LOC=P79;
LOC=P82;
020- NET A5
                LOC=P82;
LOC=P83;
LOC=P84;
LOC=P58; # UPPER BYTE OF ADDRESS
LOC=P56;
LOC=P54;
LOC=P55;
LOC=P53;
LOC=P57;
LOC=P61;
021- NET A6
022- NET A7
023- NET A8
024- NET A9
025- NET A10
026- NET A11
027- NET A12
028- NET A13
029- NET A14
030- #
031- # XS95 BOARD RAM CONTROL PINS
032- NET OE_ LOC=P62; # ACTIVE-LOW OUTPUT ENABLE
033- NET CE
                  LOC=P65; # ACTIVE-LOW CHIP ENABLE
034- #
035- #
036- # XSTEND BOARD CONNECTIONS
037- #
038- # VGA CONNECTIONS
039- NET VSYNC_ LOC=P24;
040- NET HSYNC_
                  LOC=P15;
041- NET RED1
042- NET RED0
                  LOC=P14;
                  LOC=P18;
043- NET GREEN1 LOC=P17;
044- NET GREEN0 LOC=P19;
045- NET BLUE1
                    LOC=P23;
046- NET BLUE0
                   LOC=P21;
047- #
048- # PUSHBUTTON SWITCH CONNECTIONS (ACTIVE-LOW)
049- NET PUSH_RESET_ LOC=P10;
```

### 3.3 Using the PS/2 Keyboard Interface

This example creates a circuit that accepts scan codes from a keyboard attached to the PS/2 interface of the XStend Board and displays it on the LEDs. In addition, if a scan code for one of the keys '0'—'9' arrives, then the numeral will be displayed on the right LED display of the XStend Board. The ABEL code for this example is shown in **Listing 19**; **Listing 20** and **Listing 21** show the UCF files for using the XS40 and XS95 Boards with the XStend Board, respectively.

The design files for this example should be found in C:\XST-PROJ\EXP3. The steps for compiling and testing the design using an XS40 combined with an XStend Board are as follows:

- Synthesize the ABEL code in the EXP3.ABL for an XC4005XL FPGA.
- Compile the synthesized netlist using the EXP3\_40.UCF constraint file.
- Mount an XS40 Board in the XStend Board and attach the downloading cable from the XS40 to the PC parallel port. Apply 9VDC though jack J9 of the XS40. Place shunts on jumpers J4, J7, and J8 to enable the LEDs. Place a shunt on jumper J11 to keep the XStend codec disabled. Attach a keyboard to the PS/2 connector of the XStend Board.

- Download the EXP3.BIT file into the XS40/XStend combination with the command: XSLOAD EXP3.BIT.
- Press keys on the keyboard and observe the results on the LED displays.

The steps for compiling and testing the design using an XS95 combined with an XStend Board are as follows:

- Synthesize the ABEL code in the EXP3.ABL for an XC95108 CPLD.
- Compile the synthesized netlist using the EXP3\_95.UCF constraint file.
- Generate an SVF file for the design.
- Mount an XS95 Board in the XStend Board and attach the downloading cable from the XS95 to the PC parallel port. Apply 9VDC though jack J9 of the XS95. Place shunts on jumpers J4, J7, and J8 to enable the LEDs. Place a shunt on jumper J11 to keep the XStend codec disabled. Attach a keyboard to the PS/2 connector of the XStend Board.
- Download the EXP3.SVF file into the XS95/XStend combination with the command: XSLOAD EXP3.SVF.
- Press keys on the keyboard and observe the results on the LED displays.

**Listing 19:** ABEL code for testing the XStend PS/2 example.

```
001- MODULE EXP3
002- TITLE 'EXP3'
003-
004- DECLARATIONS
005-
006- RST PIN;
                                   // uC reset control
007- OE_ PIN;
                                   // RAM output enable
008- KB_DATA PIN;
                                   // serial data from PS/2 keyboard
009- KB_CLK PIN;
                                   // clock from PS/2 keyboard
010- D_8..D_1 PIN;
                                   // LED string on XStend Board
011 - D_{=} [D_{8..D_{1}}];
012- RS_6..RS_0 PIN ISTYPE 'COM'; // right LED display on XStend Board
013 - RS_{=} [RS_{6..RS_{0}}];
014- [MASTER9..MASTER0] NODE ISTYPE 'REG';
                                               // master register for
                                               // storing keyboard data
015- MASTER = [MASTER9..MASTER0];
016- [SLAVE9..SLAVE0] NODE ISTYPE 'REG';
                                               // slave register for
017- SLAVE = [SLAVE9..SLAVE0];
                                               // storing keyboard data
018-
019- EQUATIONS
020-
021- RST = 1; // disable uC
022- OE = 1; // disable RAM outputs
023 -
024- // Scan codes from the keyboard arrive LSB-first on the falling
025- // edge of the clock. Each bit is shifted into the MSB of the
026- // master register. The lower bits of the master are filled with
027- // slave contents shifted right by one bit. Then the updated
```

028- // contents of the master are loaded into the slave on the rising 029- // edge of the clock. 030- MASTER.CLK = !KB\_CLK; 031- MASTER := [KB\_DATA, SLAVE9..SLAVE1]; 032- SLAVE.CLK = KB\_CLK; 033- SLAVE := MASTER; 034 -035- // Show the bit string for the scan code. Ignore the upper two 036- // bits because these are the parity bit and the stop bit. 037- D\_ = ![SLAVE7..SLAVE0]; 0.38 -039- // If one of the '0'-'9' keys is pressed, display the digit on the 040- // right LED display of the XStend Board. 041- TRUTH\_TABLE ([SLAVE7..SLAVE0] -> [RS\_6..RS\_0]) 042 -^H16 -> ^B1101101; 043-^H1E -> ^B0100010; 044-^H26 ^B0100100; -> 045-^H25 -> ^B1000101; 046-^H2E -> ^B0010100; 047-^НЗб -> ^B0010000; 048-^H3D -> ^B0101101; 049-^H3E ^B0000000; -> 050-^H46 -> ^B0000100; 051-^H45 -> ^B0001000; 052-053- END EXP3

Listing 20: UCF file for PS/2 XStend example with XS40.

```
001- # MICROCONTROLLER PINS
002- NET RST LOC=P36; # ACTIVE-HIGH RESET
003- #
004- # XS40 BOARD RAM CONTROL PINS
005- NET OE
             LOC=P61; # ACTIVE-LOW OUTPUT ENABLE
006- #
007- #
008- # XSTEND BOARD CONNECTIONS
009- #
010- # PS/2 KEYBOARD CONNECTIONS
011- NET KB_DATA LOC=P69;
012- NET KB CLK LOC=P68;
013- #
014- # RIGHT LED DIGIT SEGMENT CONNECTIONS (ACTIVE-LOW)
015- NET RS 0
                LOC=P59;
016- NET RS_1
                 LOC=P57;
017- NET RS 2
                LOC=P51;
018- NET RS_3
                LOC=P56;
019- NET RS_4
                LOC=P50;
020- NET RS_5
                LOC=P58;
021- NET RS_6
                LOC=P60;
022- #
023- # INDIVIDUAL LED CONNECTIONS (ACTIVE-LOW)
024- NET D 1
             LOC=P41;
025- NET D_2
                 LOC=P40;
026- NET D_3
                 LOC=P39;
027- NET D_4
                 LOC=P38;
                LOC=P35;
028- NET D_5
029- NET D_6
                LOC=P81;
```

030- NET D\_7 LOC=P80; 031- NET D\_8 LOC=P10;

Listing 21: UCF file for PS/2 XStend example with XS95.

```
001- # MICROCONTROLLER PINS
 002- NET RST
                                     LOC=P45; # ACTIVE-HIGH RESET
 003- #
 004- # XS95 BOARD RAM CONTROL PINS
 005- NET OE_ LOC=P62; # ACTIVE-LOW OUTPUT ENABLE
 006- #
 007- #
 008- # XSTEND BOARD CONNECTIONS
 009- #
 010- # PS/2 KEYBOARD CONNECTIONS
 011- NET KB_DATA LOC=P70;
 012- NET KB_CLK LOC=P26;
 013- #
 014- # RIGHT LED DIGIT SEGMENT CONNECTIONS (ACTIVE-LOW)
 015- NET RS_0 LOC=P58;

      016-
      NET
      RS_0
      LOC=P56;

      017-
      NET
      RS_1
      LOC=P56;

      018-
      NET
      RS_2
      LOC=P54;

      019-
      NET
      RS_3
      LOC=P55;

      019-
      NET
      RS_4
      LOC=P53;

      020-
      NET
      RS_5
      LOC=P57;

      021-
      NET
      RS_6
      LOC=P61;

 022- #
 023- # INDIVIDUAL LED CONNECTIONS (ACTIVE-LOW)

      023- # INDIVIDUAL
      LED CONNI

      024- NET D_1
      LOC=P44;

      025- NET D_2
      LOC=P43;

      026- NET D_3
      LOC=P41;

      027- NET D_4
      LOC=P40;

      028- NET D_5
      LOC=P39;

      029- NET D_6
      LOC=P37;

      030- NET D_7
      LOC=P36;

      031- NET D_8
      LOC=P35;
```

- 3.4 Using the RAMs
- 3.5 Using the Stereo Codec

### 4 Connections between XStend/XS Board resources

**Table 4** and **Table 5** show the connections between the XS40 Board and XS95 Board and the resources on the XStend Board, respectively. Both tables contain the same information but are sorted according to the ordering of the XS40 or XS95 Board pins.

| XS 40 Bus<br>(J1,J3,J18)                                                   | XS95 Pins (J2)                                                                        | Power / GND | DIP Switch                           | Push-but tons | LEDS                                              | VGA<br>Interface                                    | PS/2 Interface  | RAMS                                        | Stereo Codec        | 8051Uc                                          | PC Parallel<br>Port                                | Oscillator | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | UW-FPGA<br>BOARD Pin                                 |
|----------------------------------------------------------------------------|---------------------------------------------------------------------------------------|-------------|--------------------------------------|---------------|---------------------------------------------------|-----------------------------------------------------|-----------------|---------------------------------------------|---------------------|-------------------------------------------------|----------------------------------------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|
| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12                | 77<br>78 +<br>1<br>2<br>3<br>5<br>6<br>7<br>11<br>35<br>31<br>69                      | 5V          | DIPSW4<br>DIPSW1<br>DIPSW2<br>DIPSW3 |               | LS_0<br>LS_1<br>LS_2<br>D_8                       |                                                     |                 | A0<br>A1<br>A2<br>LCE_<br>RCE_<br>AD7       | LRCK                | P13<br>P10<br>P11<br>P12<br>P07                 |                                                    |            | Uncommitted XS95 I/O pin<br>+5V power source<br>LED segment; address line<br>LED segment; address line<br>DIP switch; codec control; uC I/O<br>DIP switch; RAM chip-enable, uC I/O port<br>DIP switch; codec clock; uC I/O port<br>DIP switch; codec clock; uC I/O port<br>LED; RAM data line; uC muxed address/data line<br>Uncommitted XS95 I/O pin<br>Uncommitted XS95 I/O pin                                                                                                                                                             | P35<br>P36<br>P29<br>P24<br>P19<br>P20<br>P23<br>P61 |
| 13<br>14<br>15<br>16<br>17<br>18<br>19<br>20<br>21<br>22<br>23<br>24<br>25 | 9<br>13<br>28<br>30<br>29<br>14<br>15<br>17<br>68<br>33<br>18<br>33<br>18<br>19<br>21 |             |                                      |               | S5<br>S6<br>S3<br>S4<br>S2<br>S0                  | RED1<br>HSYNC_<br>GREEN1<br>RED0<br>GREEN0<br>BLUE0 | -<br> <br>)     |                                             |                     | PSEN_                                           |                                                    | CLK        | XS40/95 oscillator output<br>uC program storage-enable<br>JTAG TDI; DIN<br>JTAG TCK; CCLK<br>JTAG TMS<br>XS Board LED segment; VGA color signal<br>XS Board LED segment; VGA color signal<br>Uncommitted XS95 I/O pin<br>Uncommitted XS95 I/O pin<br>XS Board LED segment; VGA color signal<br>XS Board LED segment; VGA color signal<br>XS Board LED segment; VGA color signal<br>XS Board LED segment; VGA color signal                                                                                                                     |                                                      |
| 26<br>27<br>28<br>29<br>30<br>31<br>32                                     | 23<br>32<br>34<br>20<br>12<br>81<br>25                                                |             |                                      |               | S1<br>RDP_                                        | BLUE1                                               |                 | A15                                         |                     | RD_<br>P27<br>ALE_                              | PC_D6                                              |            | XS Board LED segment; VGA color signal<br>uC read line<br>LED decimal-point; address line; uC I/O port<br>uC address-latch-enable<br>Serial EEPROM chip-enable<br>Uncommitted XS95 I/O pin<br>PC parallel port output                                                                                                                                                                                                                                                                                                                         | P41                                                  |
| 33<br>34<br>35<br>36<br>37<br>38<br>39<br>40<br>41<br>42                   | 25<br>80<br>39<br>45<br>10<br>40<br>41<br>43<br>44<br>44                              |             |                                      | RESET         | D_5<br>-<br>D_4<br>D_3<br>D_2<br>D_1              |                                                     |                 | AD4<br>AD3<br>AD2<br>AD1<br>AD0             |                     | P04<br>RST<br>XTAL1<br>P03<br>P02<br>P01<br>P00 | PC_D7                                              |            | Uncommitted XS95 I/O pin<br>PC parallel port output<br>LED; RAM data line; uC muxed address/data line<br>uC reset line<br>Pushbutton; uC clock line<br>LED; RAM data line; uC muxed address/data line<br>Uncommitted XS95 I/O pin                                                                                                     | P66<br>P56<br>P57<br>P58<br>P59<br>P60               |
| 43<br>44<br>45<br>46<br>47<br>48<br>49<br>50<br>51                         | 46<br>47<br>48<br>50<br>51<br>52<br>53<br>54                                          |             |                                      |               | RS_4<br>RS_2                                      |                                                     |                 | A12<br>A10                                  | CCLK<br>CDIN<br>CS_ | P24<br>P22                                      | PC_D0<br>PC_D1<br>PC_D2<br>PC_D3<br>PC_D4<br>PC_D5 |            | Unconnected<br>Codec control line; PC parallel port output<br>Codec control line; PC parallel port output<br>PC parallel port output<br>PC parallel port output<br>PC parallel port output<br>LED segment; address line; uC I/O port<br>LED segment; address line; uC I/O port                                                                                                                                                                                                                                                                | P48<br>P45                                           |
| 52<br>53<br>54<br>55<br>56<br>57<br>58<br>59<br>60<br>61<br>62             | 49 G<br>+<br>55<br>56<br>57<br>58<br>61<br>62<br>63                                   | 3.3V        |                                      | PROGF         | RAM<br>RS_3<br>RS_1<br>RS_5<br>RS_0<br>RS_6       |                                                     |                 | A11<br>A9<br>A13<br>A8<br>A14<br>OE_<br>WR_ |                     | P23<br>P21<br>P25<br>P20<br>P26<br>P36          |                                                    |            | Power supply ground<br>Unconnected<br>+3.3V/+5V power supply (4000E/4000XL)<br>XS40 configuration control<br>LED segment; address line; uC I/O port<br>LED segment; address line; uC I/O port | P55<br>P51<br>P47<br>P50<br>P46<br>P49               |
| 63<br>64<br>65<br>66<br>67<br>68<br>69<br>70<br>71<br>72                   | 65<br>66<br>24,67<br>26<br>70<br>71<br>28<br>59                                       |             | DIPSW7<br>DIPSW8<br>DIPSW6           | SPARE         | _                                                 | VSYNC_                                              | KB_CLI<br>KB_DA | CE_<br>K<br>TA                              | SDOUT<br>SDIN       | P16<br>P17<br>P34<br>P31<br>P15                 |                                                    |            | Unconnected<br>Vinconnected<br>XS Board RAM chip-enable<br>DIP switch; codec output data; uC I/O port<br>Pushbutton; VGA horiz, sync.; uC I/O port<br>PS/2 keyboard clock; uC I/O port<br>DIP switch; keyboard serial data; uC I/O port<br>DIP switch; codec input data; uC I/O port<br>JTAG TDI; DIN<br>JTAG TDC; DOUT                                                                                                                                                                                                                       | P27<br>P18<br>P28<br>P26                             |
| 73<br>74<br>75<br>76<br>77<br>80<br>81<br>82<br>83<br>84                   | 30<br>74<br>59<br>76<br>72<br>75<br>79<br>36<br>37<br>82<br>83<br>84                  |             | DIPSW5                               | i             | LS_3<br>LS_4<br>D_7<br>D_6<br>LS_5<br>LS_6<br>LDP |                                                     |                 | A3<br>A4<br>AD6<br>AD5<br>A5<br>A6<br>A7    | SCLK                | P14<br>P06<br>P05                               |                                                    |            | JTAG TCK; CCLK<br>Uncommitted XS95 I/O pin<br>JTAG TDO; DOUT<br>Uncommitted XS95 I/O pin<br>DIP switch; codec serial clock; uC I/O port<br>LED segment; address line<br>LED segment; address line<br>LED; RAM data line; uC muxed address/data line<br>LED; RAM data line; uC muxed address/data line<br>LED segment; address line<br>LED segment; address line<br>LED segment; address line                                                                                                                                                  | P25<br>P44<br>P38<br>P62<br>P65<br>P40<br>P39<br>P37 |

 Table 4: Connections between the XS40 Board and XStend Board resources.

| (S95 Pins<br>J2) | (S40 Bus<br>J1,J3,J18)<br>Power/ GND | <b>DIP Switch</b> | ush-buttons | EDs          | /GA Interface | S/2 Interface | RAMS         | Stereo Codec | 3051 Uc    | PC Parallel    | Oscillator | Function                                                                                         | JW-FPGA<br>30ARD Pin |
|------------------|--------------------------------------|-------------------|-------------|--------------|---------------|---------------|--------------|--------------|------------|----------------|------------|--------------------------------------------------------------------------------------------------|----------------------|
| 1<br>2           | 3<br>4                               |                   |             | LS_0<br>LS_1 |               |               | A0<br>A1     | ,            |            |                | 0          | LED segment; address line                                                                        | P35<br>P36           |
| 3                | 5                                    |                   |             | LS_2         |               |               | A2           |              |            |                |            | LED segment; address line                                                                        | P29                  |
| 5                | 6                                    | DIPSW4            |             |              |               |               |              | LRCK         | P13        |                |            | DIP switch; codec control; uC I/O                                                                | P24                  |
| 6<br>7           | 7<br>8                               | DIPSW1<br>DIPSW2  |             |              |               |               | LCE_<br>RCE_ |              | P10<br>P11 |                |            | DIP switch; RAM chip-enable, uC I/O port<br>DIP switch; RAM chip-enable, uC I/O port             | P19<br>P20           |
| 9<br>10          | 13<br>37                             | F                 | RESET       |              |               |               |              |              | XTAL1      |                | CLK        | XS40/95 oscillator output<br>Pushbutton: uC clock line                                           | P56                  |
| 11               | 9                                    | DIPSW3            |             | -            |               |               |              | MCLK         | P12        |                |            | DIP switch; codec clock; uC I/O port                                                             | P23                  |
| 12               | 14                                   |                   |             |              |               |               |              |              | PSEN_      |                |            | uC program storage-enable                                                                        |                      |
| 14<br>15         | 18<br>19                             |                   |             | S5<br>S6     | RED1<br>HSYNC |               |              |              |            |                |            | XS Board LED segment; VGA color signal<br>XS Board LED segment; VGA horiz. sync.                 |                      |
| 17<br>18         | 20<br>23                             |                   |             | S3<br>S4     | GREEN1        |               |              |              |            |                |            | XS Board LED segment; VGA color signal                                                           |                      |
| 19               | 24                                   |                   |             | S2           | GREEN0        |               |              |              |            |                |            | XS Board LED segment; VGA color signal                                                           |                      |
| 20<br>21         | 29<br>25                             |                   |             | S0           | BLUE0         |               |              |              | ALE_       |                |            | UC address-latch-enable<br>XS Board LED segment; VGA color signal                                |                      |
| 23<br>25         | 26<br>33                             |                   |             | S1           | BLUE1         |               |              |              |            |                |            | XS Board LED segment; VGA color signal<br>Uncommitted XS95 I/O pin                               |                      |
| 26<br>28         | 68<br>15                             |                   |             |              | I             | KB_CL         | К            |              | P34        |                |            | PS/2 keyboard clock; uC I/O port                                                                 |                      |
| 28               | 71                                   |                   |             |              |               |               |              |              |            |                |            | JTAG TDI; DIN                                                                                    |                      |
| 29<br>30         | 17<br>16                             |                   |             |              |               |               |              |              |            |                |            | JTAG TMS<br>JTAG TCK; CCLK                                                                       |                      |
| 30<br>31         | 73<br>11                             |                   |             |              |               |               |              |              |            |                |            | JTAG TCK; CCLK                                                                                   |                      |
| 32               | 27                                   |                   |             |              |               |               |              |              | RD_        |                |            | uC read line                                                                                     |                      |
| 33<br>34         | 28                                   |                   |             | RDP_         |               |               | A15          |              | P27        |                |            | LED decimal-point; address line; uC I/O port                                                     | P41                  |
| 35<br>36         | 10<br>80                             |                   |             | D_8<br>D 7   |               |               | AD7<br>AD6   |              | P07<br>P06 |                |            | LED; RAM data line; uC muxed address/data line<br>LED; RAM data line; uC muxed address/data line | P61<br>P62           |
| 37<br>30         | 81<br>35                             |                   |             | D_6          |               |               | AD5          |              | P05        |                |            | LED; RAM data line; uC muxed address/data line                                                   | P65                  |
| 40               | 38                                   |                   |             | D_3<br>D_4   |               |               | AD3          |              | P03        |                |            | LED; RAM data line; uC muxed address/data line                                                   | P57                  |
| 41<br>43         | 39<br>40                             |                   |             | D_3<br>D_2   |               |               | AD2<br>AD1   |              | P02<br>P01 |                |            | LED; RAM data line; uC muxed address/data line<br>LED; RAM data line; uC muxed address/data line | P58<br>P59           |
| 44<br>45         | 41<br>36                             |                   |             | D_1          |               |               | AD0          |              | P00<br>RST |                |            | LED; RAM data line; uC muxed address/data line<br>uC reset line                                  | P60                  |
| 46               | 44                                   |                   |             |              |               |               |              | CCLK         |            | PC_D0          |            | Codec control line; PC parallel port output                                                      |                      |
| 47               | 45                                   |                   |             |              |               |               |              | CDIN<br>CS_  |            | PC_D1<br>PC_D2 |            | Codec control line; PC parallel port output                                                      |                      |
| 49<br>50         | 52 GND<br>47                         |                   |             |              |               |               |              |              |            | PC D3          |            | Power supply ground<br>PC parallel port output                                                   |                      |
| 51<br>52         | 48<br>49                             |                   |             |              |               |               |              |              |            | PC_D4          |            | PC parallel port output                                                                          |                      |
| 53               | 50                                   |                   |             | RS_4         |               |               | A12          |              | P24        | 10_00          |            | LED segment; address line; uC I/O port                                                           | P48                  |
| 54<br>55         | 51<br>56                             |                   |             | RS_2<br>RS_3 |               |               | A10<br>A11   |              | P22<br>P23 |                |            | LED segment; address line; uC I/O port<br>LED segment; address line; uC I/O port                 | P45<br>P51           |
| 56<br>57         | 57<br>58                             |                   |             | RS_1<br>RS_5 |               |               | A9<br>A13    |              | P21<br>P25 |                |            | LED segment; address line; uC I/O port                                                           | P47<br>P50           |
| 58               | 59<br>72                             |                   |             | RS_0         |               |               | A8           |              | P20        |                |            | LED segment; address line; uC I/O port                                                           | P46                  |
| 59               | 75                                   |                   |             |              |               |               |              |              |            |                |            | JTAG TDO; DOUT                                                                                   |                      |
| 61<br>62         | 60<br>61                             |                   |             | RS_6         |               |               | A14<br>OE_   |              | P26        |                |            | LED segment; address line; uC I/O port<br>RAM output-enable                                      | P49                  |
| 63<br>65         | 62<br>65                             |                   |             |              |               |               | WR_<br>CF    |              | P36        |                |            | RAM write-enable; uC I/O port                                                                    |                      |
| 66               | 66<br>21                             | DIPSW7            |             |              |               |               | 01_          | SDOUT        | P16        |                |            | DIP switch; codec output data; uC I/O port                                                       | P27                  |
| 69               | 12                                   |                   |             |              |               |               |              |              |            |                |            | Uncommitted XS95 I/O pin                                                                         |                      |
| 70<br>71         | 69<br>70                             | DIPSW8<br>DIPSW6  |             |              |               | KB_DA         | TA           | SDIN         | P31<br>P15 |                |            | DIP switch; keyboard serial data; uC I/O port<br>DIP switch; codec input data; uC I/O port       | P28<br>P26           |
| 72<br>74         | 77<br>74                             | DIPSW5            |             |              |               |               |              | SCLK         | P14        |                |            | DIP switch; codec serial clock; uC I/O port                                                      | P25                  |
| 75               | 78                                   |                   |             | LS_3         |               |               | A3           |              |            |                |            | LED segment; address line                                                                        | P44                  |
| 76<br>77         | 76<br>1                              |                   |             |              |               |               |              |              |            |                |            | Uncommitted XS95 I/O pin<br>Uncommitted XS95 I/O pin                                             |                      |
| 78<br>79         | 2 +5V<br>79                          |                   |             | LS 4         |               |               | A4           |              |            |                |            | +5V power source<br>LED segment: address line                                                    | P38                  |
| 80               | 34                                   |                   |             |              |               |               |              |              |            | PC_D7          |            | PC parallel port output                                                                          |                      |
| 81               | 32<br>82                             |                   |             | LS_5         |               |               | A5           |              |            | FC_D0          |            | LED segment; address line                                                                        | P40                  |
| 83<br>84         | 83<br>84                             |                   |             | LS_6<br>LDP_ |               |               | A6<br>A7     |              |            |                |            | LED segment; address line<br>LED decimal-point; address line                                     | P39<br>P37           |
| 24,67            | 67<br>30                             | ŝ                 | SPARE_      | -            | VSYNC_        |               |              |              | P17        |                |            | Pushbutton; VGA horiz. sync.; uC I/O port<br>Serial EEPROM chip-enable                           | P18                  |
|                  | 43                                   |                   |             |              |               |               |              |              |            |                |            | Unconnected                                                                                      |                      |
|                  | 53<br>54 +3.3V                       |                   |             |              |               |               |              |              |            |                |            | +3.3V/+5V power supply (4000E/4000XL)                                                            |                      |
|                  | 55<br>63                             | F                 | PROGR       | AM           |               |               |              |              |            |                |            | XS40 configuration control<br>Unconnected                                                        | P55                  |
|                  | 64                                   |                   |             |              |               |               |              |              |            |                |            | Unconnected                                                                                      |                      |

 Table 5: Connections between the XS95 Board and XStend Board resources.

### Table 6: Jumpers for the XStend Board.

| Jumper   | Setting                                                                                                                          |  |  |  |  |  |  |  |
|----------|----------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| J8       | Removing the shunt on this jumper disconnects the power from LEDs D1—D8.                                                         |  |  |  |  |  |  |  |
| J4       | Removing the shunt on this jumper disconnects the power to the left LED display U1.                                              |  |  |  |  |  |  |  |
| J7       | Removing the shunt on this jumper disconnects the power to the right LED display U2.                                             |  |  |  |  |  |  |  |
| J16      | Removing the shunt on this jumper disables the left<br>RAM U5 by pulling its chip-select pin high.                               |  |  |  |  |  |  |  |
| J17      | Removing the shunt on this jumper disables the right RAM U6 by pulling its chip-select pin high.                                 |  |  |  |  |  |  |  |
| J11      | Placing a shunt on this jumper disables the codec by holding it in the reset state.                                              |  |  |  |  |  |  |  |
| J13, J15 | Placing shunts across two of the three pins of these<br>jumpers selects the digital de-emphasis for different<br>sampling rates: |  |  |  |  |  |  |  |
| 0 0      | De-emphasis for 32 KHz                                                                                                           |  |  |  |  |  |  |  |
| 0 1      | De-emphasis for 44.1 KHz                                                                                                         |  |  |  |  |  |  |  |
| 1 0      | De-emphasis for 48 KHz                                                                                                           |  |  |  |  |  |  |  |
| 1 1      | De-emphasis off                                                                                                                  |  |  |  |  |  |  |  |

# XStend Bus Connections

Connector

Daughterboard

Connector

XS40 Board

Connector

| J18-1   | D—          | XS40BUS01 |
|---------|-------------|-----------|
|         | _           | XS40BUS03 |
| J18-3   | <u>H</u>    | XS40BUS04 |
| J18-4   |             | XS40BUS05 |
| J18-5   |             | XS40BUS06 |
| 118-7   | H           | XS40BUS07 |
| J18-8   | й—          | XS40BUS08 |
| J18-9   | п—          | XS40BUS09 |
| J18-10  | ō           | XS40BUS10 |
| J18-11  | ō           | XS40BUS11 |
| J18-12  |             |           |
| J18-13  | D           | X540BUS13 |
| J18-14  | <u>D</u>    | XS40BUS15 |
| J18-15  | <u>–</u>    | XS40BUS16 |
| J18-16  | <u> </u>    | XS40BUS17 |
| JI8-17  | 1           | XS40BUS18 |
| 118-10  |             | XS40BUS19 |
| .118-20 | H           | XS40BUS20 |
| J18-21  | й—          | XS40BUS21 |
| J18-22  | <u> </u>    | XS40BUS22 |
| J18-23  | <u> </u>    | XS40BUS23 |
| J18-24  |             | XS40BUS24 |
| J18-25  |             | XS40BUS26 |
| J18-26  | <u> </u>    | XS40BUS27 |
| J18-27  |             | XS40BUS28 |
| J18-28  |             | XS40BUS29 |
| J18-29  |             | XS40BUS30 |
| J18-30  | 1           | XS40BUS31 |
| J18-32  | й—          | XS40BUS32 |
| J18-33  | Ğ—          | XS40BUS33 |
| J18-34  | п—          | XS40BUS34 |
| J18-35  | ō—          | XS40BUS35 |
| J18-36  | □           | XS40BUS36 |
| J18-37  | $\square$ — | X540BU537 |
| J18-38  | D           | X540BUS30 |
| J18-39  | <u>D</u>    | XS40BUS40 |
| J18-40  |             | XS40BUS41 |
| J18-41  |             | XS40BUS42 |
| J18-42  |             | XS40BUS43 |
| 118-44  |             | XS40BUS44 |
| 118-45  | й—          | XS40BUS45 |
| J18-46  | Б—          | XS40BUS46 |
| J18-47  | <u> </u>    | XS40BUS47 |
| J18-48  | D           | XS40BUS48 |
| J18-49  | $\square$   | X540BU549 |
| J18-50  | D           | X540BUS50 |
| J18-51  | D           | x3+000331 |
| J18-53  | D—          | XS40BUS53 |
|         | _           | XS40BUS55 |
| J18-55  |             | XS40BUS56 |
| J18-56  |             | XS40BUS57 |
| JI8-57  |             | XS40BUS58 |
| J18-59  |             | XS40BUS59 |
| J18-60  | й—          | XS40BUS60 |
| J18-61  | ō—          | XS40BUS61 |
| J18-62  | D           | XS40BUS62 |
| J18-63  |             | XS40BUS63 |
| J18-64  |             | XS40BUS65 |
| J18-65  | <u> </u>    | XS40BUS66 |
| J18-66  |             | XS40BUS67 |
| J18-67  |             | XS40BUS68 |
| J18-68  |             | XS40BUS69 |
| JI0-09  |             | XS40BUS70 |
| .118-71 | H           | XS40BUS71 |
| J18-72  | <u>п</u> —  | XS40BUS72 |
| J18-73  | ō—          | XS40BUS73 |
| J18-74  | □           | XS40BUS74 |
| J18-75  | □           | XS40BUS75 |
| J18-76  |             | X540BUS77 |
| J18-77  | <u> </u>    | XS40BUS78 |
| J18-78  | <u> </u>    | XS40BUS79 |
| J18-79  |             | XS40BUS80 |
| J18-80  |             | XS40BUS81 |
| JIG-61  |             | XS40BUS82 |
| J18-83  | H           | XS40BUS83 |
| J18-84  | й—          | XS40BUS84 |
|         | -           |           |

| J3-1           |   | XS40BUS01              | XS40BUS01   | ] J1-1   |
|----------------|---|------------------------|-------------|----------|
| 13-3           |   | XS40BUS03              | XS40BUS03   | 7 11-3   |
| 13-4           | Н | XS40BUS04              | XS40BUS04   | ] .1-4   |
| J3-5           |   | XS40BUS05              | XS40BUS05   | J1-5     |
| J3-6           |   | XS40BUS06              | XS40BUS06   | J1-6     |
| J3-7           |   | XS40BUS08              |             | J1-7     |
| J3-8           |   | XS40BUS09              | XS40BUS09   | J1-8     |
| J3-9           |   | XS40BUS10              | XS40BUS10   | J19      |
| J3-10<br>J3-11 | Н | XS40BUS11              | XS40BUS11   |          |
| J3-12          | Н | XS40BUS12              | XS40BUS12   | ] .II-12 |
| J3-13          |   | XS40BUS13              | XS40BUS13   | J1–13    |
| J3-14          |   |                        | XS40BUS14   | J1–14    |
| J3-15          |   | XS40BUS16              | XS4080515   | J1–15    |
| J3-16          |   | XS40BUS17              | XS40BUS17   | J1-16    |
| J3-1/          | H | XS40BUS18              | XS40BUS18   |          |
| J3-18<br>J3-19 | Н | XS40BUS19              | XS40BUS19   |          |
| J3-20          |   | XS40BUS20              | XS40BUS20   |          |
| J3-21          |   | XS40BUS21              | XS40BUS21   | J1-21    |
| J3-22          |   | XS40BUS22              |             | J1-22    |
| J3-23          |   | XS40BUS24              | XS40BUS24   | J1-23    |
| J3-24          | Н | XS40BUS25              | XS40BUS25   | J1-24    |
| JJ-25<br>JJ-26 | Н | XS40BUS26              | XS40BUS26   |          |
| J3-27          | ŏ | XS40BUS27              | XS40BUS27   | J J1-27  |
| J3-28          |   | XS40BUS28              | XS40BUS28   | J1-28    |
| J3-29          |   | XS40B0529<br>XS40B0530 | XS40BUS29   | J1-29    |
| J3-30          |   | XS40BUS31              | XS40BUS31   |          |
| J3-31          |   | XS40BUS32              | XS40BUS32   | J131     |
| J3-32          |   | XS40BUS33              | XS40BUS33   | J1=32    |
| J3-34          | П | XS40BUS34              | XS40BUS34   | J J1-34  |
| J3-35          |   | XS40BUS35              | XS40BUS35   |          |
| J3-36          |   | XS40BUS36              | XS40BUS36   | ] J1-36  |
| J3-37          |   | XS40BUS38              | XS40BUS38   | _ J1-37  |
| J3-38          | Ц | XS40BUS39              | XS40BUS39   | J1-38    |
| J3-39          |   | XS40BUS40              | XS40BUS40   |          |
| J3-40          | Н | XS40BUS41              | XS40BUS41   | J J1-40  |
| J3-42          |   | XS40BUS42              | XS40BUS42   |          |
| J3-43          |   | XS40BUS43              | XS40BUS43   | J1-43    |
| J3-44          |   | XS40BUS45              |             | J1-44    |
| J3-45          | Ц | XS40BUS46              | XS40BUS46   | J1-45    |
| J3-46          |   | XS40BUS47              | XS40BUS47   |          |
| J3-48          | Н | XS40BUS48              | XS40BUS48   | J J1-48  |
| J3-49          |   | XS40BUS49              | XS40BUS49   |          |
| J3-50          |   | XS40BUS50              | XS40BUS50   | ] J1-50  |
| J3-51          |   |                        | ×34080331   | J1-51    |
| J3-53          |   | XS40BUS53              | XS40BUS53   | ] J1-53  |
| 17 66          |   | XS40BUS55              | XS40BUS55 r |          |
| J3-55<br>J3-56 | H | XS40BUS56              | XS40BUS56   |          |
| J3-57          | П | XS40BUS57              | XS40BUS57   | J J1-57  |
| J3-58          |   | XS40BUS58              | XS40BUS58   | J1-58    |
| J3-59          |   | XS40B0559              |             | J1-59    |
| J3-60          |   | XS40BUS61              | XS40BUS61   | J1-60    |
| J3-61          |   | XS40BUS62              | XS40BUS62   | J1-61    |
| J3-63          | Н | XS40BUS63              | XS40BUS63   |          |
| J3-64          |   | XS40BUS64              | XS40BUS64   |          |
| J3-65          |   | XS40BUS65              | XS40BUS65   | ] J1-65  |
| J3-66          |   | XS40BUS67              | XS4080566   | J1-66    |
| J3-67          |   | XS40BUS68              | XS40BUS68   | J1-67    |
| J3-68          |   | XS40BUS69              | XS40BUS69   | J1-68    |
| J3-09<br>J3-70 | Н | XS40BUS70              | XS40BUS70   |          |
| J3-71          |   | XS40BUS71              | XS40BUS71   |          |
| J3-72          |   | XS40BUS72              | XS40BUS72   | J1-72    |
| J3-73          |   | XS4080573              |             | ] J1-73  |
| J3-74          |   | XS40BUS75              | XS40BUS75   | J1-74    |
| J3-75          |   | XS40BUS76              | XS40BUS76   | J1-75    |
| JS-/6          |   | XS40BUS77              | XS40BUS77   |          |
| J3-78          |   | XS40BUS78              | XS40BUS78   |          |
| J3-79          |   | XS40BUS79              | XS40BUS79   |          |
| J3-80          |   | XS408US80              |             | J1-80    |
| J3-81          |   | XS40BUS82              | XS40BUS82   | J1-81    |
| J3-82          |   | XS40BUS83              | XS40BUS83   | J1-82    |
| J3-83          |   | XS40BUS84              | XS40BUS84   | <br>     |
| 00-04          |   |                        |             | _ 004    |

XS40BUS01 J2-77 XS40BUS03 - J2-1 XS40BUS04 - J2-2 - J2-3 XS40BUS05 XS40BUS06 - J2-5 XS40BUS07 XS40BUS08 - J2-6 - J2-7 XS40BUS09 XS40BUS10 - J2-11 - J2-35 XS40BUS11 - J2-31 - J2-69 XS40BUS12 XS40BUS13 - J2-9 XS40BUS14 J2-13 XS40BUS15 - J2-28 XS40BUS16 - J2-30 - J2-29 XS40BUS17 XS40BUS18 - J2-14 - J2-14 - J2-15 - J2-17 XS40BUS19 XS40BUS20 XS40BUS21 XS40BUS22 - J2-68 - J2-33 XS40BUS23 - J2-18 - J2-19 XS40BUS24 XS40BUS25 - J2-21 XS40BUS26 - J2-23 XS40BUS27 - J2-32 - J2-34 XS40BUS28 XS40BUS29 - J2-20 XS40BUS31 - J2-12 XS40BUS32 - J2-81 XS40BUS33 - J2-25 - J2-80 - J2-80 - J2-39 - J2-45 XS40BUS34 XS40BUS35 XS40BUS36 XS40BUS37 - J2-10 - J2-40 XS40BUS38 XS40BUS39 - J2-41 XS40BUS40 - J2-43 - J2-44 XS40BUS41 XS40BUS42 - J2-4 XS40BUS44 \_\_\_\_ J2−46 XS40BUS45 XS40BUS46 - J2-47 - J2-48 XS40BUS47 - J2-50 - J2-51 XS40BUS48 XS40BUS49 - J2-52 - J2-53 XS40BUS50 XS40BUS51 - J2-54 XS40BUS56 - J2-55 XS40BUS57 - J2-56 XS40BUS58 -J2-57 XS40BUS59 XS40BUS60 - J2-58 - J2-61 - J2-62 - J2-63 XS40BUS61 XS40BUS62 XS40BUS67 -🗌 J2-24 XS40BUS65 - J2-65 XS40BUS66 XS40BUS67 -□ J2-66 -□ J2-67 XS40BUS68 - J2-26 - J2-70 XS40BUS69 XS40BUS70 - J2-71 XS40BUS74 - J2-74 XS40BUS75 -- J2-59 -- J2-76 XS40BUS76 XS40BUS77 - J2-72 XS40BUS78 - J2-75 - J2-79 XS40BUS79 XS40BUS80 -□ J2-36 -□ J2-37 XS40BUS81 XS40BUS82 -- J2-82 -- J2-83 XS40BUS83 XS40BUS84 - J2-84

XS95 Board

Connector

### **J18**

XS40BUS[01:84]

J3

+5V

XS40BUS[01:84]

#### J2 XS40BUS[01:84]

**J1** +3.3V - J1-54

-🗌 J3-54

- J18-54

- J18-2 - J1-52 - J2-49 - J3-52 GND

J1−2

- J2-78 - J3-2



### XStend Analog I/O





### XStend Stereo Codec

#### XS40BUS[01:84]







H1 H5<sub>H3</sub> H2





Silkscreen