background image

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)
096-              [      0     ,^b0000 ] :> ^b000000; "black
097-              [      0     ,^b0001 ] :> ^b101010; "light-gray
098-              [      0     ,^b0010 ] :> ^b111111; "white
099-              [      0     ,^b0011 ] :> ^b110000; "red
100-              [      0     ,^b0100 ] :> ^b001100; "green
101-              [      0     ,^b0101 ] :> ^b000011; "blue
102-              [      0     ,^b0110 ] :> ^b111100; "yellow
103-              [      0     ,^b0111 ] :> ^b110011; "magenta
104-              [      0     ,^b1000 ] :> ^b001111; "cyan
105-              [      0     ,^b1001 ] :> ^b100000; "dark-red
106-              [      0     ,^b1010 ] :> ^b001000; "dark-green
107-              [      0     ,^b1011 ] :> ^b000010; "dark-blue
108-              [      0     ,^b1100 ] :> ^b101000; "tan
109-              [      0     ,^b1101 ] :> ^b100010; "purple
110-              [      0     ,^b1110 ] :> ^b001010; "teal
111-              [      0     ,^b1111 ] :> ^b010101; "dark-gray
112-              [      1     ,X      ] :> ^b000000; "black during blanking
113-
114- END VGACORE

Listing 17:

 UCF file for VGA XStend example with XS40.

001- # CLOCK FROM XS40 OSCILLATOR
002- NET CLK

LOC=P13;

003- #
004- # MICROCONTROLLER PINS
005- NET RST

LOC=P36; # ACTIVE-HIGH RESET

006- NET WR_

LOC=P62; # ACTIVE-LOW WRITE (ALSO CONTROLS RAM)

007- NET AD0

LOC=P41; # MULTIPLEXED ADDRESS/DATA BUS

008- NET AD1

LOC=P40;

009- NET AD2

LOC=P39;

010- NET AD3

LOC=P38;

011- NET AD4

LOC=P35;

Содержание XStend

Страница 1: ...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 r...

Страница 2: ...2 9 Daughterboard Connector 12 3 Example Designs for the XStend Board 12 3 1 Using the LEDs and Switches 12 3 2 Using the VGA Interface 16 3 3 Using the PS 2 Keyboard Interface 21 3 4 Using the RAMs...

Страница 3: ...hat 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...

Страница 4: ...000XL 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 receptacle...

Страница 5: ...S ACTIVE LOW NET LS_0 LOC P3 NET LS_1 LOC P4 NET LS_2 LOC P5 NET LS_3 LOC P78 NET LS_4 LOC P79 NET LS_5 LOC P82 NET LS_6 LOC P83 NET LDP_ LOC P84 RIGHT LED DIGIT SEGMENT CONNECTIONS ACTIVE LOW NET RS_...

Страница 6: ...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 in...

Страница 7: ...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 ca...

Страница 8: ...40 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...

Страница 9: ...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 A6 LOC P83 NET A7 LOC P84 NET A8 LOC P59 UPPER BYTE OF ADDR...

Страница 10: ...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...

Страница 11: ...K LOC P9 NET LRCK LOC P6 NET SCLK LOC P77 NET SDIN LOC P70 NET CCLK LOC P44 NET CDIN LOC P45 NET CS_ LOC P46 Listing 12 Connections between the XStend codec and the XS95 STEREO CODEC CONNECTIONS NET S...

Страница 12: ...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 DI...

Страница 13: ...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...

Страница 14: ...11 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 054 S B0000000 05...

Страница 15: ...ET 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...

Страница 16: ...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 045 NET RS_1 LOC P56 046 NET RS_2 LOC P54 047 NET RS_3 LOC P55 048 NET RS_4 LO...

Страница 17: ...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...

Страница 18: ...tate 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 d...

Страница 19: ...t_ 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...

Страница 20: ...TIONS 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 PUSHBUTT...

Страница 21: ...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...

Страница 22: ...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 DECLA...

Страница 23: ...10000 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 HIG...

Страница 24: ...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_1 LOC P56 017 NET RS_2 LOC P54 018 NET RS_3 LOC P55 019 NET RS_4 LOC P53 020 NET RS_5...

Страница 25: ...how 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 XS...

Страница 26: ...ata line uC muxed address data line P58 40 43 D_2 AD1 P01 LED RAM data line uC muxed address data line P59 41 44 D_1 AD0 P00 LED RAM data line uC muxed address data line P60 42 4 Uncommitted XS95 I O...

Страница 27: ...2 LED RAM data line uC muxed address data line P58 43 40 D_2 AD1 P01 LED RAM data line uC muxed address data line P59 44 41 D_1 AD0 P00 LED RAM data line uC muxed address data line P60 45 36 RST uC re...

Страница 28: ...ing the shunt on this jumper disables the left 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 Placin...

Страница 29: ...XStend Bus Connections...

Страница 30: ...XStend RAMs...

Страница 31: ...XStend Analog I O...

Страница 32: ...XStend Stereo Codec...

Страница 33: ...XStend Switches LEDs VGA Interface and PS 2 Interface...

Страница 34: ...XStend Board Layout...

Отзывы: