

# XSV Flash Programming and Virtex Configuration

July 5, 2001 (Version 1.1)

Application Note by D. Vanden Bout

## Summary

This application note describes the circuits that let the XC95108 CPLD program the Flash on the XSV Board and then configure the Virtex FPGA with the data stored in the Flash.

## Using Flash with the XSV Board

The 16 Mb Flash chip on the XSV Board can be used to store configurations for the Virtex FPGA. When used in this way, there are three steps used to set up the Flash:

- 1. Configure the XC95108 CPLD with a programming circuit that connects the Flash to the parallel port.
- 2. Program the Flash by passing the Virtex configuration bitstream through the parallel port.
- 3. Configure the CPLD with a configuration circuit that will, upon power-up of the XSV Board, load the Virtex with the bitstream stored in the Flash.

## The Flash Programming Interface

Listing 1 and Listing 2 show the VHDL code and pin assignments for the CPLD circuit that connects the Flash to the parallel port. This circuit is simply an interface that allows the PC to read and write the Flash using only four data bits and two control signals. The PC uses this simple interface to control the higher-level Flash programming functions such as erasing the Flash sectors before they are programmed with new data.

The Flash programming circuit performs the following functions:

- It collects six successive nybbles from the parallel port and concatenates these into a 24-bit Flash address.
- It collects two successive nybbles from the parallel port and concatenates these into a byte of Flash data.

- It writes the data into the Flash at the given address and then loops back to await the arrival of another set of address and data nybbles.
- While gathering the nybbles for an address, it also reads the byte of Flash data from the previous loop and passes it to the parallel port as two successive nybbles.

How the VHDL implements these functions is described below.

Lines 10-32 of Listing 1 define the interface for the circuit. It uses six data pins of the parallel port: four for passing data and address nybbles, one for a synchronizing clock to drive the state machine in the CPLD, and one as a reset for the state machine. Four status pins of the parallel port are used to send data nybbles back to the PC and to report the current state of the CPLD state machine. The CPLD also interfaces to the address, data, and control pins of the Flash chip and the PROGRAM pin of the Virtex FPGA.

The eight states of the Flash programming state machine are defined on lines 43-53. Six states are used to gather the 24-bit Flash address in nybble chunks, and then two more states are used to collect the Flash data.

Line 63 makes the CPLD pull the Virtex PROGRAM pin low so it stays in its unconfigured state. This tristates the pins of the Virtex so it can't interfere with the programming of the Flash chip. Line 64 makes sure the reset of the Flash chip is released so it can be programmed.

Lines 65-67 just rename the parallel port I/O with more understandable names that reflect their underlying functions.

The main process for the Flash programming state machine begins on line 71. Lines 74-81 just set the default values for the outputs from the state machine.

Lines 87-132 implement the six states that concatenate nybbles from the parallel port into a 24-bit address. During each of these states, the nybble from the parallel port is placed into the appropriate slot in the address register. The current state is also reported back to the PC through the parallel port status lines in states load\_a20, load\_a8, load\_a4, and load\_a0. The Flash programming code in the PC uses this information to make sure it is in sync with the state machine.

However, during states load\_a16 and load\_a12 the status lines are used to carry the nybbles of a data byte from the Flash. The location of this data is stored in the next\_addr register in state load\_a20 (line 92). This address appears on the Flash address lines at the start of state load\_a16 and persists until the next\_addr register is written to again. During states load\_a16 and load\_a12, the Flash chip-enable and output-enable lines are forced low and the upper and lower nybbles of the Flash data at the given address are passed through the parallel port (lines 103 and 113, respectively). The Flash programming code in the PC gathers these nybbles and assembles the byte of Flash data.

Lines 134-152 implement the two states that concatenate two data nybbles into a byte of data that is written into the Flash at the address loaded during the previous six states. The actual write occurs in the second half of state load\_d0 when the clock is low. this gives the address time to settle from the previous cycle before the write occurs. When the clock goes high to end the write pulse, the state machine transfers to state load\_a20. Note that when state load\_a20 is first entered, line 90 ensures that the Flash data lines are still carrying the same value as they were in state load\_d0. This ensures the data hold time for the Flash.

The process on lines 163-177 updates the state, address, and data registers on the rising clock edge. A reset from the parallel port will clear the data register and send the state machine to the load\_a20 state to start another Flash address cycle. Note that the reset will not clear the address register. This allows the PC to read the Flash without writing it by forcing a reset after state load\_a0. When the state machine returns to the load\_a16 and load\_a12 states, the PC can read the Flash data at the address that was loaded during the previous loop. This would not be possible if the address register was cleared by a reset.

The process on lines 181-188 updates the register that drives the Flash address lines. (The connection of this register to the Flash address lines is done on line 190.) The address lines change on the falling clock edge. This ensures the address lines are stable before any potential write operation is initiated on the next rising clock edge.

## The Virtex-Flash Configuration Circuit

Listing 3 and Listing 4 show the VHDL code and pin assignments for the CPLD circuit that configures the Virtex FPGA with the bitstream programmed into the Flash. This circuit is simply increments an address counter which reads out the next byte of Flash data and strobes it into the Virtex. When the Virtex signals that it is completely configured, then the CPLD ceases operations. How the VHDL implements these functions is described below.

Lines 10-37 of Listing 3 define the interface for the circuit. It uses the programmable oscillator on the XSV Board as the main clock. The CPLD also interfaces to the address and control pins of the Flash chip so it can fetch the bytes of the Virtex configuration bitstream. (It doesn't need to access the Flash data pins since these are already directly connected to the configuration data inputs of the Virtex chip on the XSV Board.) The CPLD stuffs the bitstream into the Virtex using the configuration control pins.

Line 54 merely renames the V\_dout pin of the Virtex to V\_busy since the Virtex will use this signal to indicate when it is busy storing a byte of configuration data. Line 57 causes the CPLD to output the code onto the mode pins of the Virtex that place it in the SelectMAP configuration mode. In this mode, the Virtex chip accepts bytes of configuration data on the rising edge of the configuration clock as long as its chip-select and write-enable are active.

Lines 61-64 set the Flash control pins so it can output the data bytes of the Virtex bitstream. The CPLD releases its control of these pins when the Virtex signals that the configuration process is done (V\_done=HI).

The Flash chip has an access time of 85 ns while the XSV Board oscillator can run as fast as 100 MHz. Lines 69-76 implement a counter that divides the oscillator frequency by 16 and uses the slower clock to drive the configuration of the Virtex.

After power is applied to the XSV Board, the Virtex FPGA needs some time to settle before configuration starts. Lines 80-90 create a power-on timeout counter and a reset signal that is active until the counter reaches zero. Then the reset is removed and the configuration starts. Line 8 of Listing 4 ensures that the timeout counter in the CPLD is initialized to the 11...1 state upon power-up of the XSV Board.

Lines 95-96 use the power-on reset to lower the PROGRAM pin of the Virtex when the board powers up. The PROGRAM signal goes high after the power-on timeout expires and the Virtex configuration starts.

Lines 100-107 select the Virtex chip for configuration when the PROGRAM pin is high and the Virtex is not indicating a configuration error by pulling its INIT pin low. The internal chip-select signal is inverted and drives the Virtex chip-select and write-enable pins on lines 112-113. The CPLD releases control of these pins when the configuration process is done.

The process on lines 120-129 controls the fetching of configuration data from the Flash. The Flash address register is set to zero while the Virtex is held in its reset state with the PROGRAM pin pulled low. After the PROGRAM pin goes high and configuration starts, the Flash address is incremented on every clock cycle as long as the Virtex chip is selected and the Virtex is not signaling a configuration error (INIT=HI) or that it is busy with a previous byte of configuration data (BUSY=LO). The value in the address counter is passed to the Flash chip address pins on line 133.

#### Listing 1: VHDL code for the Flash programming interface.

```
1
 2
     -- XC9500 CPLD design which controls the loading of the XSV Flash
 3
     -- with data from the PC parallel port.
 4
 5
6
7
8
     library ieee;
     use ieee.std logic 1164.all;
     use ieee.std logic unsigned.all;
9
10
11
     entity flash is
            generic
12
             (
13
                    ADDR LEN: positive := 21
                                                              -- number of address bits for XSV FLASH
14
            );
15
            port
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
40
41
42
43
             (
                    -- parallel port data and status pins
                    ppd: in std_logic_vector(5 downto 0);
                                                              -- data nybble, clk, reset from par. port
                    pps: out std_logic_vector(6 downto 3); -- status nybble to parallel port
                    -- Flash data, address, and control pins
                    d: inout std logic vector(7 downto 0);
                                                                      -- data bus to XSV FLASH
                    a: out std_logic_vector(ADDR_LEN-1 downto 0); -- address bus to XSV FLASH
                    ceb: out std logic;
                                                                      -- chip-enable for XSV FLASH
                    oeb: out std logic;
                                                                      -- output-enable for XSV FLASH
                    web: out std logic;
                                                                      -- write-enable for XSV FLASH
                    resetb: out std logic;
                                                                      -- reset for XSV FLASH
                    -- Virtex FPGA pins
                                                                      -- Virtex PROGRAM pin
                    V progb: out std logic
            );
     end flash;
     architecture flash arch of flash is
             constant LO : std logic := '0';
             constant HI : std_logic := '1';
             constant NO : std_logic := '0';
            constant YES: std logic := '1';
            -- states for the state machine that programs the Flash
            type flash_state_type is
44
             (
45
                                         -- load address nybble A23-A20
                    load a20,
46
47
48
49
50
51
52
53
54
55
                    load_a16,
                                         -- load address nybble A19-A16, read data nybble D7-D4
                    load_a12,
                                         -- load address nybble A12-A15, read data nybble D3-D0
                                         -- load address nybble A8-A11
                    load a8,
                                         -- load address nybble A4-A7
                    load a4,
                                         -- load address nybble A0-A4
                    load a0,
                                         -- load data nybble D4-D7
                    load d4,
                                         -- load data nybble D0-D3
                    load d0
            );
             signal flash_state, next_flash_state: flash_state_type;
56
             signal clk, reset: std logic;
57
             signal nybble: std logic vector(3 downto 0);
58
             signal addr, next_addr: std_logic_vector(ADDR_LEN-1 downto 0);
59
             signal addr_reg, next_addr_reg: std_logic_vector(23 downto 0);
60
             signal data_reg, next_data_reg: std_logic_vector(3 downto 0);
61
62
     begin
63
             V progb<= L0;</pre>
                                  -- keep Virtex in reset state so it doesn't interfere
```

```
64
 65
 66
 67
 68
 69
 70
71
72
73
74
75
76
77
78
79
80
 81
 82
 83
 84
 85
 86
87
 88
 89
 90
 91
 92
93
94
 95
96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
```

```
resetb <= HI;
                 -- remove Flash reset so the chip is enabled
reset <= ppd(0); -- Flash prog. state machine reset from LSB of parallel port data
clk <= ppd(1); -- state machine clock from next bit of parallel port data
nybble <= ppd(5 downto 2); -- Flash data nybble from parallel port data</pre>
-- this process directs the state transitions of the Flash programming
-- state machine and sets the control outputs for each state
process(addr,addr reg,d,data reg,nybble,ppd,flash state)
begin
      -- the following statements set the default values for the outputs
      oeb <= HI; -- Flash chip data pin drivers disabled
                 -- Flash chip disabled
      ceb <= HI;
                -- no write operations to Flash chip
      web <= HI;
      d <= (others=>'Z'); -- no data driven into the Flash chip
      pps <= "1111";
                                   -- illegal state reported on status pins
      next_addr <= addr;</pre>
                                   -- Flash address does not change
      next_addr_reg <= addr reg;</pre>
      next data req <= data req;</pre>
                                  -- Flash data does not change
      -- now use the current state to determine the outputs and the
      -- next state for the Flash programming state machine
      case flash state is
            when load a20 =>
                  -- load Flash address bits A23-A20 and output the
                  -- last complete Flash address that was assembled previously
                  d <= data reg & nybble; -- complete data byte written to Flash
                  next addr reg(23 downto 20) <= nybble; -- store A23-A20
                  next_addr <= addr_reg(ADDR_LEN-1 downto 0); -- output last addr</pre>
                  pps <= "0000"; -- report current state through parallel port
                  when load a16 =>
                  -- load Flash address bits A19-A16, read the contents
                  -- from the previous Flash address, and send the upper
                  -- nybble of the Flash data back through the parallel port
                  next_addr_reg(19 downto 16) <= nybble; -- store A19-A16</pre>
                  ceb <= LO;
                                         -- enable Flash
                  oeb <= LO;
                                         -- read Flash
                  pps <= d(7 downto 4); -- send upper data nybble back to PC
                  when load_a12 =>
                  -- load Flash address bits A15-A12, read the contents
                  -- from the previous Flash address, and send the lower
                  -- nybble of the Flash data back through the parallel port
                  next addr req(15 downto 12) <= nybble; -- store A15-A12</pre>
                  ceb <= LO;
                                         -- enable Flash
                  when load a8 =>
                  -- load Flash address bits A11-A8
                  next addr req(11 downto 8) <= nybble; -- store A11-A8</pre>
                  pps <= "0011"; -- report current state through parallel port
                  when load a4 =>
                  -- load Flash address bits A7-A4
                  next addr reg(7 downto 4) <= nybble; -- store A7-A4</pre>
                  pps <= "0100"; -- report current state through parallel port
                  next_flash_state <= load_a0; -- go to next state</pre>
            when load_a0 =>
```

```
129
                                   -- load Flash address bits A3-A0
130
                                   next_addr_reg(3 downto 0) <= nybble; -- store A3-A0</pre>
131
                                   pps <= "0101"; -- report current state through parallel port
132
                                   next flash state <= load d4;</pre>
                                                                     -- go to next state
133
134
                           when load d4 =>
135
                                   -- output the assembled address to the Flash and load the
136
                                   -- upper nybble of data that will be written to the Flash
137
                                   next addr <= addr_reg(ADDR_LEN-1 downto 0); -- output complete addr</pre>
138
                                   ceb <= LO; -- enable the Flash
139
                                   next_data_reg <= nybble; -- store upper data nybble from par port
d <= data_reg & nybble; -- output data to the Flash</pre>
140
141
                                   pps <= "0110"; -- report current state through parallel port
142
                                                                   -- go to the next state
                                   next flash state <= load d0;</pre>
143
144
                           when load_d0 =>
145
                                   -- now get the lower nybble of data from the parallel port
146
                                   -- and write the complete byte to the Flash during the
147
                                   -- second half of the clock phase
148
                                   ceb <= LO; -- keep the Flash enabled
149
                                   web <= clk; -- write goes low during second half of clock cycle
150
                                   d <= data_reg & nybble; -- complete data byte written to Flash</pre>
151
                                   pps <= "0111"; -- report current state through parallel port
152
                                   next_flash_state <= load_a20; -- go back to the start</pre>
153
154
                           when others =>
155
                                   -- return the state machine to the initial state if it
156
                                   -- ever gets into an erroneous state
157
                                   next_flash_state <= load_a20;</pre>
158
159
                    end case;
160
             end process;
161
162
             -- update the programming machine state and other registers
163
             process(reset,clk)
164
             begin
165
                    if (reset=HI) then
166
                            -- asynchronous reset sets state machine to initial state
167
                            -- and clears data register
168
                            flash state <= load a20;
169
                           data reg <= (others=>'0');
170
171
                    elsif (clk'event and clk=HI) then
172
                            -- update the machine state and other registers on rising clock edge
173
                           flash state <= next flash state;</pre>
174
                           addr reg <= next addr reg;
175
                            data req <= next data req;
176
                    end if;
177
             end process;
178
179
             -- output Flash addresses one-half cycle early. This gives the Flash
180
             -- address time to settle and activate the appropriate location for writing.
181
             process (reset, clk)
182
             begin
183
                     -- change Flash address during the second half of the clock cycle
184
                    -- before the machine changes states
185
                    if (clk'event and clk=LO) then
186
                           addr <= next_addr;</pre>
187
                    end if:
188
             end process;
189
190
             a <= addr; -- output address to the Flash chip
191
192
      end flash arch;
```

## Listing 2: Pin assignments for the Flash programming interface.

```
1
 2
      # pin assignments for the XC95108 CPLD chip on the XSV Board
 3
 4
 5
6
7
      # Virtex FPGA
     net V_progb
                           loc=p11;
 8
      # Flash RAM
 9
     net resetb
                           loc=p3;
10
     net ceb
                           loc=P46;
11
     net oeb
                           loc=p42;
12
     net web
                           loc=p43;
13
     net d<0>
                           loc=p32;
14
     net d<1>
                           loc=p33;
15
     net d<2>
                           loc=p34;
16
     net d<3>
                           loc=P35;
17
     net d<4>
                           loc=P36;
18
     net d<5>
                           loc=P37;
19
     net d<6>
                           loc=P39;
20
21
22
     net d<7>
                           loc=P40;
     net a<0>
                           loc=p16;
     net a<1>
                           loc=p17;
23
     net a<2>
                           loc=p18;
24
     net a<3>
                           loc=p19;
25
26
27
28
     net a<4>
                           loc=p20;
     net a<5>
                           loc=p23;
                           loc=p24;
     net a<6>
     net a<7>
                           loc=p25;
29
                           loc=p27;
     net a<8>
30
     net a<9>
                           loc=p28;
31
     net a<10>
                           loc=p29;
32
33
     net a<11>
                           loc=p30;
     net a<12>
                           loc=p49;
34
35
     net a<13>
                           loc=p50;
     net a<14>
                           loc=p52;
36
     net a<15>
                           loc=p53;
37
     net a<16>
                           loc=p54;
38
     net a<17>
                           loc=p55;
39
     net a<18>
                           loc=p56;
40
     net a<19>
                           loc=p58;
41
     net a<20>
                           loc=p59;
42
43
      # parallel port
44
     net ppd<0>
                           loc=p77;
45
     net ppd<1>
                           loc=p74;
46
     net ppd<2>
                           loc=p72;
47
     net ppd<3>
                           loc=p70;
48
     net ppd<4>
                           loc=p68;
49
      net ppd<5>
                           loc=p67;
50
      # net ppd<6>
                           loc=p66;
51
      # net ppd<7>
                           loc=p65;
52
      # net ppc<0>
                           loc=p79;
53
      # net ppc<1>
                           loc=p78;
54
      # net ppc<2>
                           loc=p73;
55
      # net ppc<3>
                           loc=p71;
56
     net pps<3>
                           loc=p76;
57
     net pps<4>
                           loc=p60;
58
     net pps<5>
                           loc=p61;
59
      net pps<6>
                           loc=p64;
60
      # net pps<7>
                           loc=p63;
```

#### Listing 3: VHDL code for the Virtex-Flash configuration circuit.

```
1
 2
      -- XC9500 CPLD design which controls the configuration of the XSV Virtex
 3
      -- with data from the Flash chip.
 4
5
6
7
8
9
     library ieee;
     use ieee.std logic 1164.all;
     use ieee.std_logic_unsigned.all;
10
     entity config is
11
            generic
12
            (
13
                   ADDR_LEN: positive := 21
                                                     -- number of Flash address bits
14
            );
15
            port
16
            (
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
33
34
35
36
37
38
                   clk
                                  : in std logic;
                                                      -- clock from DS1075 prog. osc.
                    -- Flash address and control pins
                                 : out std_logic_vector(ADDR_LEN-1 downto 0); -- Flash address
                                  : out std logic;
                                                      -- Flash chip-enable
                   ceb
                                 : out std logic;
                                                       -- Flash output-enable
                   oeb
                   web
                                 : out std logic;
                                                       -- Flash write-enable
                   resetb
                                 : out std logic;
                                                       -- Flash reset
                   -- Virtex configuration pins
                   V progb
                               : out std_logic;
                                                       -- Virtex PROGRAM pin
                                 : out std logic;
                                                      -- Virtex config clock
                   V_cclk
                   V_csb
                                 : out std logic;
                                                      -- Virtex config chip-select
                   V_wrb
                                 : out std_logic;
                                                      -- Virtex config write-enable
                                                       -- Virtex config init status
                   V_initb
                                 : in std_logic;
                                 : in std_logic;
                                                       -- Virtex config busy status
                   V_{dout}
                                                       -- Virtex config done status
                   V done
                                 : in std logic;
                   V m
                                 : out std logic vector(2 downto 0)
                                                                          -- Virtex config. mode pins
            );
     end config;
39
     architecture config_arch of config is
40
                             : std logic := '0';
            constant LO
41
            constant HI
                                : std logic := '1';
42
            constant FLOAT
                                : std logic := 'Z';
43
44
            signal clk cnt
                                        : std logic vector(3 downto 0);
45
            signal cclk
                                        : std_logic;
46
            signal programb, cs
                                        : std_logic;
47
            signal addr, next addr
                                        : std_logic_vector(ADDR_LEN-1 downto 0);
48
            signal poweron reset
                                        : std logic;
49
50
51
52
53
                                        : std_logic_vector(19 downto 0);
            signal poweron cnt
            signal V busy
                                         : std logic;
            signal button progb
                                         : std logic;
     begin
54
            V busy <= V dout;
                                        -- give this signal a better name
55
56
             -- set Virtex mode to SelectMAP so it can be configured from Flash
57
                          <= "110";
            V_m
58
59
             -- Flash is enabled for reading while Virtex is not yet configured
60
             -- and then the Flash pins float when configuration is done
61
            oeb
                          <= LO when (V_done=LO) else FLOAT;
62
                          <= LO when (V done=LO) else FLOAT;
            ceb
```

```
-- disable Flash writes
63
                           <= HI when (V_done=LO) else FLOAT;
             web
 64
                           <= HI;
                                                                     -- remove Flash reset
             resetb
65
 66
             -- generate configuration clock for Virtex from the XSV clock.
67
             -- The XSV clock could be as much as 100 MHz, so divide by 16
68
             -- to exceed the access time of the Flash.
69
             process(clk,clk cnt)
70
71
72
             begin
                    if(clk'event and clk=HI) then
                           clk cnt <= clk cnt + 1;
73
74
                    end if:
             end process;
75
             cclk <= clk cnt(3);
                                         -- internal configuration clock
76
             V cclk <= cclk;
                                         -- also send config. clock to Virtex
77
78
             -- Apply reset when the power to the XSV Board is first applied.
79
             -- Remove the power-on reset after the counter reaches 0.
80
             process(poweron cnt,cclk)
81
             begin
82
                    if(cclk'event and cclk=HI) then
83
                           if(poweron cnt = 0) then
84
                                  poweron_reset <= LO;</pre>
                                                             -- remove reset when timeout expires
85
                           else
86
                                  poweron_cnt <= poweron_cnt - 1;</pre>
87
                                  poweron reset <= HI;</pre>
88
                           end if;
89
                    end if;
90
             end process;
91
92
             -- initiate Virtex configuration by lowering the /PROGRAM pin
93
             -- during the initial power-on reset and then raising it when
94
             -- the power-on timeout expires and the manual program control is high
95
             programb <= not(poweron reset);</pre>
96
             V progb <= programb;</pre>
97
98
             -- Select the Virtex for configuration as long as the /PROGRAM pin
99
             -- is not held low and the INIT pin is not low.
100
             process(V_initb,cclk,programb)
101
             begin
102
                    if(programb = LO) then
103
                           cs <= LO;
104
                    elsif(cclk'event and cclk=HI) then
105
                           cs <= V_initb;
106
                    end if;
107
             end process;
108
109
             -- Select the Virtex for configuration by lowering its chip-select
110
             -- and write inputs when the internal chip-select is high. Then
111
             -- float these pins after the Virtex configuration is done.
112
             V csb <= not(cs)
                                  when (V done=LO) else FLOAT;
113
             V_wrb <= not(cs)</pre>
                                  when (V_done=LO) else FLOAT;
114
115
             -- increment the Flash address so the next byte of configuration
116
             -- data is presented to the Virtex. Stop incrementing if the
117
             -- Virtex is not selected, signals a config. error (INIT=0), or
118
             -- is busy. Reset the address counter to zero whenever the
119
             -- /PROGRAM pin goes low and a new configuration sequence begins.
120
             process(addr,cs,V_initb,V_busy,cclk)
121
             begin
122
                    if (cclk'event and cclk=HI) then
123
                           if((cs=HI) and (V initb=HI) and (V_busy=LO)) then
124
                                  addr <= addr + 1;
125
                           elsif(programb = LO) then
126
                                  addr <= (others=>LO);
127
                           end if;
```

## XSV Flash Programming and Virtex Configuration

```
128 end if;
129 end process;
130
131 -- pass the Flash address out to the Flash chip. Float the address
132 -- lines once configuration is done.
133 a <= addr when (V_done=LO) else (others=>FLOAT);
134
135 end config_arch;
```

### Listing 4: Pin assignments for the Virtex-Flash configuration circuit.

1

```
2
     # pin assignments for the XC95108 CPLD chip on the XSV Board
4
5
6
7
8
     # set all the bits in the initial state of the power-on
     # counter so we get the maximum timeout interval
     inst poweron_cnt_reg<*> INIT=S;
9
10
     # Virtex FPGA
11
     net V dout
                          loc=p6;
12
     net V wrb
                         loc=p7;
13
     net V csb
                         loc=p8;
14
     net V initb
                         loc=p9;
15
     net V_done
                          loc=p10;
16
     net V_progb
                          loc=p11;
17
     net V_cclk
                          loc=p12;
18
     net V_m<0>
                          loc=p13;
19
     net V m<1>
                          loc=p14;
20
21
22
23
24
25
26
27
28
29
30
     net V_m<2>
                          loc=p15;
     # Flash RAM
     net resetb
                          loc=p3;
     net ceb
                          loc=P46;
     net oeb
                          loc=p42;
     net web
                         loc=p43;
     net a<0>
                         loc=p16;
     net a<1>
                          loc=p17;
     net a<2>
                          loc=p18;
     net a<3>
                          loc=p19;
31
32
33
34
35
     net a<4>
                          loc=p20;
     net a<5>
                          loc=p23;
                          loc=p24;
     net a<6>
     net a<7>
                           loc=p25;
     net a<8>
                          loc=p27;
36
37
38
39
40
     net a<9>
                          loc=p28;
                          loc=p29;
     net a<10>
                         loc=p30;
     net a<11>
     net a<12>
                          loc=p49;
     net a<13>
                          loc=p50;
41
     net a<14>
                         loc=p52;
42
     net a<15>
                         loc=p53;
43
     net a<16>
                          loc=p54;
44
     net a<17>
                          loc=p55;
45
     net a<18>
                          loc=p56;
46
     net a<19>
                           loc=p58;
47
     net a<20>
                           loc=p59;
48
49
     # programmable oscillator
50
     net clk
                           loc=p22;
```