URL
https://opencores.org/ocsvn/System09/System09/trunk
Subversion Repositories System09
Compare Revisions
- This comparison shows the changes necessary to convert path
/System09/trunk/rtl
- from Rev 116 to Rev 117
- ↔ Reverse comparison
Rev 116 → Rev 117
/System09_Terasic_DE1/System09_Terasic_DE1.vhd
0,0 → 1,1120
--=============================================================================-- |
-- -- |
-- System09 - Synthesizable System On a Chip - VHDL FPGA core top level file. -- |
-- -- |
--=============================================================================-- |
-- |
-- |
-- File name : System09_Terasic_DE1.vhd |
-- |
-- Entity name : System09 |
-- |
-- Purpose : Top level file for 6809 compatible system on a chip |
-- Designed with Alera EP2C20 Cyclone 2 FPGA. |
-- Implemented with Terasic DE1 FPGA board, |
-- |
-- Dependencies : ieee.Std_Logic_1164 |
-- ieee.std_logic_unsigned |
-- ieee.std_logic_arith |
-- ieee.numeric_std |
-- |
-- Uses : cpu09 (..\VHDL\cpu09.vhd) CPU core |
-- dat_ram (..\VHDL\datram.vhd) Dynamic Address Translation |
-- mon_rom (..\Cyclone2\mon_rom.vhd) Monitor ROM |
-- acia6850 (..\VHDL\acia6850.vhd) ACIA (UART) |
-- ACIA_Clock (..\VHDL\ACIA_Clock.vhd) ACIA Baud Rate Clock Divider |
-- keyboard (..\VHDL\keyboard.vhd) PS/2 Keyboard register interface |
-- ps2_keyboard (..\VHDL\ps2_keyboard.vhd) PS/2 Keyboard interface logic |
-- keymap_rom (..\Cyclone2\keymap_rom.vhd) PS/2 Keyboard key code look up table |
-- trap (..\VHDL\trap.vhd) Hardware breakpointy trap |
-- timer (..\VHDL\timer.vhd) Interrupt timer |
-- vdu8 (..\VHDL\vdu8.vhd) Video Display Unit |
-- (..\Cyclone2\char_rom.vhd) Character Generator ROM (B16_RAM) |
-- (..\Cyclone2\ram_2k.vhd) Text & Attribute RAM Buffer |
-- sprom (..\Cyclone2\sprom.vhd) Single port altsyncrom |
-- spram (..\Cyclone2\spram.vhd) Single port altsyncram |
-- bit_funcs (..\VHDL\bit_funcs.vhd) Bit manipulation Functions package |
-- |
-- Author : John E. Kent |
-- dilbert57@opencores.org |
-- |
-- Memory Map : |
-- |
-- $0000 - $DFFF System RAM (512K Mapped via DAT) |
-- $E000 - ACIA (SWTPc) |
-- $E010 - Reserved for SWTPc FD-01 FD1771 FDC |
-- $E020 - Keyboard |
-- $E030 - VDU |
-- $E040 - Reserved for SWTPc MP-T (was Compact Flash) |
-- $E050 - Timer |
-- $E060 - Trap (Hardware Breakpoint) |
-- $E070 - Reserved for Trace Buffer |
-- $E080 - Reserved for SWTPc MP-ID 6821 PIA (?) |
-- $E090 - Reserved for SWTPc MP-ID 6840 PTM (?) |
-- $E0A0 - Switches in / LEDS out |
-- $E0B0 - 7 Segment hex display |
-- $E0C0 - Reserved |
-- $E0D0 - Reserved |
-- $E0E0 - Reserved |
-- $E0F0 - Reserved |
-- $E100 - $E13F Reserved IDE / Compact Flash Card |
-- $E140 - $E17F Reserved for Ethernet MAC (XESS) |
-- $E180 - $E1BF Reserved for Expansion Slot 0 (XESS) |
-- $E1C0 - $E1FF Reserved for Expansion Slot 1 (XESS) |
-- $E200 - $EFFF Reserved for Future I/O |
-- $F000 - $F7FF RAM for Sys09bug monitor extensions |
-- $F800 - $FFFF Sys09bug ROM (Read only) |
-- $FFF0 - $FFFF DAT - Dynamic Address Translation (Write Only) |
-- |
-- |
-- Copyright (C) 2003 - 2010 John Kent |
-- |
-- This program is free software: you can redistribute it and/or modify |
-- it under the terms of the GNU General Public License as published by |
-- the Free Software Foundation, either version 3 of the License, or |
-- (at your option) any later version. |
-- |
-- This program is distributed in the hope that it will be useful, |
-- but WITHOUT ANY WARRANTY; without even the implied warranty of |
-- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
-- GNU General Public License for more details. |
-- |
-- You should have received a copy of the GNU General Public License |
-- along with this program. If not, see <http://www.gnu.org/licenses/>. |
-- |
--===========================================================================-- |
-- |
-- Revision History: |
-- |
--===========================================================================-- |
-- |
-- Version 0.1 - 20 March 2003 |
-- Version 0.2 - 30 March 2003 |
-- Version 0.3 - 29 April 2003 |
-- Version 0.4 - 29 June 2003 |
-- |
-- Version 0.5 - 19 July 2003 |
-- prints out "Hello World" |
-- |
-- Version 0.6 - 5 September 2003 |
-- Runs SBUG |
-- |
-- Version 1.0- 6 Sep 2003 - John Kent |
-- Inverted sys_clk |
-- Initial release to Open Cores |
-- |
-- Version 1.1 - 17 Jan 2004 - John Kent |
-- Updated miniUart. |
-- |
-- Version 1.2 - 25 Jan 2004 - John Kent |
-- removed signals "test_alu" and "test_cc" |
-- Trap hardware re-instated. |
-- |
-- Version 1.3 - 11 Feb 2004 - John Kent |
-- Designed forked off to produce System09_VDU |
-- Added VDU component |
-- VDU runs at 25MHz and divides the clock by 2 for the CPU |
-- UART Runs at 57.6 Kbps |
-- |
-- Version 2.0 - 2 September 2004 - John Kent |
-- ported to Digilent Xilinx Spartan3 starter board |
-- removed Compaact Flash and Trap Logic. |
-- Replaced SBUG with KBug9s |
-- |
-- Version 2.1 - 21 November 2006 - John Kent |
-- Replaced KBug9s with Sys09bug 1.0 |
-- Inverted bottom nybble of DAT register outputs |
-- Changed ROM & I/O decoding to be compatible with SWTPc |
-- Upped the serial baud rate to 115.2 KBd |
-- added multiple global clock buffers |
-- (Uart would not operate correctly) |
-- |
-- Version 2.2 - 22 December 2006 - John Kent |
-- Increased CPU clock from 12.5MHz to 25 MHz. |
-- Removed some of the global clock buffers |
-- Added LED output register |
-- Changed address decoding to 4K Blocks |
-- |
-- Version 2.3 - 1 June 2007 - John Kent |
-- Updated VDU & ACIA |
-- Changed decoding for Sys09Bug |
-- |
-- Version 2.4 - 31 January 2008 - John Kent |
-- ACIA does not appear to work. |
-- Made RAM OE and WE strobes synchonous to sys_clk |
-- |
-- Version 2.5 - 23rd Feburary 2009 - John Kent |
-- Implemented recommendation to remove vga_clk clock buffer |
-- |
-- Version 2.6 - 5th september 2010 - John Kent |
-- Renamed ACIA_6850 to acia6850 |
-- Updated generics on VDU8 |
-- Shortened the "keyboard" label |
-- Fixed up address label on CPU09 |
-- Removed Flex RAM |
-- Map RAM at $F000 - $F7FF |
-- |
-- Vesrion 2.7 - 22nd October 2010 - John Kent |
-- Ported from Digilent XC3S200 Starter to |
-- Terasic EP2C20 DE1 board. |
-- |
--===========================================================================-- |
library ieee; |
use ieee.std_logic_1164.all; |
use IEEE.STD_LOGIC_ARITH.ALL; |
use IEEE.STD_LOGIC_UNSIGNED.ALL; |
use ieee.numeric_std.all; |
|
entity System09_Terasic_DE1 is |
port( |
-- clocks |
clock_24 : in std_logic_vector(1 downto 0); |
clock_27 : in std_logic; |
clock_50 : in std_logic; -- System Clock input |
ext_clock : in std_logic; |
|
-- push button keys |
key : in std_logic_vector(3 downto 0); -- RST, NMI |
|
-- SRAM interface signals |
|
sram_ce_n : out std_logic; |
sram_we_n : out std_logic; |
sram_oe_n : out std_logic; |
sram_ub_n : out std_logic; |
sram_lb_n : out std_logic; |
sram_addr : out std_logic_vector(17 downto 0); |
sram_dq : inout std_logic_vector(15 downto 0); |
|
-- PS/2 Keyboard |
ps2_clk : inout Std_logic; |
ps2_dat : inout Std_Logic; |
|
-- ACIA/UART Interface |
uart_rxd : in Std_Logic; |
uart_txd : out Std_Logic; |
|
-- CRTC output signals |
vga_r : out std_logic_vector(3 downto 0); |
vga_g : out std_logic_vector(3 downto 0); |
vga_b : out std_logic_vector(3 downto 0); |
vga_hs : out Std_Logic; |
vga_vs : out Std_Logic; |
|
-- LEDS & Switches |
ledg : out std_logic_vector(7 downto 0); |
ledr : out std_logic_vector(9 downto 0); |
sw : in std_logic_vector(9 downto 0); |
|
-- hexadecimal display |
hex0 : out std_logic_vector(6 downto 0); |
hex1 : out std_logic_vector(6 downto 0); |
hex2 : out std_logic_vector(6 downto 0); |
hex3 : out std_logic_vector(6 downto 0); |
|
-- gnereal purpose I/O |
gpio_0 : in std_logic_vector(35 downto 0); |
gpio_1 : in std_logic_vector(35 downto 0); |
|
-- i2c interface |
i2c_sclk : in std_logic; |
i2c_sdat : in std_logic; |
|
-- audio codec |
aud_adcdat : in std_logic; |
aud_adclrck : in std_logic; |
aud_bclk : in std_logic; |
aud_dacdat : in std_logic; |
aud_daclrck : in std_logic; |
aud_xck : in std_logic; |
|
-- dram |
dram_addr : out std_logic_vector(11 downto 0); |
dram_dq : in std_logic_vector(15 downto 0); |
dram_cs_n : out std_logic; |
dram_ba_0 : in std_logic; |
dram_ba_1 : in std_logic; |
dram_ldqm : in std_logic; |
dram_udqm : in std_logic; |
dram_ras_n : out std_logic; |
dram_cas_n : out std_logic; |
dram_we_n : out std_logic; |
dram_cke : in std_logic; |
dram_clk : in std_logic; |
|
-- Flash memory |
fl_addr : out std_logic_vector(21 downto 0); |
fl_dq : in std_logic_vector(7 downto 0); |
fl_rst_n : in std_logic; |
fl_oe_n : out std_logic; |
fl_we_n : out std_logic; |
|
-- JTAG |
tck : in std_logic; |
tcs : in std_logic; |
tdi : in std_logic; |
tdo : in std_logic |
); |
end System09_Terasic_DE1; |
|
------------------------------------------------------------------------------- |
-- Architecture for System09 |
------------------------------------------------------------------------------- |
architecture my_computer of System09_Terasic_DE1 is |
----------------------------------------------------------------------------- |
-- constants |
----------------------------------------------------------------------------- |
constant SYS_CLK_FREQ : integer := 50000000; -- FPGA System Clock |
constant VGA_CLK_FREQ : integer := 25000000; -- VGA Pixel Clock |
constant CPU_CLK_FREQ : integer := 25000000; -- CPU Clock |
constant BAUD_Rate : integer := 57600; -- Baud Rate |
constant ACIA_CLK_FREQ : integer := BAUD_Rate * 16; |
|
type hold_state_type is ( hold_release_state, hold_request_state ); |
|
----------------------------------------------------------------------------- |
-- Signals |
----------------------------------------------------------------------------- |
|
signal sys_clk : std_logic; |
signal vga_clk : std_logic; |
signal pll_locked : std_logic; |
|
-- CPU Interface signals |
signal cpu_clk : std_logic; |
signal cpu_rst : std_logic; |
signal cpu_rw : std_logic; |
signal cpu_vma : std_logic; |
signal cpu_halt : std_logic; |
signal cpu_hold : std_logic; |
signal cpu_firq : std_logic; |
signal cpu_irq : std_logic; |
signal cpu_nmi : std_logic; |
signal cpu_addr : std_logic_vector(15 downto 0); |
signal cpu_data_in : std_logic_vector(7 downto 0); |
signal cpu_data_out : std_logic_vector(7 downto 0); |
|
-- Dynamic Address Translation |
signal dat_cs : std_logic; |
signal dat_addr : std_logic_vector(7 downto 0); |
|
-- BOOT ROM |
signal rom_cs : Std_logic; |
signal rom_data_out : Std_Logic_Vector(7 downto 0); |
|
-- ACIA Interface signals |
signal acia_clk : std_logic; |
signal acia_cs : Std_Logic; |
signal acia_data_out : Std_Logic_Vector(7 downto 0); |
signal acia_irq : Std_Logic; |
signal acia_rxd : Std_Logic; |
signal acia_txd : Std_Logic; |
signal acia_dcd_n : Std_Logic; |
-- signal acia_rts_n : Std_Logic; |
signal acia_cts_n : Std_Logic; |
|
-- keyboard port |
signal kbd_data_out : std_logic_vector(7 downto 0); |
signal kbd_cs : std_logic; |
signal kbd_irq : std_logic; |
|
-- LEDs |
signal leds_data_out : std_logic_vector(7 downto 0); |
signal leds_cs : std_logic; |
|
-- Video Display Unit |
signal vdu_cs : std_logic; |
signal vdu_data_out : std_logic_vector(7 downto 0); |
signal vga_red : std_logic; |
signal vga_green : std_logic; |
signal vga_blue : std_logic; |
|
-- LEDs |
signal led_cs : std_logic; |
signal led_data_out : std_logic_vector(7 downto 0); |
|
-- 7 Segment Display |
signal hex_cs : std_logic; |
signal hex_data_out : std_logic_vector(7 downto 0); |
signal hex0_reg : std_logic_vector(7 downto 0); |
signal hex1_reg : std_logic_vector(7 downto 0); |
signal hex2_reg : std_logic_vector(7 downto 0); |
signal hex3_reg : std_logic_vector(7 downto 0); |
|
-- interrupt timer |
signal tmr_data_out : std_logic_vector(7 downto 0); |
signal tmr_cs : std_logic; |
signal tmr_irq : std_logic; |
|
-- hardware break point (trap) |
signal hbp_data_out : std_logic_vector(7 downto 0); |
signal hbp_cs : std_logic; |
signal hbp_irq : std_logic; |
|
-- RAM |
signal sram_cs : std_logic; -- memory chip select |
signal sram_data_out : std_logic_vector(7 downto 0); |
signal sram_ce : std_logic; |
signal sram_ub : std_logic; |
signal sram_lb : std_logic; |
signal sram_we : std_logic; |
signal sram_oe : std_logic; |
|
-- System Clock Prescaler |
signal clk_count : std_logic; |
|
----------------------------------------------------------------- |
-- |
-- CPU09 CPU core |
-- |
----------------------------------------------------------------- |
|
component cpu09 |
port ( |
clk : in std_logic; |
rst : in std_logic; |
vma : out std_logic; |
addr : out std_logic_vector(15 downto 0); |
rw : out std_logic; |
data_in : in std_logic_vector(7 downto 0); |
data_out : out std_logic_vector(7 downto 0); |
halt : in std_logic; |
hold : in std_logic; |
irq : in std_logic; |
nmi : in std_logic; |
firq : in std_logic |
); |
end component; |
|
---------------------------------------- |
-- |
-- Dynamic Address Translation Registers |
-- |
---------------------------------------- |
component dat_ram |
port ( |
clk : in std_logic; |
rst : in std_logic; |
cs : in std_logic; |
rw : in std_logic; |
addr_lo : in std_logic_vector(3 downto 0); |
addr_hi : in std_logic_vector(3 downto 0); |
data_in : in std_logic_vector(7 downto 0); |
data_out : out std_logic_vector(7 downto 0) |
); |
end component; |
|
---------------------------------------- |
-- |
-- 4KByte Block RAM Monitor ROM |
-- |
---------------------------------------- |
component mon_rom |
Port ( |
clk : in std_logic; |
rst : in std_logic; |
cs : in std_logic; |
rw : in std_logic; |
addr : in std_logic_vector (10 downto 0); |
data_in : in std_logic_vector (7 downto 0); |
data_out : out std_logic_vector (7 downto 0) |
); |
end component; |
|
----------------------------------------------------------------- |
-- |
-- 6850 ACIA |
-- |
----------------------------------------------------------------- |
|
component acia6850 |
port ( |
clk : in Std_Logic; -- System Clock |
rst : in Std_Logic; -- Reset input (active high) |
cs : in Std_Logic; -- ACIA Chip Select |
rw : in Std_Logic; -- Read / Not Write |
addr : in Std_Logic; -- Register Select |
data_in : in Std_Logic_Vector(7 downto 0); -- Data Bus In |
data_out : out Std_Logic_Vector(7 downto 0); -- Data Bus Out |
irq : out Std_Logic; -- Interrupt |
RxC : in Std_Logic; -- Receive Baud Clock |
TxC : in Std_Logic; -- Transmit Baud Clock |
RxD : in Std_Logic; -- Receive Data |
TxD : out Std_Logic; -- Transmit Data |
DCD_n : in Std_Logic; -- Data Carrier Detect |
CTS_n : in Std_Logic; -- Clear To Send |
RTS_n : out Std_Logic -- Request To send |
); |
end component; |
|
----------------------------------------------------------------- |
-- |
-- ACIA Clock divider |
-- |
----------------------------------------------------------------- |
|
component ACIA_Clock |
generic ( |
SYS_CLK_FREQ : integer := SYS_CLK_FREQ; |
ACIA_CLK_FREQ : integer := ACIA_CLK_FREQ |
); |
port ( |
clk : in Std_Logic; -- System Clock Input |
acia_clk : out Std_logic -- ACIA Clock output |
); |
end component; |
|
---------------------------------------- |
-- |
-- PS/2 Keyboard |
-- |
---------------------------------------- |
|
component keyboard |
generic( |
KBD_CLK_FREQ : integer := CPU_CLK_FREQ |
); |
port( |
clk : in std_logic; |
rst : in std_logic; |
cs : in std_logic; |
addr : in std_logic; |
rw : in std_logic; |
data_in : in std_logic_vector(7 downto 0); |
data_out : out std_logic_vector(7 downto 0); |
irq : out std_logic; |
kbd_clk : inout std_logic; |
kbd_data : inout std_logic |
); |
end component; |
|
---------------------------------------- |
-- |
-- Video Display Unit. |
-- |
---------------------------------------- |
component vdu8 |
generic( |
VGA_CLK_FREQ : integer := VGA_CLK_FREQ; -- HZ |
VGA_HOR_CHARS : integer := 80; -- CHARACTERS 25.6us |
VGA_HOR_CHAR_PIXELS : integer := 8; -- PIXELS 0.32us |
VGA_HOR_FRONT_PORCH : integer := 16; -- PIXELS 0.64us |
VGA_HOR_SYNC : integer := 96; -- PIXELS 3.84us |
VGA_HOR_BACK_PORCH : integer := 48; -- PIXELS 1.92us |
VGA_VER_CHARS : integer := 25; -- CHARACTERS 12.8ms |
VGA_VER_CHAR_LINES : integer := 16; -- LINES 0.512ms |
VGA_VER_FRONT_PORCH : integer := 10; -- LINES 0.320ms |
VGA_VER_SYNC : integer := 2; -- LINES 0.064ms |
VGA_VER_BACK_PORCH : integer := 34 -- LINES 1.088ms |
); |
port( |
-- control register interface |
vdu_clk : in std_logic; -- CPU Clock - 12.5MHz |
vdu_rst : in std_logic; |
vdu_cs : in std_logic; |
vdu_rw : in std_logic; |
vdu_addr : in std_logic_vector(2 downto 0); |
vdu_data_in : in std_logic_vector(7 downto 0); |
vdu_data_out : out std_logic_vector(7 downto 0); |
|
-- vga port connections |
vga_clk : in std_logic; -- VGA Pixel Clock - 25 MHz |
vga_red_o : out std_logic; |
vga_green_o : out std_logic; |
vga_blue_o : out std_logic; |
vga_hsync_o : out std_logic; |
vga_vsync_o : out std_logic |
); |
end component; |
|
---------------------------------------- |
-- |
-- Interrupt timer |
-- |
---------------------------------------- |
|
component timer is |
port ( |
clk : in std_logic; |
rst : in std_logic; |
cs : in std_logic; |
addr : in std_logic; |
rw : in std_logic; |
data_in : in std_logic_vector(7 downto 0); |
data_out : out std_logic_vector(7 downto 0); |
irq : out std_logic |
); |
end component; |
|
---------------------------------------- |
-- |
-- hardware break point (bus trap) |
-- |
---------------------------------------- |
|
component trap is |
port ( |
clk : in std_logic; |
rst : in std_logic; |
cs : in std_logic; |
rw : in std_logic; |
vma : in std_logic; |
addr : in std_logic_vector(15 downto 0); |
data_in : in std_logic_vector(7 downto 0); |
data_out : out std_logic_vector(7 downto 0); |
irq : out std_logic |
); |
end component; |
|
|
component pll IS |
PORT |
( |
areset : IN STD_LOGIC := '0'; |
inclk0 : IN STD_LOGIC := '0'; |
c0 : OUT STD_LOGIC ; |
c1 : OUT STD_LOGIC ; |
c2 : OUT STD_LOGIC ; |
locked : OUT STD_LOGIC |
); |
END component; |
|
begin |
----------------------------------------------------------------------------- |
-- Instantiation of internal components |
----------------------------------------------------------------------------- |
|
my_cpu : cpu09 port map ( |
clk => cpu_clk, |
rst => cpu_rst, |
vma => cpu_vma, |
addr => cpu_addr(15 downto 0), |
rw => cpu_rw, |
data_in => cpu_data_in, |
data_out => cpu_data_out, |
halt => cpu_halt, |
hold => cpu_hold, |
irq => cpu_irq, |
nmi => cpu_nmi, |
firq => cpu_firq |
); |
|
my_dat : dat_ram port map ( |
clk => cpu_clk, |
rst => cpu_rst, |
cs => dat_cs, |
addr_hi => cpu_addr(15 downto 12), |
addr_lo => cpu_addr(3 downto 0), |
rw => cpu_rw, |
data_in => cpu_data_out, |
data_out => dat_addr(7 downto 0) |
); |
|
my_rom : mon_rom port map ( |
clk => cpu_clk, |
rst => cpu_rst, |
cs => rom_cs, |
rw => '1', |
addr => cpu_addr(10 downto 0), |
data_in => cpu_data_out, |
data_out => rom_data_out |
); |
|
my_acia : acia6850 port map ( |
clk => cpu_clk, |
rst => cpu_rst, |
cs => acia_cs, |
addr => cpu_addr(0), |
rw => cpu_rw, |
data_in => cpu_data_out, |
data_out => acia_data_out, |
irq => acia_irq, |
RxC => acia_clk, |
TxC => acia_clk, |
RxD => acia_rxd, |
TxD => acia_txd, |
DCD_n => acia_dcd_n, |
CTS_n => acia_cts_n, |
RTS_n => open |
); |
|
|
---------------------------------------- |
-- |
-- ACIA Clock |
-- |
---------------------------------------- |
my_ACIA_Clock : ACIA_Clock |
generic map( |
SYS_CLK_FREQ => SYS_CLK_FREQ, |
ACIA_CLK_FREQ => ACIA_CLK_FREQ |
) |
port map( |
clk => sys_clk, |
acia_clk => acia_clk |
); |
|
|
---------------------------------------- |
-- |
-- PS/2 Keyboard Interface |
-- |
---------------------------------------- |
my_keyboard : keyboard |
generic map ( |
KBD_CLK_FREQ => CPU_CLK_FREQ |
) |
port map( |
clk => cpu_clk, |
rst => cpu_rst, |
cs => kbd_cs, |
addr => cpu_addr(0), |
rw => cpu_rw, |
data_in => cpu_data_out(7 downto 0), |
data_out => kbd_data_out(7 downto 0), |
irq => kbd_irq, |
kbd_clk => ps2_clk, |
kbd_data => ps2_dat |
); |
|
---------------------------------------- |
-- |
-- Video Display Unit instantiation |
-- |
---------------------------------------- |
my_vdu : vdu8 |
generic map( |
VGA_CLK_FREQ => VGA_CLK_FREQ, -- 25MHZ |
VGA_HOR_CHARS => 80, -- CHARACTERS 25.6us |
VGA_HOR_CHAR_PIXELS => 8, -- PIXELS 0.32us |
VGA_HOR_FRONT_PORCH => 16, -- PIXELS 0.64us |
VGA_HOR_SYNC => 96, -- PIXELS 3.84us |
VGA_HOR_BACK_PORCH => 48, -- PIXELS 1.92us |
VGA_VER_CHARS => 25, -- CHARACTERS 12.8ms |
VGA_VER_CHAR_LINES => 16, -- LINES 0.512ms |
VGA_VER_FRONT_PORCH => 10, -- LINES 0.320ms |
VGA_VER_SYNC => 2, -- LINES 0.064ms |
VGA_VER_BACK_PORCH => 34 -- LINES 1.088ms |
) |
port map( |
|
-- Control Registers |
vdu_clk => cpu_clk, -- 12.5 MHz System Clock in |
vdu_rst => cpu_rst, |
vdu_cs => vdu_cs, |
vdu_addr => cpu_addr(2 downto 0), |
vdu_rw => cpu_rw, |
vdu_data_in => cpu_data_out, |
vdu_data_out => vdu_data_out, |
|
-- vga port connections |
vga_clk => vga_clk, -- 25 MHz pixel clock |
vga_red_o => vga_red, |
vga_green_o => vga_green, |
vga_blue_o => vga_blue, |
vga_hsync_o => vga_hs, |
vga_vsync_o => vga_vs |
); |
|
---------------------------------------- |
-- |
-- Interrupt timer |
-- |
---------------------------------------- |
|
my_timer : timer |
port map ( |
clk => cpu_clk, |
rst => cpu_rst, |
cs => tmr_cs, |
addr => cpu_addr(0), |
rw => cpu_rw, |
data_in => cpu_data_out, |
data_out => tmr_data_out, |
irq => tmr_irq |
); |
|
---------------------------------------- |
-- |
-- hardware break point (bus trap) |
-- |
---------------------------------------- |
|
my_hw_bp : trap |
port map ( |
clk => cpu_clk, |
rst => cpu_rst, |
cs => hbp_cs, |
rw => cpu_rw, |
vma => cpu_vma, |
addr => cpu_addr, |
data_in => cpu_data_out, |
data_out => hbp_data_out, |
irq => hbp_irq |
); |
|
---------------------------------------- |
-- |
-- Phase Locked Loop Clock divider |
-- |
|
my_pll : pll |
PORT MAP |
( |
areset => '0', |
inclk0 => clock_50, |
c0 => sys_clk, |
c1 => cpu_clk, |
c2 => vga_clk, |
locked => pll_locked |
); |
|
---------------------------------------------------------------------- |
-- |
-- Process to decode memory map |
-- |
---------------------------------------------------------------------- |
|
mem_decode: process( cpu_addr, cpu_rw, cpu_vma, |
dat_cs, dat_addr, |
rom_data_out, |
acia_data_out, |
kbd_data_out, |
vdu_data_out, |
hex_data_out, |
led_data_out, |
tmr_data_out, |
hbp_data_out, |
sram_data_out |
) |
begin |
cpu_data_in <= (others=>'0'); |
dat_cs <= '0'; |
rom_cs <= '0'; |
acia_cs <= '0'; |
kbd_cs <= '0'; |
vdu_cs <= '0'; |
hex_cs <= '0'; |
led_cs <= '0'; |
sram_cs <= '0'; |
tmr_cs <= '0'; |
hbp_cs <= '0'; |
-- pb_cs <= '0'; |
-- ide_cs <= '0'; |
-- ether_cs <= '0'; |
-- slot1_cs <= '0'; |
-- slot2_cs <= '0'; |
|
if cpu_addr( 15 downto 8 ) = "11111111" then |
cpu_data_in <= rom_data_out; |
dat_cs <= cpu_vma; -- write DAT |
rom_cs <= cpu_vma; -- read ROM |
-- |
-- Sys09Bug Monitor ROM $F000 - $FFFF |
-- |
elsif dat_addr(3 downto 0) = "1111" then -- $XF000 - $XFFFF |
if cpu_addr(11) = '1' then |
-- |
-- Monitor ROM $F800 - $FFFF |
-- |
cpu_data_in <= rom_data_out; |
rom_cs <= cpu_vma; -- read ROM |
else |
-- |
-- SRAM $F000 - $F7FF |
-- |
cpu_data_in <= sram_data_out; |
sram_cs <= cpu_vma; |
end if; |
-- |
-- IO Devices $E000 - $EFFF |
-- |
elsif dat_addr(3 downto 0) = "1110" then -- $XE000 - $XEFFF |
case cpu_addr(11 downto 8) is |
-- |
-- SWTPC peripherals from $E000 to $E0FF |
-- |
when "0000" => |
case cpu_addr(7 downto 4) is |
-- |
-- ACIA ($E000 - $E00F) |
-- |
when "0000" => |
cpu_data_in <= acia_data_out; |
acia_cs <= cpu_vma; |
|
-- |
-- Reserved - FD1771 FDC ($E010 - $E01F) (SWTPC) |
-- |
|
-- |
-- Keyboard port ($E020 - $E02F) |
-- |
when "0010" => |
cpu_data_in <= kbd_data_out; |
kbd_cs <= cpu_vma; |
|
-- |
-- VDU port ($E030 - $E03F) |
-- |
when "0011" => |
cpu_data_in <= vdu_data_out; |
vdu_cs <= cpu_vma; |
|
-- |
-- Reserved - SWTPc MP-T ($E040 - $E04F) |
-- |
|
-- |
-- Reserved - Timer ($E050 - $E05F) (B5-X300) |
-- |
when "0101" => |
cpu_data_in <= tmr_data_out; |
tmr_cs <= cpu_vma; |
|
-- |
-- Reserved - hardware break point (Bus Trap) ($E060 - $E06F) |
-- |
when "0110" => |
cpu_data_in <= hbp_data_out; |
hbp_cs <= cpu_vma; |
|
-- |
-- Reserved - I/O port ($E070 - $E07F) (B5-X300) |
-- |
|
-- |
-- Reserved - PTM 6840 ($E080 - $E08F) (SWTPC) |
-- |
|
-- |
-- Reserved - PIA Timer ($E090 - $E09F) (SWTPC) |
-- |
|
-- |
-- Read Switched port ($E0A0 - $E0AF) |
-- Write LEDS |
-- |
when "1010" => |
cpu_data_in <= led_data_out; |
led_cs <= cpu_vma; |
|
-- |
-- 7 segment display port ($E0B0 - $E0BF) |
-- |
when "1011" => |
cpu_data_in <= hex_data_out; |
hex_cs <= cpu_vma; |
|
|
when others => -- $EXC0 to $EXFF |
null; |
end case; |
-- |
-- $E100 to $EFFF reserved for future use |
-- |
when others => |
null; |
end case; |
-- |
-- Everything else is RAM |
-- |
else |
cpu_data_in <= sram_data_out; |
sram_cs <= cpu_vma; |
end if; |
end process; |
|
|
-- |
-- 1M byte SRAM Control |
-- Processes to read and write memory based on bus signals |
-- |
sram_process: process( sys_clk, cpu_rst, |
cpu_addr, cpu_rw, cpu_vma, cpu_data_out, |
dat_addr, sram_cs, |
sram_ce, sram_ub, sram_lb, sram_dq, |
sram_we, sram_oe ) |
begin |
-- |
-- Clock Hold on rising edge |
-- |
if( sys_clk'event and sys_clk='1' ) then |
-- |
-- sram_hold signal helps |
-- |
if( cpu_rst = '1' ) then |
sram_we <= '0'; |
sram_oe <= '0'; |
else |
if (sram_cs = '1') and (sram_we = '0') and (sram_oe = '0') then |
sram_we <= not cpu_rw; |
sram_oe <= cpu_rw; |
else |
sram_we <= '0'; |
sram_oe <= '0'; |
end if; |
end if; |
end if; |
|
sram_we_n <= not sram_we; |
sram_oe_n <= not sram_oe; |
|
sram_ce <= sram_cs; |
sram_ub <= not cpu_addr(0); |
sram_lb <= cpu_addr(0); |
sram_ce_n <= not sram_ce; |
sram_ub_n <= not sram_ub; |
sram_lb_n <= not sram_lb; |
|
sram_addr(17 downto 11) <= dat_addr(6 downto 0); |
sram_addr(10 downto 0) <= cpu_addr(11 downto 1); |
|
if sram_we = '1' and sram_ce = '1' and sram_lb = '1' then |
sram_dq(7 downto 0) <= cpu_data_out; |
else |
sram_dq(7 downto 0) <= "ZZZZZZZZ"; |
end if; |
|
if sram_we = '1' and sram_ce = '1' and sram_ub = '1' then |
sram_dq(15 downto 8) <= cpu_data_out; |
else |
sram_dq(15 downto 8) <= "ZZZZZZZZ"; |
end if; |
|
if cpu_addr(0) = '0' then |
sram_data_out <= sram_dq(15 downto 8); |
else |
sram_data_out <= sram_dq(7 downto 0); |
end if; |
|
end process; |
|
-- |
-- LEDS output register |
-- |
led_output : process( cpu_clk, cpu_rst, led_cs, cpu_rw, cpu_addr, cpu_data_out, sw ) |
begin |
if cpu_clk'event and cpu_clk='0' then |
if cpu_rst = '1' then |
ledr <= (others=>'0'); |
ledg <= (others=>'0'); |
else |
if led_cs = '1' and cpu_rw = '0' then |
if cpu_addr(0) = '0' then |
ledr(7 downto 0) <= cpu_data_out; |
else |
ledg(7 downto 0) <= cpu_data_out; |
end if; |
end if; |
end if; |
end if; |
led_data_out <= sw(7 downto 0); |
end process; |
|
-- |
-- 7 segment HEX display output register |
-- |
hex_output : process( cpu_clk, cpu_rst, hex_cs, cpu_rw, cpu_addr, cpu_data_out, |
hex0_reg, hex1_reg, hex2_reg, hex3_reg ) |
begin |
if cpu_clk'event and cpu_clk='0' then |
if cpu_rst = '1' then |
hex0_reg <= (others=>'0'); |
hex1_reg <= (others=>'0'); |
hex2_reg <= (others=>'0'); |
hex3_reg <= (others=>'0'); |
else |
if hex_cs = '1' and cpu_rw = '0' then |
case cpu_addr(1 downto 0) is |
when "00" => |
hex0_reg <= cpu_data_out; |
when "01" => |
hex1_reg <= cpu_data_out; |
when "10" => |
hex2_reg <= cpu_data_out; |
when "11" => |
hex3_reg <= cpu_data_out; |
end case; |
end if; |
end if; |
end if; |
|
case cpu_addr(1 downto 0) is |
when "00" => |
hex_data_out <= hex0_reg; |
when "01" => |
hex_data_out <= hex1_reg; |
when "10" => |
hex_data_out <= hex2_reg; |
when "11" => |
hex_data_out <= hex3_reg; |
end case; |
|
hex0 <= not hex0_reg(6 downto 0); |
hex1 <= not hex1_reg(6 downto 0); |
hex2 <= not hex2_reg(6 downto 0); |
hex3 <= not hex3_reg(6 downto 0); |
|
end process; |
|
-- |
-- Interrupts and other bus control signals |
-- |
interrupts : process( key, pll_locked, |
acia_irq, kbd_irq, hbp_irq, tmr_irq ) |
begin |
cpu_rst <= not key(0); -- CPU reset is active high |
cpu_firq <= kbd_irq; |
cpu_nmi <= (not key(1)) or hbp_irq; |
cpu_irq <= acia_irq or tmr_irq; |
cpu_halt <= '0'; |
cpu_hold <= '0'; |
end process; |
|
-- |
-- ACIA pin assignments |
-- |
acia_assignments : process( uart_rxd, acia_txd ) |
begin |
acia_dcd_n <= '0'; |
acia_cts_n <= '0'; |
acia_rxd <= uart_rxd; |
uart_txd <= acia_txd; |
end process; |
|
-- |
-- assign vga colour bits to single bit RGB output of VDU |
-- |
vga_assignments : process( vga_red, vga_green, vga_blue ) |
begin |
vga_r <= (others=>vga_red); |
vga_g <= (others=>vga_green); |
vga_b <= (others=>vga_blue); |
end process; |
|
-- |
-- assign dram signals |
-- |
dram_assign : process( all ) |
begin |
dram_addr <= (others=>'0'); |
dram_cs_n <= '1'; |
dram_ras_n <= '1'; |
dram_cas_n <= '1'; |
dram_we_n <= '1'; |
end process; |
|
-- |
-- assign flash memory signals |
-- |
flash_assign : process( all ) |
begin |
fl_addr <= (others=>'0'); |
fl_oe_n <= '1'; |
fl_we_n <= '1'; |
|
end process; |
|
end my_computer; --===================== End of architecture =======================-- |
|
/System09_Terasic_DE1/system09.pof
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream
System09_Terasic_DE1/system09.pof
Property changes :
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: System09_Terasic_DE1/system09.pin
===================================================================
--- System09_Terasic_DE1/system09.pin (nonexistent)
+++ System09_Terasic_DE1/system09.pin (revision 117)
@@ -0,0 +1,557 @@
+ -- Copyright (C) 1991-2010 Altera Corporation
+ -- Your use of Altera Corporation's design tools, logic functions
+ -- and other software and tools, and its AMPP partner logic
+ -- functions, and any output files from any of the foregoing
+ -- (including device programming or simulation files), and any
+ -- associated documentation or information are expressly subject
+ -- to the terms and conditions of the Altera Program License
+ -- Subscription Agreement, Altera MegaCore Function License
+ -- Agreement, or other applicable license agreement, including,
+ -- without limitation, that your use is for the sole purpose of
+ -- programming logic devices manufactured by Altera and sold by
+ -- Altera or its authorized distributors. Please refer to the
+ -- applicable agreement for further details.
+ --
+ -- This is a Quartus II output file. It is for reporting purposes only, and is
+ -- not intended for use as a Quartus II input file. This file cannot be used
+ -- to make Quartus II pin assignments - for instructions on how to make pin
+ -- assignments, please see Quartus II help.
+ ---------------------------------------------------------------------------------
+
+
+
+ ---------------------------------------------------------------------------------
+ -- NC : No Connect. This pin has no internal connection to the device.
+ -- DNU : Do Not Use. This pin MUST NOT be connected.
+ -- VCCINT : Dedicated power pin, which MUST be connected to VCC (1.2V).
+ -- VCCIO : Dedicated power pin, which MUST be connected to VCC
+ -- of its bank.
+ -- Bank 1: 3.3V
+ -- Bank 2: 3.3V
+ -- Bank 3: 3.3V
+ -- Bank 4: 3.3V
+ -- Bank 5: 3.3V
+ -- Bank 6: 3.3V
+ -- Bank 7: 3.3V
+ -- Bank 8: 3.3V
+ -- GND : Dedicated ground pin. Dedicated GND pins MUST be connected to GND.
+ -- It can also be used to report unused dedicated pins. The connection
+ -- on the board for unused dedicated pins depends on whether this will
+ -- be used in a future design. One example is device migration. When
+ -- using device migration, refer to the device pin-tables. If it is a
+ -- GND pin in the pin table or if it will not be used in a future design
+ -- for another purpose the it MUST be connected to GND. If it is an unused
+ -- dedicated pin, then it can be connected to a valid signal on the board
+ -- (low, high, or toggling) if that signal is required for a different
+ -- revision of the design.
+ -- GND+ : Unused input pin. It can also be used to report unused dual-purpose pins.
+ -- This pin should be connected to GND. It may also be connected to a
+ -- valid signal on the board (low, high, or toggling) if that signal
+ -- is required for a different revision of the design.
+ -- GND* : Unused I/O pin. For transceiver I/O banks, connect each pin marked GND*
+ -- either individually through a 10k Ohm resistor to GND or tie all pins
+ -- together and connect through a single 10k Ohm resistor to GND.
+ -- For non-transceiver I/O banks, connect each pin marked GND* directly to GND
+ -- or leave it unconnected.
+ -- RESERVED : Unused I/O pin, which MUST be left unconnected.
+ -- RESERVED_INPUT : Pin is tri-stated and should be connected to the board.
+ -- RESERVED_INPUT_WITH_WEAK_PULLUP : Pin is tri-stated with internal weak pull-up resistor.
+ -- RESERVED_INPUT_WITH_BUS_HOLD : Pin is tri-stated with bus-hold circuitry.
+ -- RESERVED_OUTPUT_DRIVEN_HIGH : Pin is output driven high.
+ ---------------------------------------------------------------------------------
+
+
+
+ ---------------------------------------------------------------------------------
+ -- Pin directions (input, output or bidir) are based on device operating in user mode.
+ ---------------------------------------------------------------------------------
+
+Quartus II Version 9.1 Build 304 01/25/2010 Service Pack 1 SJ Web Edition
+CHIP "system09" ASSIGNED TO AN: EP2C20F484C7
+
+Pin Name/Usage : Location : Dir. : I/O Standard : Voltage : I/O Bank : User Assignment
+-------------------------------------------------------------------------------------------------------------
+GND : A1 : gnd : : : :
+VCCIO3 : A2 : power : : 3.3V : 3 :
+i2c_sclk : A3 : input : 3.3-V LVTTL : : 3 : Y
+aud_bclk : A4 : input : 3.3-V LVTTL : : 3 : Y
+aud_daclrck : A5 : input : 3.3-V LVTTL : : 3 : Y
+aud_adclrck : A6 : input : 3.3-V LVTTL : : 3 : Y
+vga_r[2] : A7 : output : 3.3-V LVTTL : : 3 : Y
+vga_g[3] : A8 : output : 3.3-V LVTTL : : 3 : Y
+vga_b[0] : A9 : output : 3.3-V LVTTL : : 3 : Y
+vga_b[2] : A10 : output : 3.3-V LVTTL : : 3 : Y
+vga_hs : A11 : output : 3.3-V LVTTL : : 3 : Y
+clock_24[1] : A12 : input : 3.3-V LVTTL : : 4 : Y
+gpio_0[0] : A13 : input : 3.3-V LVTTL : : 4 : Y
+gpio_0[2] : A14 : input : 3.3-V LVTTL : : 4 : Y
+gpio_0[4] : A15 : input : 3.3-V LVTTL : : 4 : Y
+gpio_0[6] : A16 : input : 3.3-V LVTTL : : 4 : Y
+gpio_0[8] : A17 : input : 3.3-V LVTTL : : 4 : Y
+gpio_0[10] : A18 : input : 3.3-V LVTTL : : 4 : Y
+gpio_0[12] : A19 : input : 3.3-V LVTTL : : 4 : Y
+gpio_0[14] : A20 : input : 3.3-V LVTTL : : 4 : Y
+VCCIO4 : A21 : power : : 3.3V : 4 :
+GND : A22 : gnd : : : :
+VCCIO1 : AA1 : power : : 3.3V : 1 :
+GND : AA2 : gnd : : : :
+sram_addr[0] : AA3 : output : 3.3-V LVTTL : : 8 : Y
+sram_addr[2] : AA4 : output : 3.3-V LVTTL : : 8 : Y
+sram_addr[4] : AA5 : output : 3.3-V LVTTL : : 8 : Y
+sram_dq[0] : AA6 : bidir : 3.3-V LVTTL : : 8 : Y
+sram_dq[2] : AA7 : bidir : 3.3-V LVTTL : : 8 : Y
+sram_dq[4] : AA8 : bidir : 3.3-V LVTTL : : 8 : Y
+sram_dq[6] : AA9 : bidir : 3.3-V LVTTL : : 8 : Y
+sram_we_n : AA10 : output : 3.3-V LVTTL : : 8 : Y
+sram_addr[6] : AA11 : output : 3.3-V LVTTL : : 8 : Y
+fl_addr[15] : AA12 : output : 3.3-V LVTTL : : 7 : Y
+fl_addr[13] : AA13 : output : 3.3-V LVTTL : : 7 : Y
+fl_addr[1] : AA14 : output : 3.3-V LVTTL : : 7 : Y
+fl_oe_n : AA15 : output : 3.3-V LVTTL : : 7 : Y
+fl_dq[1] : AA16 : input : 3.3-V LVTTL : : 7 : Y
+fl_dq[3] : AA17 : input : 3.3-V LVTTL : : 7 : Y
+fl_dq[5] : AA18 : input : 3.3-V LVTTL : : 7 : Y
+fl_dq[7] : AA19 : input : 3.3-V LVTTL : : 7 : Y
+fl_addr[17] : AA20 : output : 3.3-V LVTTL : : 7 : Y
+GND : AA21 : gnd : : : :
+VCCIO6 : AA22 : power : : 3.3V : 6 :
+GND : AB1 : gnd : : : :
+VCCIO8 : AB2 : power : : 3.3V : 8 :
+sram_addr[1] : AB3 : output : 3.3-V LVTTL : : 8 : Y
+sram_addr[3] : AB4 : output : 3.3-V LVTTL : : 8 : Y
+sram_ce_n : AB5 : output : 3.3-V LVTTL : : 8 : Y
+sram_dq[1] : AB6 : bidir : 3.3-V LVTTL : : 8 : Y
+sram_dq[3] : AB7 : bidir : 3.3-V LVTTL : : 8 : Y
+sram_dq[5] : AB8 : bidir : 3.3-V LVTTL : : 8 : Y
+sram_dq[7] : AB9 : bidir : 3.3-V LVTTL : : 8 : Y
+sram_addr[5] : AB10 : output : 3.3-V LVTTL : : 8 : Y
+sram_addr[7] : AB11 : output : 3.3-V LVTTL : : 8 : Y
+fl_addr[16] : AB12 : output : 3.3-V LVTTL : : 7 : Y
+fl_addr[14] : AB13 : output : 3.3-V LVTTL : : 7 : Y
+fl_addr[12] : AB14 : output : 3.3-V LVTTL : : 7 : Y
+RESERVED_INPUT : AB15 : : : : 7 :
+fl_dq[0] : AB16 : input : 3.3-V LVTTL : : 7 : Y
+fl_dq[2] : AB17 : input : 3.3-V LVTTL : : 7 : Y
+fl_dq[4] : AB18 : input : 3.3-V LVTTL : : 7 : Y
+fl_dq[6] : AB19 : input : 3.3-V LVTTL : : 7 : Y
+fl_addr[0] : AB20 : output : 3.3-V LVTTL : : 7 : Y
+VCCIO7 : AB21 : power : : 3.3V : 7 :
+GND : AB22 : gnd : : : :
+VCCIO2 : B1 : power : : 3.3V : 2 :
+GND : B2 : gnd : : : :
+i2c_sdat : B3 : input : 3.3-V LVTTL : : 3 : Y
+aud_xck : B4 : input : 3.3-V LVTTL : : 3 : Y
+aud_dacdat : B5 : input : 3.3-V LVTTL : : 3 : Y
+aud_adcdat : B6 : input : 3.3-V LVTTL : : 3 : Y
+vga_r[3] : B7 : output : 3.3-V LVTTL : : 3 : Y
+vga_g[0] : B8 : output : 3.3-V LVTTL : : 3 : Y
+vga_g[2] : B9 : output : 3.3-V LVTTL : : 3 : Y
+vga_b[3] : B10 : output : 3.3-V LVTTL : : 3 : Y
+vga_vs : B11 : output : 3.3-V LVTTL : : 3 : Y
+clock_24[0] : B12 : input : 3.3-V LVTTL : : 4 : Y
+gpio_0[1] : B13 : input : 3.3-V LVTTL : : 4 : Y
+gpio_0[3] : B14 : input : 3.3-V LVTTL : : 4 : Y
+gpio_0[5] : B15 : input : 3.3-V LVTTL : : 4 : Y
+gpio_0[7] : B16 : input : 3.3-V LVTTL : : 4 : Y
+gpio_0[9] : B17 : input : 3.3-V LVTTL : : 4 : Y
+gpio_0[11] : B18 : input : 3.3-V LVTTL : : 4 : Y
+gpio_0[13] : B19 : input : 3.3-V LVTTL : : 4 : Y
+gpio_0[15] : B20 : input : 3.3-V LVTTL : : 4 : Y
+GND : B21 : gnd : : : :
+VCCIO5 : B22 : power : : 3.3V : 5 :
+hex2[3] : C1 : output : 3.3-V LVTTL : : 2 : Y
+hex2[2] : C2 : output : 3.3-V LVTTL : : 2 : Y
+~nCSO~ / RESERVED_INPUT_WITH_WEAK_PULLUP : C3 : input : 3.3-V LVTTL : : 2 : N
+~ASDO~ / RESERVED_INPUT_WITH_WEAK_PULLUP : C4 : input : 3.3-V LVTTL : : 2 : N
+GND : C5 : gnd : : : :
+VCCIO3 : C6 : power : : 3.3V : 3 :
+tck : C7 : input : 3.3-V LVTTL : : 3 : Y
+GND : C8 : gnd : : : :
+vga_r[1] : C9 : output : 3.3-V LVTTL : : 3 : Y
+vga_g[1] : C10 : output : 3.3-V LVTTL : : 3 : Y
+VCCIO3 : C11 : power : : 3.3V : 3 :
+VCCIO4 : C12 : power : : 3.3V : 4 :
+RESERVED_INPUT : C13 : : : : 4 :
+gpio_1[10] : C14 : input : 3.3-V LVTTL : : 4 : Y
+GND : C15 : gnd : : : :
+RESERVED_INPUT : C16 : : : : 4 :
+gpio_1[14] : C17 : input : 3.3-V LVTTL : : 4 : Y
+gpio_1[15] : C18 : input : 3.3-V LVTTL : : 4 : Y
+gpio_1[16] : C19 : input : 3.3-V LVTTL : : 5 : Y
+gpio_1[17] : C20 : input : 3.3-V LVTTL : : 5 : Y
+gpio_0[16] : C21 : input : 3.3-V LVTTL : : 5 : Y
+gpio_0[17] : C22 : input : 3.3-V LVTTL : : 5 : Y
+hex1[6] : D1 : output : 3.3-V LVTTL : : 2 : Y
+hex1[5] : D2 : output : 3.3-V LVTTL : : 2 : Y
+hex2[6] : D3 : output : 3.3-V LVTTL : : 2 : Y
+hex3[6] : D4 : output : 3.3-V LVTTL : : 2 : Y
+hex3[1] : D5 : output : 3.3-V LVTTL : : 2 : Y
+hex3[2] : D6 : output : 3.3-V LVTTL : : 2 : Y
+tdo : D7 : input : 3.3-V LVTTL : : 3 : Y
+tcs : D8 : input : 3.3-V LVTTL : : 3 : Y
+vga_r[0] : D9 : output : 3.3-V LVTTL : : 3 : Y
+GND : D10 : gnd : : : :
+vga_b[1] : D11 : output : 3.3-V LVTTL : : 3 : Y
+clock_27 : D12 : input : 3.3-V LVTTL : : 3 : Y
+GND : D13 : gnd : : : :
+gpio_1[11] : D14 : input : 3.3-V LVTTL : : 4 : Y
+gpio_1[12] : D15 : input : 3.3-V LVTTL : : 4 : Y
+gpio_1[13] : D16 : input : 3.3-V LVTTL : : 4 : Y
+VCCIO4 : D17 : power : : 3.3V : 4 :
+GND : D18 : gnd : : : :
+gpio_1[18] : D19 : input : 3.3-V LVTTL : : 5 : Y
+gpio_1[19] : D20 : input : 3.3-V LVTTL : : 5 : Y
+gpio_0[18] : D21 : input : 3.3-V LVTTL : : 5 : Y
+gpio_0[19] : D22 : input : 3.3-V LVTTL : : 5 : Y
+hex1[0] : E1 : output : 3.3-V LVTTL : : 2 : Y
+hex0[6] : E2 : output : 3.3-V LVTTL : : 2 : Y
+hex2[4] : E3 : output : 3.3-V LVTTL : : 2 : Y
+hex2[5] : E4 : output : 3.3-V LVTTL : : 2 : Y
+VCCD_PLL3 : E5 : power : : 1.2V : :
+VCCA_PLL3 : E6 : power : : 1.2V : :
+RESERVED_INPUT : E7 : : : : 3 :
+tdi : E8 : input : 3.3-V LVTTL : : 3 : Y
+RESERVED_INPUT : E9 : : : : 3 :
+VCCIO3 : E10 : power : : 3.3V : 3 :
+RESERVED_INPUT : E11 : : : : 3 :
+GND+ : E12 : : : : 3 :
+VCCIO4 : E13 : power : : 3.3V : 4 :
+gpio_1[4] : E14 : input : 3.3-V LVTTL : : 4 : Y
+gpio_1[5] : E15 : input : 3.3-V LVTTL : : 4 : Y
+GNDA_PLL2 : E16 : gnd : : : :
+GND_PLL2 : E17 : gnd : : : :
+gpio_1[23] : E18 : input : 3.3-V LVTTL : : 5 : Y
+gpio_1[22] : E19 : input : 3.3-V LVTTL : : 5 : Y
+gpio_1[20] : E20 : input : 3.3-V LVTTL : : 5 : Y
+gpio_0[20] : E21 : input : 3.3-V LVTTL : : 5 : Y
+gpio_0[21] : E22 : input : 3.3-V LVTTL : : 5 : Y
+hex0[5] : F1 : output : 3.3-V LVTTL : : 2 : Y
+hex0[4] : F2 : output : 3.3-V LVTTL : : 2 : Y
+hex3[5] : F3 : output : 3.3-V LVTTL : : 2 : Y
+hex3[0] : F4 : output : 3.3-V LVTTL : : 2 : Y
+GND_PLL3 : F5 : gnd : : : :
+GND_PLL3 : F6 : gnd : : : :
+GNDA_PLL3 : F7 : gnd : : : :
+RESERVED_INPUT : F8 : : : : 3 :
+RESERVED_INPUT : F9 : : : : 3 :
+RESERVED_INPUT : F10 : : : : 3 :
+RESERVED_INPUT : F11 : : : : 3 :
+gpio_1[8] : F12 : input : 3.3-V LVTTL : : 4 : Y
+gpio_1[9] : F13 : input : 3.3-V LVTTL : : 4 : Y
+uart_rxd : F14 : input : 3.3-V LVTTL : : 4 : Y
+gpio_1[6] : F15 : input : 3.3-V LVTTL : : 4 : Y
+VCCA_PLL2 : F16 : power : : 1.2V : :
+VCCD_PLL2 : F17 : power : : 1.2V : :
+GND_PLL2 : F18 : gnd : : : :
+GND : F19 : gnd : : : :
+gpio_1[21] : F20 : input : 3.3-V LVTTL : : 5 : Y
+gpio_0[22] : F21 : input : 3.3-V LVTTL : : 5 : Y
+gpio_0[23] : F22 : input : 3.3-V LVTTL : : 5 : Y
+NC : G1 : : : : :
+NC : G2 : : : : :
+hex1[4] : G3 : output : 3.3-V LVTTL : : 2 : Y
+GND : G4 : gnd : : : :
+hex2[0] : G5 : output : 3.3-V LVTTL : : 2 : Y
+hex2[1] : G6 : output : 3.3-V LVTTL : : 2 : Y
+RESERVED_INPUT : G7 : : : : 3 :
+RESERVED_INPUT : G8 : : : : 3 :
+VCCIO3 : G9 : power : : 3.3V : 3 :
+GND : G10 : gnd : : : :
+RESERVED_INPUT : G11 : : : : 3 :
+uart_txd : G12 : output : 3.3-V LVTTL : : 4 : Y
+GND : G13 : gnd : : : :
+VCCIO4 : G14 : power : : 3.3V : 4 :
+gpio_1[3] : G15 : input : 3.3-V LVTTL : : 4 : Y
+gpio_1[7] : G16 : input : 3.3-V LVTTL : : 4 : Y
+gpio_1[26] : G17 : input : 3.3-V LVTTL : : 5 : Y
+gpio_1[25] : G18 : input : 3.3-V LVTTL : : 5 : Y
+VCCIO5 : G19 : power : : 3.3V : 5 :
+gpio_1[24] : G20 : input : 3.3-V LVTTL : : 5 : Y
+gpio_0[24] : G21 : input : 3.3-V LVTTL : : 5 : Y
+gpio_0[25] : G22 : input : 3.3-V LVTTL : : 5 : Y
+hex0[3] : H1 : output : 3.3-V LVTTL : : 2 : Y
+hex0[2] : H2 : output : 3.3-V LVTTL : : 2 : Y
+RESERVED_INPUT : H3 : : : : 2 :
+hex1[3] : H4 : output : 3.3-V LVTTL : : 2 : Y
+hex1[2] : H5 : output : 3.3-V LVTTL : : 2 : Y
+hex1[1] : H6 : output : 3.3-V LVTTL : : 2 : Y
+RESERVED_INPUT : H7 : : : : 3 :
+RESERVED_INPUT : H8 : : : : 3 :
+RESERVED_INPUT : H9 : : : : 3 :
+RESERVED_INPUT : H10 : : : : 3 :
+RESERVED_INPUT : H11 : : : : 3 :
+gpio_1[0] : H12 : input : 3.3-V LVTTL : : 4 : Y
+gpio_1[1] : H13 : input : 3.3-V LVTTL : : 4 : Y
+gpio_1[2] : H14 : input : 3.3-V LVTTL : : 4 : Y
+ps2_clk : H15 : bidir : 3.3-V LVTTL : : 4 : Y
+RESERVED_INPUT : H16 : : : : 5 :
+gpio_1[27] : H17 : input : 3.3-V LVTTL : : 5 : Y
+gpio_1[29] : H18 : input : 3.3-V LVTTL : : 5 : Y
+RESERVED_INPUT : H19 : : : : 5 :
+GND : H20 : gnd : : : :
+NC : H21 : : : : :
+NC : H22 : : : : :
+hex0[1] : J1 : output : 3.3-V LVTTL : : 2 : Y
+hex0[0] : J2 : output : 3.3-V LVTTL : : 2 : Y
+NC : J3 : : : : :
+hex3[3] : J4 : output : 3.3-V LVTTL : : 2 : Y
+NC : J5 : : : : :
+NC : J6 : : : : :
+VCCIO2 : J7 : power : : 3.3V : 2 :
+NC : J8 : : : : :
+NC : J9 : : : : :
+VCCINT : J10 : power : : 1.2V : :
+VCCINT : J11 : power : : 1.2V : :
+VCCINT : J12 : power : : 1.2V : :
+VCCINT : J13 : power : : 1.2V : :
+ps2_dat : J14 : bidir : 3.3-V LVTTL : : 4 : Y
+gpio_1[28] : J15 : input : 3.3-V LVTTL : : 5 : Y
+VCCIO5 : J16 : power : : 3.3V : 5 :
+RESERVED_INPUT : J17 : : : : 5 :
+gpio_0[32] : J18 : input : 3.3-V LVTTL : : 5 : Y
+gpio_0[30] : J19 : input : 3.3-V LVTTL : : 5 : Y
+gpio_0[31] : J20 : input : 3.3-V LVTTL : : 5 : Y
+gpio_0[26] : J21 : input : 3.3-V LVTTL : : 5 : Y
+gpio_0[27] : J22 : input : 3.3-V LVTTL : : 5 : Y
+nCE : K1 : : : : 2 :
+TCK : K2 : input : : : 2 :
+GND : K3 : gnd : : : :
+DATA0 : K4 : input : : : 2 :
+TDI : K5 : input : : : 2 :
+TMS : K6 : input : : : 2 :
+GND : K7 : gnd : : : :
+NC : K8 : : : : :
+VCCINT : K9 : power : : 1.2V : :
+GND : K10 : gnd : : : :
+GND : K11 : gnd : : : :
+GND : K12 : gnd : : : :
+GND : K13 : gnd : : : :
+VCCINT : K14 : power : : 1.2V : :
+NC : K15 : : : : :
+GND : K16 : gnd : : : :
+NC : K17 : : : : :
+NC : K18 : : : : :
+GND : K19 : gnd : : : :
+gpio_0[33] : K20 : input : 3.3-V LVTTL : : 5 : Y
+gpio_0[28] : K21 : input : 3.3-V LVTTL : : 5 : Y
+gpio_0[29] : K22 : input : 3.3-V LVTTL : : 5 : Y
+clock_50 : L1 : input : 3.3-V LVTTL : : 2 : Y
+sw[9] : L2 : input : 3.3-V LVTTL : : 2 : Y
+VCCIO2 : L3 : power : : 3.3V : 2 :
+nCONFIG : L4 : : : : 2 :
+TDO : L5 : output : : : 2 :
+DCLK : L6 : : : : 2 :
+NC : L7 : : : : :
+hex3[4] : L8 : output : 3.3-V LVTTL : : 2 : Y
+VCCINT : L9 : power : : 1.2V : :
+GND : L10 : gnd : : : :
+GND : L11 : gnd : : : :
+GND : L12 : gnd : : : :
+GND : L13 : gnd : : : :
+VCCINT : L14 : power : : 1.2V : :
+NC : L15 : : : : :
+NC : L16 : : : : :
+NC : L17 : : : : :
+gpio_0[35] : L18 : input : 3.3-V LVTTL : : 5 : Y
+gpio_0[34] : L19 : input : 3.3-V LVTTL : : 5 : Y
+VCCIO5 : L20 : power : : 3.3V : 5 :
+sw[1] : L21 : input : 3.3-V LVTTL : : 5 : Y
+sw[0] : L22 : input : 3.3-V LVTTL : : 5 : Y
+sw[8] : M1 : input : 3.3-V LVTTL : : 1 : Y
+sw[7] : M2 : input : 3.3-V LVTTL : : 1 : Y
+VCCIO1 : M3 : power : : 3.3V : 1 :
+GND : M4 : gnd : : : :
+dram_udqm : M5 : input : 3.3-V LVTTL : : 1 : Y
+RESERVED_INPUT : M6 : : : : 1 :
+NC : M7 : : : : :
+NC : M8 : : : : :
+VCCINT : M9 : power : : 1.2V : :
+GND : M10 : gnd : : : :
+GND : M11 : gnd : : : :
+GND : M12 : gnd : : : :
+GND : M13 : gnd : : : :
+VCCINT : M14 : power : : 1.2V : :
+NC : M15 : : : : :
+NC : M16 : : : : :
+MSEL0 : M17 : : : : 6 :
+RESERVED_INPUT : M18 : : : : 6 :
+RESERVED_INPUT : M19 : : : : 6 :
+VCCIO6 : M20 : power : : 3.3V : 6 :
+ext_clock : M21 : input : 3.3-V LVTTL : : 6 : Y
+sw[2] : M22 : input : 3.3-V LVTTL : : 6 : Y
+dram_dq[8] : N1 : input : 3.3-V LVTTL : : 1 : Y
+dram_dq[9] : N2 : input : 3.3-V LVTTL : : 1 : Y
+dram_cke : N3 : input : 3.3-V LVTTL : : 1 : Y
+dram_addr[9] : N4 : output : 3.3-V LVTTL : : 1 : Y
+NC : N5 : : : : :
+dram_addr[11] : N6 : output : 3.3-V LVTTL : : 1 : Y
+GND : N7 : gnd : : : :
+NC : N8 : : : : :
+VCCINT : N9 : power : : 1.2V : :
+GND : N10 : gnd : : : :
+GND : N11 : gnd : : : :
+GND : N12 : gnd : : : :
+GND : N13 : gnd : : : :
+VCCINT : N14 : power : : 1.2V : :
+gpio_1[33] : N15 : input : 3.3-V LVTTL : : 6 : Y
+GND : N16 : gnd : : : :
+MSEL1 : N17 : : : : 6 :
+CONF_DONE : N18 : : : : 6 :
+GND : N19 : gnd : : : :
+nSTATUS : N20 : : : : 6 :
+gpio_1[31] : N21 : input : 3.3-V LVTTL : : 6 : Y
+gpio_1[30] : N22 : input : 3.3-V LVTTL : : 6 : Y
+dram_dq[10] : P1 : input : 3.3-V LVTTL : : 1 : Y
+dram_dq[11] : P2 : input : 3.3-V LVTTL : : 1 : Y
+dram_addr[8] : P3 : output : 3.3-V LVTTL : : 1 : Y
+NC : P4 : : : : :
+dram_addr[7] : P5 : output : 3.3-V LVTTL : : 1 : Y
+dram_addr[6] : P6 : output : 3.3-V LVTTL : : 1 : Y
+VCCIO1 : P7 : power : : 3.3V : 1 :
+RESERVED_INPUT : P8 : : : : 8 :
+RESERVED_INPUT : P9 : : : : 8 :
+VCCINT : P10 : power : : 1.2V : :
+VCCINT : P11 : power : : 1.2V : :
+VCCINT : P12 : power : : 1.2V : :
+VCCINT : P13 : power : : 1.2V : :
+NC : P14 : : : : :
+gpio_1[32] : P15 : input : 3.3-V LVTTL : : 6 : Y
+VCCIO6 : P16 : power : : 3.3V : 6 :
+gpio_1[34] : P17 : input : 3.3-V LVTTL : : 6 : Y
+gpio_1[35] : P18 : input : 3.3-V LVTTL : : 6 : Y
+NC : P19 : : : : :
+NC : P20 : : : : :
+NC : P21 : : : : :
+NC : P22 : : : : :
+dram_dq[12] : R1 : input : 3.3-V LVTTL : : 1 : Y
+dram_dq[13] : R2 : input : 3.3-V LVTTL : : 1 : Y
+GND : R3 : gnd : : : :
+NC : R4 : : : : :
+dram_addr[5] : R5 : output : 3.3-V LVTTL : : 1 : Y
+dram_addr[4] : R6 : output : 3.3-V LVTTL : : 1 : Y
+dram_ldqm : R7 : input : 3.3-V LVTTL : : 1 : Y
+dram_we_n : R8 : output : 3.3-V LVTTL : : 1 : Y
+sram_dq[12] : R9 : bidir : 3.3-V LVTTL : : 8 : Y
+sram_addr[14] : R10 : output : 3.3-V LVTTL : : 8 : Y
+sram_addr[10] : R11 : output : 3.3-V LVTTL : : 8 : Y
+fl_addr[10] : R12 : output : 3.3-V LVTTL : : 7 : Y
+fl_addr[21] : R13 : output : 3.3-V LVTTL : : 7 : Y
+fl_addr[8] : R14 : output : 3.3-V LVTTL : : 7 : Y
+fl_addr[3] : R15 : output : 3.3-V LVTTL : : 7 : Y
+RESERVED_INPUT : R16 : : : : 7 :
+ledr[9] : R17 : output : 3.3-V LVTTL : : 6 : Y
+ledr[8] : R18 : output : 3.3-V LVTTL : : 6 : Y
+ledr[1] : R19 : output : 3.3-V LVTTL : : 6 : Y
+ledr[0] : R20 : output : 3.3-V LVTTL : : 6 : Y
+key[1] : R21 : input : 3.3-V LVTTL : : 6 : Y
+key[0] : R22 : input : 3.3-V LVTTL : : 6 : Y
+dram_dq[14] : T1 : input : 3.3-V LVTTL : : 1 : Y
+dram_dq[15] : T2 : input : 3.3-V LVTTL : : 1 : Y
+dram_cas_n : T3 : output : 3.3-V LVTTL : : 1 : Y
+VCCIO1 : T4 : power : : 3.3V : 1 :
+dram_ras_n : T5 : output : 3.3-V LVTTL : : 1 : Y
+dram_cs_n : T6 : output : 3.3-V LVTTL : : 1 : Y
+sram_addr[15] : T7 : output : 3.3-V LVTTL : : 8 : Y
+sram_oe_n : T8 : output : 3.3-V LVTTL : : 8 : Y
+VCCIO8 : T9 : power : : 3.3V : 8 :
+GND : T10 : gnd : : : :
+sram_addr[11] : T11 : output : 3.3-V LVTTL : : 8 : Y
+fl_addr[11] : T12 : output : 3.3-V LVTTL : : 7 : Y
+GND : T13 : gnd : : : :
+VCCIO7 : T14 : power : : 3.3V : 7 :
+fl_addr[4] : T15 : output : 3.3-V LVTTL : : 7 : Y
+RESERVED_INPUT : T16 : : : : 7 :
+GND_PLL4 : T17 : gnd : : : :
+ledr[4] : T18 : output : 3.3-V LVTTL : : 6 : Y
+VCCIO6 : T19 : power : : 3.3V : 6 :
+GND : T20 : gnd : : : :
+key[3] : T21 : input : 3.3-V LVTTL : : 6 : Y
+key[2] : T22 : input : 3.3-V LVTTL : : 6 : Y
+dram_dq[0] : U1 : input : 3.3-V LVTTL : : 1 : Y
+dram_dq[1] : U2 : input : 3.3-V LVTTL : : 1 : Y
+dram_ba_0 : U3 : input : 3.3-V LVTTL : : 1 : Y
+dram_clk : U4 : input : 3.3-V LVTTL : : 1 : Y
+GND_PLL1 : U5 : gnd : : : :
+VCCD_PLL1 : U6 : power : : 1.2V : :
+VCCA_PLL1 : U7 : power : : 1.2V : :
+sram_dq[15] : U8 : bidir : 3.3-V LVTTL : : 8 : Y
+sram_dq[11] : U9 : bidir : 3.3-V LVTTL : : 8 : Y
+sram_addr[13] : U10 : output : 3.3-V LVTTL : : 8 : Y
+sw[6] : U11 : input : 3.3-V LVTTL : : 8 : Y
+sw[5] : U12 : input : 3.3-V LVTTL : : 8 : Y
+fl_addr[20] : U13 : output : 3.3-V LVTTL : : 7 : Y
+fl_addr[18] : U14 : output : 3.3-V LVTTL : : 7 : Y
+fl_addr[5] : U15 : output : 3.3-V LVTTL : : 7 : Y
+VCCA_PLL4 : U16 : power : : 1.2V : :
+VCCD_PLL4 : U17 : power : : 1.2V : :
+ledr[7] : U18 : output : 3.3-V LVTTL : : 6 : Y
+ledr[2] : U19 : output : 3.3-V LVTTL : : 6 : Y
+RESERVED_INPUT : U20 : : : : 6 :
+ledg[1] : U21 : output : 3.3-V LVTTL : : 6 : Y
+ledg[0] : U22 : output : 3.3-V LVTTL : : 6 : Y
+dram_dq[2] : V1 : input : 3.3-V LVTTL : : 1 : Y
+dram_dq[3] : V2 : input : 3.3-V LVTTL : : 1 : Y
+GND : V3 : gnd : : : :
+dram_ba_1 : V4 : input : 3.3-V LVTTL : : 1 : Y
+GND_PLL1 : V5 : gnd : : : :
+GND : V6 : gnd : : : :
+GNDA_PLL1 : V7 : gnd : : : :
+sram_dq[14] : V8 : bidir : 3.3-V LVTTL : : 8 : Y
+sram_dq[10] : V9 : bidir : 3.3-V LVTTL : : 8 : Y
+VCCIO8 : V10 : power : : 3.3V : 8 :
+sram_addr[8] : V11 : output : 3.3-V LVTTL : : 8 : Y
+sw[3] : V12 : input : 3.3-V LVTTL : : 7 : Y
+VCCIO7 : V13 : power : : 3.3V : 7 :
+fl_addr[19] : V14 : output : 3.3-V LVTTL : : 7 : Y
+fl_addr[6] : V15 : output : 3.3-V LVTTL : : 7 : Y
+GNDA_PLL4 : V16 : gnd : : : :
+GND : V17 : gnd : : : :
+GND_PLL4 : V18 : gnd : : : :
+ledr[5] : V19 : output : 3.3-V LVTTL : : 6 : Y
+RESERVED_INPUT : V20 : : : : 6 :
+ledg[3] : V21 : output : 3.3-V LVTTL : : 6 : Y
+ledg[2] : V22 : output : 3.3-V LVTTL : : 6 : Y
+dram_dq[4] : W1 : input : 3.3-V LVTTL : : 1 : Y
+dram_dq[5] : W2 : input : 3.3-V LVTTL : : 1 : Y
+dram_addr[10] : W3 : output : 3.3-V LVTTL : : 1 : Y
+dram_addr[0] : W4 : output : 3.3-V LVTTL : : 1 : Y
+dram_addr[1] : W5 : output : 3.3-V LVTTL : : 1 : Y
+VCCIO8 : W6 : power : : 3.3V : 8 :
+sram_ub_n : W7 : output : 3.3-V LVTTL : : 8 : Y
+sram_dq[13] : W8 : bidir : 3.3-V LVTTL : : 8 : Y
+sram_dq[9] : W9 : bidir : 3.3-V LVTTL : : 8 : Y
+GND : W10 : gnd : : : :
+sram_addr[9] : W11 : output : 3.3-V LVTTL : : 8 : Y
+sw[4] : W12 : input : 3.3-V LVTTL : : 7 : Y
+GND : W13 : gnd : : : :
+fl_rst_n : W14 : input : 3.3-V LVTTL : : 7 : Y
+fl_addr[7] : W15 : output : 3.3-V LVTTL : : 7 : Y
+RESERVED_INPUT : W16 : : : : 7 :
+VCCIO7 : W17 : power : : 3.3V : 7 :
+NC : W18 : : : : :
+GND : W19 : gnd : : : :
+RESERVED_INPUT : W20 : : : : 6 :
+ledg[5] : W21 : output : 3.3-V LVTTL : : 6 : Y
+ledg[4] : W22 : output : 3.3-V LVTTL : : 6 : Y
+dram_dq[6] : Y1 : input : 3.3-V LVTTL : : 1 : Y
+dram_dq[7] : Y2 : input : 3.3-V LVTTL : : 1 : Y
+dram_addr[2] : Y3 : output : 3.3-V LVTTL : : 1 : Y
+dram_addr[3] : Y4 : output : 3.3-V LVTTL : : 1 : Y
+sram_addr[17] : Y5 : output : 3.3-V LVTTL : : 8 : Y
+sram_addr[16] : Y6 : output : 3.3-V LVTTL : : 8 : Y
+sram_lb_n : Y7 : output : 3.3-V LVTTL : : 8 : Y
+GND : Y8 : gnd : : : :
+sram_dq[8] : Y9 : bidir : 3.3-V LVTTL : : 8 : Y
+sram_addr[12] : Y10 : output : 3.3-V LVTTL : : 8 : Y
+VCCIO8 : Y11 : power : : 3.3V : 8 :
+VCCIO7 : Y12 : power : : 3.3V : 7 :
+fl_addr[9] : Y13 : output : 3.3-V LVTTL : : 7 : Y
+fl_we_n : Y14 : output : 3.3-V LVTTL : : 7 : Y
+GND : Y15 : gnd : : : :
+fl_addr[2] : Y16 : output : 3.3-V LVTTL : : 7 : Y
+RESERVED_INPUT : Y17 : : : : 7 :
+ledr[6] : Y18 : output : 3.3-V LVTTL : : 6 : Y
+ledr[3] : Y19 : output : 3.3-V LVTTL : : 6 : Y
+RESERVED_INPUT : Y20 : : : : 6 :
+ledg[7] : Y21 : output : 3.3-V LVTTL : : 6 : Y
+ledg[6] : Y22 : output : 3.3-V LVTTL : : 6 : Y
Index: System09_Terasic_DE1/system09.qpf
===================================================================
--- System09_Terasic_DE1/system09.qpf (nonexistent)
+++ System09_Terasic_DE1/system09.qpf (revision 117)
@@ -0,0 +1,23 @@
+# Copyright (C) 1991-2005 Altera Corporation
+# Your use of Altera Corporation's design tools, logic functions
+# and other software and tools, and its AMPP partner logic
+# functions, and any output files any of the foregoing
+# (including device programming or simulation files), and any
+# associated documentation or information are expressly subject
+# to the terms and conditions of the Altera Program License
+# Subscription Agreement, Altera MegaCore Function License
+# Agreement, or other applicable license agreement, including,
+# without limitation, that your use is for the sole purpose of
+# programming logic devices manufactured by Altera and sold by
+# Altera or its authorized distributors. Please refer to the
+# applicable agreement for further details.
+
+
+
+QUARTUS_VERSION = "5.0"
+DATE = "19:21:54 August 25, 2005"
+
+
+# Revisions
+
+PROJECT_REVISION = "system09"
Index: System09_Terasic_DE1/system09.sof
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream
Index: System09_Terasic_DE1/system09.sof
===================================================================
--- System09_Terasic_DE1/system09.sof (nonexistent)
+++ System09_Terasic_DE1/system09.sof (revision 117)
System09_Terasic_DE1/system09.sof
Property changes :
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: System09_Terasic_DE1/system09.qsf
===================================================================
--- System09_Terasic_DE1/system09.qsf (nonexistent)
+++ System09_Terasic_DE1/system09.qsf (revision 117)
@@ -0,0 +1,544 @@
+# copyright (c) 1991-2005 altera corporation
+# your use of altera corporation's design tools, logic functions
+# and other software and tools, and its ampp partner logic
+# functions, and any output files any of the foregoing
+# (including device programming or simulation files), and any
+# associated documentation or information are expressly subject
+# to the terms and conditions of the altera program license
+# subscription agreement, altera megacore function license
+# agreement, or other applicable license agreement, including,
+# without limitation, that your use is for the sole purpose of
+# programming logic devices manufactured by altera and sold by
+# altera or its authorized distributors. please refer to the
+# applicable agreement for further details.
+
+
+# the default values for assignments are stored in the file
+# system09_assignment_defaults.qdf
+# if this file doesn't exist, and for assignments not listed, see file
+# assignment_defaults.qdf
+
+# altera recommends that you do not modify this file. this
+# file is updated automatically by the quartus ii software
+# and any changes you make may be lost or overwritten.
+
+
+# project-wide assignments
+# ========================
+set_global_assignment -name LAST_QUARTUS_VERSION "9.1 SP1"
+
+# pin & location assignments
+# ==========================
+
+# analysis & synthesis assignments
+# ================================
+set_global_assignment -name FAMILY "cyclone ii"
+set_global_assignment -name TOP_LEVEL_ENTITY System09_Terasic_DE1
+
+# fitter assignments
+# ==================
+set_global_assignment -name DEVICE ep2c20f484c7
+set_global_assignment -name CYCLONEII_RESERVE_NCEO_AFTER_CONFIGURATION "USE AS REGULAR IO"
+set_global_assignment -name RESERVE_ALL_UNUSED_PINS "AS INPUT TRI-STATED"
+set_global_assignment -name RESERVE_ASDO_AFTER_CONFIGURATION "AS INPUT TRI-STATED"
+
+# assembler assignments
+# =====================
+set_global_assignment -name RESERVE_ALL_UNUSED_PINS_NO_OUTPUT_GND "AS OUTPUT DRIVING AN UNSPECIFIED SIGNAL"
+
+set_global_assignment -name SEED 1
+set_instance_assignment -name IO_STANDARD LVTTL -to aud_adcdat
+set_instance_assignment -name IO_STANDARD LVTTL -to aud_adclrck
+set_instance_assignment -name IO_STANDARD LVTTL -to aud_bclk
+set_instance_assignment -name IO_STANDARD LVTTL -to aud_dacdat
+set_instance_assignment -name IO_STANDARD LVTTL -to aud_daclrck
+set_instance_assignment -name IO_STANDARD LVTTL -to aud_xck
+set_instance_assignment -name IO_STANDARD LVTTL -to clock_24[0]
+set_instance_assignment -name IO_STANDARD LVTTL -to clock_24[1]
+# set_instance_assignment -name io_standard lvttl -to clock_27[1]
+set_instance_assignment -name IO_STANDARD LVTTL -to clock_50
+set_instance_assignment -name IO_STANDARD LVTTL -to ext_clock
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[0]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[10]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[11]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[12]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[13]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[14]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[15]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[16]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[17]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[18]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[19]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[1]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[20]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[21]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[22]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[23]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[24]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[25]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[26]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[27]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[28]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[29]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[2]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[30]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[31]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[32]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[33]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[34]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[35]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[3]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[4]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[5]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[6]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[7]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[8]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_0[9]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[0]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[10]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[11]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[12]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[13]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[14]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[15]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[16]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[17]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[18]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[19]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[1]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[20]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[21]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[22]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[23]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[24]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[25]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[26]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[27]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[28]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[29]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[2]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[30]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[31]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[32]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[33]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[34]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[35]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[3]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[4]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[5]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[6]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[7]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[8]
+set_instance_assignment -name IO_STANDARD LVTTL -to gpio_1[9]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex0[0]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex0[1]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex0[2]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex0[3]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex0[4]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex0[5]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex0[6]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex1[0]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex1[1]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex1[2]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex1[3]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex1[4]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex1[5]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex1[6]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex2[0]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex2[1]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex2[2]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex2[3]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex2[4]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex2[5]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex2[6]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex3[0]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex3[1]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex3[2]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex3[3]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex3[4]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex3[5]
+set_instance_assignment -name IO_STANDARD LVTTL -to hex3[6]
+set_instance_assignment -name IO_STANDARD LVTTL -to i2c_sclk
+set_instance_assignment -name IO_STANDARD LVTTL -to i2c_sdat
+set_instance_assignment -name IO_STANDARD LVTTL -to key[0]
+set_instance_assignment -name IO_STANDARD LVTTL -to key[1]
+set_instance_assignment -name IO_STANDARD LVTTL -to key[2]
+set_instance_assignment -name IO_STANDARD LVTTL -to key[3]
+set_instance_assignment -name IO_STANDARD LVTTL -to ledg[0]
+set_instance_assignment -name IO_STANDARD LVTTL -to ledg[1]
+set_instance_assignment -name IO_STANDARD LVTTL -to ledg[2]
+set_instance_assignment -name IO_STANDARD LVTTL -to ledg[3]
+set_instance_assignment -name IO_STANDARD LVTTL -to ledg[4]
+set_instance_assignment -name IO_STANDARD LVTTL -to ledg[5]
+set_instance_assignment -name IO_STANDARD LVTTL -to ledg[6]
+set_instance_assignment -name IO_STANDARD LVTTL -to ledg[7]
+set_instance_assignment -name IO_STANDARD LVTTL -to ledr[0]
+set_instance_assignment -name IO_STANDARD LVTTL -to ledr[1]
+set_instance_assignment -name IO_STANDARD LVTTL -to ledr[2]
+set_instance_assignment -name IO_STANDARD LVTTL -to ledr[3]
+set_instance_assignment -name IO_STANDARD LVTTL -to ledr[4]
+set_instance_assignment -name IO_STANDARD LVTTL -to ledr[5]
+set_instance_assignment -name IO_STANDARD LVTTL -to ledr[6]
+set_instance_assignment -name IO_STANDARD LVTTL -to ledr[7]
+set_instance_assignment -name IO_STANDARD LVTTL -to ledr[8]
+set_instance_assignment -name IO_STANDARD LVTTL -to ledr[9]
+set_instance_assignment -name IO_STANDARD LVTTL -to ps2_clk
+set_instance_assignment -name IO_STANDARD LVTTL -to ps2_dat
+set_instance_assignment -name IO_STANDARD LVTTL -to sw[0]
+set_instance_assignment -name IO_STANDARD LVTTL -to sw[1]
+set_instance_assignment -name IO_STANDARD LVTTL -to sw[2]
+set_instance_assignment -name IO_STANDARD LVTTL -to sw[3]
+set_instance_assignment -name IO_STANDARD LVTTL -to sw[4]
+set_instance_assignment -name IO_STANDARD LVTTL -to sw[5]
+set_instance_assignment -name IO_STANDARD LVTTL -to sw[6]
+set_instance_assignment -name IO_STANDARD LVTTL -to sw[7]
+set_instance_assignment -name IO_STANDARD LVTTL -to sw[8]
+set_instance_assignment -name IO_STANDARD LVTTL -to sw[9]
+set_instance_assignment -name IO_STANDARD LVTTL -to tck
+set_instance_assignment -name IO_STANDARD LVTTL -to tcs
+set_instance_assignment -name IO_STANDARD LVTTL -to tdi
+set_instance_assignment -name IO_STANDARD LVTTL -to tdo
+set_instance_assignment -name IO_STANDARD LVTTL -to uart_rxd
+set_instance_assignment -name IO_STANDARD LVTTL -to uart_txd
+set_instance_assignment -name IO_STANDARD LVTTL -to vga_b[0]
+set_instance_assignment -name IO_STANDARD LVTTL -to vga_b[1]
+set_instance_assignment -name IO_STANDARD LVTTL -to vga_b[2]
+set_instance_assignment -name IO_STANDARD LVTTL -to vga_b[3]
+set_instance_assignment -name IO_STANDARD LVTTL -to vga_g[0]
+set_instance_assignment -name IO_STANDARD LVTTL -to vga_g[1]
+set_instance_assignment -name IO_STANDARD LVTTL -to vga_g[2]
+set_instance_assignment -name IO_STANDARD LVTTL -to vga_g[3]
+set_instance_assignment -name IO_STANDARD LVTTL -to vga_hs
+set_instance_assignment -name IO_STANDARD LVTTL -to vga_r[0]
+set_instance_assignment -name IO_STANDARD LVTTL -to vga_r[1]
+set_instance_assignment -name IO_STANDARD LVTTL -to vga_r[2]
+set_instance_assignment -name IO_STANDARD LVTTL -to vga_r[3]
+set_instance_assignment -name IO_STANDARD LVTTL -to vga_vs
+set_location_assignment PIN_B6 -to aud_adcdat
+set_location_assignment PIN_A6 -to aud_adclrck
+set_location_assignment PIN_A4 -to aud_bclk
+set_location_assignment PIN_B5 -to aud_dacdat
+set_location_assignment PIN_A5 -to aud_daclrck
+set_location_assignment PIN_B4 -to aud_xck
+set_location_assignment PIN_B12 -to clock_24[0]
+set_location_assignment PIN_A12 -to clock_24[1]
+set_location_assignment PIN_D12 -to clock_27
+# set_location_assignment pin_e12 -to clock_27[1]
+set_location_assignment PIN_L1 -to clock_50
+set_location_assignment PIN_W4 -to dram_addr[0]
+set_location_assignment PIN_W3 -to dram_addr[10]
+set_location_assignment PIN_N6 -to dram_addr[11]
+set_location_assignment PIN_W5 -to dram_addr[1]
+set_location_assignment PIN_Y3 -to dram_addr[2]
+set_location_assignment PIN_Y4 -to dram_addr[3]
+set_location_assignment PIN_R6 -to dram_addr[4]
+set_location_assignment PIN_R5 -to dram_addr[5]
+set_location_assignment PIN_P6 -to dram_addr[6]
+set_location_assignment PIN_P5 -to dram_addr[7]
+set_location_assignment PIN_P3 -to dram_addr[8]
+set_location_assignment PIN_N4 -to dram_addr[9]
+set_location_assignment PIN_U3 -to dram_ba_0
+set_location_assignment PIN_V4 -to dram_ba_1
+set_location_assignment PIN_T3 -to dram_cas_n
+set_location_assignment PIN_N3 -to dram_cke
+set_location_assignment PIN_U4 -to dram_clk
+set_location_assignment PIN_T6 -to dram_cs_n
+set_location_assignment PIN_U1 -to dram_dq[0]
+set_location_assignment PIN_P1 -to dram_dq[10]
+set_location_assignment PIN_P2 -to dram_dq[11]
+set_location_assignment PIN_R1 -to dram_dq[12]
+set_location_assignment PIN_R2 -to dram_dq[13]
+set_location_assignment PIN_T1 -to dram_dq[14]
+set_location_assignment PIN_T2 -to dram_dq[15]
+set_location_assignment PIN_U2 -to dram_dq[1]
+set_location_assignment PIN_V1 -to dram_dq[2]
+set_location_assignment PIN_V2 -to dram_dq[3]
+set_location_assignment PIN_W1 -to dram_dq[4]
+set_location_assignment PIN_W2 -to dram_dq[5]
+set_location_assignment PIN_Y1 -to dram_dq[6]
+set_location_assignment PIN_Y2 -to dram_dq[7]
+set_location_assignment PIN_N1 -to dram_dq[8]
+set_location_assignment PIN_N2 -to dram_dq[9]
+set_location_assignment PIN_R7 -to dram_ldqm
+set_location_assignment PIN_T5 -to dram_ras_n
+set_location_assignment PIN_M5 -to dram_udqm
+set_location_assignment PIN_R8 -to dram_we_n
+set_location_assignment PIN_M21 -to ext_clock
+set_location_assignment PIN_AB20 -to fl_addr[0]
+set_location_assignment PIN_R12 -to fl_addr[10]
+set_location_assignment PIN_T12 -to fl_addr[11]
+set_location_assignment PIN_AB14 -to fl_addr[12]
+set_location_assignment PIN_AA13 -to fl_addr[13]
+set_location_assignment PIN_AB13 -to fl_addr[14]
+set_location_assignment PIN_AA12 -to fl_addr[15]
+set_location_assignment PIN_AB12 -to fl_addr[16]
+set_location_assignment PIN_AA20 -to fl_addr[17]
+set_location_assignment PIN_U14 -to fl_addr[18]
+set_location_assignment PIN_V14 -to fl_addr[19]
+set_location_assignment PIN_AA14 -to fl_addr[1]
+set_location_assignment PIN_U13 -to fl_addr[20]
+set_location_assignment PIN_R13 -to fl_addr[21]
+set_location_assignment PIN_Y16 -to fl_addr[2]
+set_location_assignment PIN_R15 -to fl_addr[3]
+set_location_assignment PIN_T15 -to fl_addr[4]
+set_location_assignment PIN_U15 -to fl_addr[5]
+set_location_assignment PIN_V15 -to fl_addr[6]
+set_location_assignment PIN_W15 -to fl_addr[7]
+set_location_assignment PIN_R14 -to fl_addr[8]
+set_location_assignment PIN_Y13 -to fl_addr[9]
+set_location_assignment PIN_AB16 -to fl_dq[0]
+set_location_assignment PIN_AA16 -to fl_dq[1]
+set_location_assignment PIN_AB17 -to fl_dq[2]
+set_location_assignment PIN_AA17 -to fl_dq[3]
+set_location_assignment PIN_AB18 -to fl_dq[4]
+set_location_assignment PIN_AA18 -to fl_dq[5]
+set_location_assignment PIN_AB19 -to fl_dq[6]
+set_location_assignment PIN_AA19 -to fl_dq[7]
+set_location_assignment PIN_AA15 -to fl_oe_n
+set_location_assignment PIN_W14 -to fl_rst_n
+set_location_assignment PIN_Y14 -to fl_we_n
+set_location_assignment PIN_A13 -to gpio_0[0]
+set_location_assignment PIN_A18 -to gpio_0[10]
+set_location_assignment PIN_B18 -to gpio_0[11]
+set_location_assignment PIN_A19 -to gpio_0[12]
+set_location_assignment PIN_B19 -to gpio_0[13]
+set_location_assignment PIN_A20 -to gpio_0[14]
+set_location_assignment PIN_B20 -to gpio_0[15]
+set_location_assignment PIN_C21 -to gpio_0[16]
+set_location_assignment PIN_C22 -to gpio_0[17]
+set_location_assignment PIN_D21 -to gpio_0[18]
+set_location_assignment PIN_D22 -to gpio_0[19]
+set_location_assignment PIN_B13 -to gpio_0[1]
+set_location_assignment PIN_E21 -to gpio_0[20]
+set_location_assignment PIN_E22 -to gpio_0[21]
+set_location_assignment PIN_F21 -to gpio_0[22]
+set_location_assignment PIN_F22 -to gpio_0[23]
+set_location_assignment PIN_G21 -to gpio_0[24]
+set_location_assignment PIN_G22 -to gpio_0[25]
+set_location_assignment PIN_J21 -to gpio_0[26]
+set_location_assignment PIN_J22 -to gpio_0[27]
+set_location_assignment PIN_K21 -to gpio_0[28]
+set_location_assignment PIN_K22 -to gpio_0[29]
+set_location_assignment PIN_A14 -to gpio_0[2]
+set_location_assignment PIN_J19 -to gpio_0[30]
+set_location_assignment PIN_J20 -to gpio_0[31]
+set_location_assignment PIN_J18 -to gpio_0[32]
+set_location_assignment PIN_K20 -to gpio_0[33]
+set_location_assignment PIN_L19 -to gpio_0[34]
+set_location_assignment PIN_L18 -to gpio_0[35]
+set_location_assignment PIN_B14 -to gpio_0[3]
+set_location_assignment PIN_A15 -to gpio_0[4]
+set_location_assignment PIN_B15 -to gpio_0[5]
+set_location_assignment PIN_A16 -to gpio_0[6]
+set_location_assignment PIN_B16 -to gpio_0[7]
+set_location_assignment PIN_A17 -to gpio_0[8]
+set_location_assignment PIN_B17 -to gpio_0[9]
+set_location_assignment PIN_H12 -to gpio_1[0]
+set_location_assignment PIN_C14 -to gpio_1[10]
+set_location_assignment PIN_D14 -to gpio_1[11]
+set_location_assignment PIN_D15 -to gpio_1[12]
+set_location_assignment PIN_D16 -to gpio_1[13]
+set_location_assignment PIN_C17 -to gpio_1[14]
+set_location_assignment PIN_C18 -to gpio_1[15]
+set_location_assignment PIN_C19 -to gpio_1[16]
+set_location_assignment PIN_C20 -to gpio_1[17]
+set_location_assignment PIN_D19 -to gpio_1[18]
+set_location_assignment PIN_D20 -to gpio_1[19]
+set_location_assignment PIN_H13 -to gpio_1[1]
+set_location_assignment PIN_E20 -to gpio_1[20]
+set_location_assignment PIN_F20 -to gpio_1[21]
+set_location_assignment PIN_E19 -to gpio_1[22]
+set_location_assignment PIN_E18 -to gpio_1[23]
+set_location_assignment PIN_G20 -to gpio_1[24]
+set_location_assignment PIN_G18 -to gpio_1[25]
+set_location_assignment PIN_G17 -to gpio_1[26]
+set_location_assignment PIN_H17 -to gpio_1[27]
+set_location_assignment PIN_J15 -to gpio_1[28]
+set_location_assignment PIN_H18 -to gpio_1[29]
+set_location_assignment PIN_H14 -to gpio_1[2]
+set_location_assignment PIN_N22 -to gpio_1[30]
+set_location_assignment PIN_N21 -to gpio_1[31]
+set_location_assignment PIN_P15 -to gpio_1[32]
+set_location_assignment PIN_N15 -to gpio_1[33]
+set_location_assignment PIN_P17 -to gpio_1[34]
+set_location_assignment PIN_P18 -to gpio_1[35]
+set_location_assignment PIN_G15 -to gpio_1[3]
+set_location_assignment PIN_E14 -to gpio_1[4]
+set_location_assignment PIN_E15 -to gpio_1[5]
+set_location_assignment PIN_F15 -to gpio_1[6]
+set_location_assignment PIN_G16 -to gpio_1[7]
+set_location_assignment PIN_F12 -to gpio_1[8]
+set_location_assignment PIN_F13 -to gpio_1[9]
+set_location_assignment PIN_J2 -to hex0[0]
+set_location_assignment PIN_J1 -to hex0[1]
+set_location_assignment PIN_H2 -to hex0[2]
+set_location_assignment PIN_H1 -to hex0[3]
+set_location_assignment PIN_F2 -to hex0[4]
+set_location_assignment PIN_F1 -to hex0[5]
+set_location_assignment PIN_E2 -to hex0[6]
+set_location_assignment PIN_E1 -to hex1[0]
+set_location_assignment PIN_H6 -to hex1[1]
+set_location_assignment PIN_H5 -to hex1[2]
+set_location_assignment PIN_H4 -to hex1[3]
+set_location_assignment PIN_G3 -to hex1[4]
+set_location_assignment PIN_D2 -to hex1[5]
+set_location_assignment PIN_D1 -to hex1[6]
+set_location_assignment PIN_G5 -to hex2[0]
+set_location_assignment PIN_G6 -to hex2[1]
+set_location_assignment PIN_C2 -to hex2[2]
+set_location_assignment PIN_C1 -to hex2[3]
+set_location_assignment PIN_E3 -to hex2[4]
+set_location_assignment PIN_E4 -to hex2[5]
+set_location_assignment PIN_D3 -to hex2[6]
+set_location_assignment PIN_F4 -to hex3[0]
+set_location_assignment PIN_D5 -to hex3[1]
+set_location_assignment PIN_D6 -to hex3[2]
+set_location_assignment PIN_J4 -to hex3[3]
+set_location_assignment PIN_L8 -to hex3[4]
+set_location_assignment PIN_F3 -to hex3[5]
+set_location_assignment PIN_D4 -to hex3[6]
+set_location_assignment PIN_A3 -to i2c_sclk
+set_location_assignment PIN_B3 -to i2c_sdat
+set_location_assignment PIN_R22 -to key[0]
+set_location_assignment PIN_R21 -to key[1]
+set_location_assignment PIN_T22 -to key[2]
+set_location_assignment PIN_T21 -to key[3]
+set_location_assignment PIN_U22 -to ledg[0]
+set_location_assignment PIN_U21 -to ledg[1]
+set_location_assignment PIN_V22 -to ledg[2]
+set_location_assignment PIN_V21 -to ledg[3]
+set_location_assignment PIN_W22 -to ledg[4]
+set_location_assignment PIN_W21 -to ledg[5]
+set_location_assignment PIN_Y22 -to ledg[6]
+set_location_assignment PIN_Y21 -to ledg[7]
+set_location_assignment PIN_R20 -to ledr[0]
+set_location_assignment PIN_R19 -to ledr[1]
+set_location_assignment PIN_U19 -to ledr[2]
+set_location_assignment PIN_Y19 -to ledr[3]
+set_location_assignment PIN_T18 -to ledr[4]
+set_location_assignment PIN_V19 -to ledr[5]
+set_location_assignment PIN_Y18 -to ledr[6]
+set_location_assignment PIN_U18 -to ledr[7]
+set_location_assignment PIN_R18 -to ledr[8]
+set_location_assignment PIN_R17 -to ledr[9]
+set_location_assignment PIN_H15 -to ps2_clk
+set_location_assignment PIN_J14 -to ps2_dat
+set_location_assignment PIN_AA3 -to sram_addr[0]
+set_location_assignment PIN_R11 -to sram_addr[10]
+set_location_assignment PIN_T11 -to sram_addr[11]
+set_location_assignment PIN_Y10 -to sram_addr[12]
+set_location_assignment PIN_U10 -to sram_addr[13]
+set_location_assignment PIN_R10 -to sram_addr[14]
+set_location_assignment PIN_T7 -to sram_addr[15]
+set_location_assignment PIN_Y6 -to sram_addr[16]
+set_location_assignment PIN_Y5 -to sram_addr[17]
+set_location_assignment PIN_AB3 -to sram_addr[1]
+set_location_assignment PIN_AA4 -to sram_addr[2]
+set_location_assignment PIN_AB4 -to sram_addr[3]
+set_location_assignment PIN_AA5 -to sram_addr[4]
+set_location_assignment PIN_AB10 -to sram_addr[5]
+set_location_assignment PIN_AA11 -to sram_addr[6]
+set_location_assignment PIN_AB11 -to sram_addr[7]
+set_location_assignment PIN_V11 -to sram_addr[8]
+set_location_assignment PIN_W11 -to sram_addr[9]
+set_location_assignment PIN_AB5 -to sram_ce_n
+set_location_assignment PIN_AA6 -to sram_dq[0]
+set_location_assignment PIN_V9 -to sram_dq[10]
+set_location_assignment PIN_U9 -to sram_dq[11]
+set_location_assignment PIN_R9 -to sram_dq[12]
+set_location_assignment PIN_W8 -to sram_dq[13]
+set_location_assignment PIN_V8 -to sram_dq[14]
+set_location_assignment PIN_U8 -to sram_dq[15]
+set_location_assignment PIN_AB6 -to sram_dq[1]
+set_location_assignment PIN_AA7 -to sram_dq[2]
+set_location_assignment PIN_AB7 -to sram_dq[3]
+set_location_assignment PIN_AA8 -to sram_dq[4]
+set_location_assignment PIN_AB8 -to sram_dq[5]
+set_location_assignment PIN_AA9 -to sram_dq[6]
+set_location_assignment PIN_AB9 -to sram_dq[7]
+set_location_assignment PIN_Y9 -to sram_dq[8]
+set_location_assignment PIN_W9 -to sram_dq[9]
+set_location_assignment PIN_Y7 -to sram_lb_n
+set_location_assignment PIN_T8 -to sram_oe_n
+set_location_assignment PIN_W7 -to sram_ub_n
+set_location_assignment PIN_AA10 -to sram_we_n
+set_location_assignment PIN_L22 -to sw[0]
+set_location_assignment PIN_L21 -to sw[1]
+set_location_assignment PIN_M22 -to sw[2]
+set_location_assignment PIN_V12 -to sw[3]
+set_location_assignment PIN_W12 -to sw[4]
+set_location_assignment PIN_U12 -to sw[5]
+set_location_assignment PIN_U11 -to sw[6]
+set_location_assignment PIN_M2 -to sw[7]
+set_location_assignment PIN_M1 -to sw[8]
+set_location_assignment PIN_L2 -to sw[9]
+set_location_assignment PIN_C7 -to tck
+set_location_assignment PIN_D8 -to tcs
+set_location_assignment PIN_E8 -to tdi
+set_location_assignment PIN_D7 -to tdo
+set_location_assignment PIN_F14 -to uart_rxd
+set_location_assignment PIN_G12 -to uart_txd
+set_location_assignment PIN_A9 -to vga_b[0]
+set_location_assignment PIN_D11 -to vga_b[1]
+set_location_assignment PIN_A10 -to vga_b[2]
+set_location_assignment PIN_B10 -to vga_b[3]
+set_location_assignment PIN_B8 -to vga_g[0]
+set_location_assignment PIN_C10 -to vga_g[1]
+set_location_assignment PIN_B9 -to vga_g[2]
+set_location_assignment PIN_A8 -to vga_g[3]
+set_location_assignment PIN_A11 -to vga_hs
+set_location_assignment PIN_D9 -to vga_r[0]
+set_location_assignment PIN_C9 -to vga_r[1]
+set_location_assignment PIN_A7 -to vga_r[2]
+set_location_assignment PIN_B7 -to vga_r[3]
+set_location_assignment PIN_B11 -to vga_vs
+
+set_global_assignment -name MISC_FILE "C:/VHDL/System09_sandbox_JK/rtl/System09_Terasic_DE1/system09.dpf"
+set_global_assignment -name PARTITION_NETLIST_TYPE SOURCE -section_id Top
+set_global_assignment -name PARTITION_COLOR 2147039 -section_id Top
+set_global_assignment -name LL_ROOT_REGION ON -section_id "Root Region"
+set_global_assignment -name LL_MEMBER_STATE LOCKED -section_id "Root Region"
+set_global_assignment -name FITTER_EFFORT "STANDARD FIT"
+set_global_assignment -name FITTER_AGGRESSIVE_ROUTABILITY_OPTIMIZATION ALWAYS
+set_global_assignment -name OPTIMIZE_TIMING OFF
+set_global_assignment -name AUTO_RAM_RECOGNITION ON
+set_global_assignment -name AUTO_SHIFT_REGISTER_RECOGNITION ALWAYS
+set_global_assignment -name OPTIMIZATION_TECHNIQUE AREA
+set_global_assignment -name STRATIXII_OPTIMIZATION_TECHNIQUE AREA
+set_global_assignment -name CYCLONE_OPTIMIZATION_TECHNIQUE AREA
+set_global_assignment -name CYCLONEII_OPTIMIZATION_TECHNIQUE AREA
+set_global_assignment -name STRATIX_OPTIMIZATION_TECHNIQUE AREA
+set_global_assignment -name MAXII_OPTIMIZATION_TECHNIQUE AREA
+set_global_assignment -name MAX7000_OPTIMIZATION_TECHNIQUE AREA
+set_global_assignment -name ADV_NETLIST_OPT_SYNTH_WYSIWYG_REMAP ON
+set_global_assignment -name REMOVE_REDUNDANT_LOGIC_CELLS ON
+set_global_assignment -name MUX_RESTRUCTURE ON
+set_global_assignment -name ALLOW_ANY_ROM_SIZE_FOR_RECOGNITION ON
+set_global_assignment -name ALLOW_ANY_RAM_SIZE_FOR_RECOGNITION ON
+set_global_assignment -name ALLOW_ANY_SHIFT_REGISTER_SIZE_FOR_RECOGNITION ON
+set_global_assignment -name PHYSICAL_SYNTHESIS_COMBO_LOGIC_FOR_AREA ON
+set_global_assignment -name PHYSICAL_SYNTHESIS_MAP_LOGIC_TO_MEMORY_FOR_AREA ON
+set_global_assignment -name DO_MIN_ANALYSIS ON
+set_global_assignment -name FMAX_REQUIREMENT "50 MHz"
+set_global_assignment -name MIF_FILE ../Cyclone2/keymap_rom.mif
+set_global_assignment -name HEX_FILE "../Cyclone2/sys09bug_de2-70.hex"
+set_global_assignment -name MIF_FILE ../Cyclone2/char_rom.mif
+set_global_assignment -name VHDL_FILE ../VHDL/trap.vhd
+set_global_assignment -name VHDL_FILE System09_Terasic_DE1.vhd
+set_global_assignment -name VHDL_FILE ../VHDL/ps2_keyboard.vhd
+set_global_assignment -name VHDL_FILE ../VHDL/acia6850.vhd
+set_global_assignment -name VHDL_FILE ../VHDL/timer.vhd
+set_global_assignment -name VHDL_FILE ../VHDL/vdu8.vhd
+set_global_assignment -name VHDL_FILE ../VHDL/keyboard.vhd
+set_global_assignment -name VHDL_FILE ../VHDL/datram.vhd
+set_global_assignment -name VHDL_FILE ../VHDL/cpu09.vhd
+set_global_assignment -name VHDL_FILE ../VHDL/bit_funcs.vhd
+set_global_assignment -name VHDL_FILE ../VHDL/ACIA_Clock.vhd
+set_global_assignment -name VHDL_FILE ../Cyclone2/sprom.vhd
+set_global_assignment -name VHDL_FILE ../Cyclone2/spram.vhd
+set_global_assignment -name VHDL_FILE ../Cyclone2/mon_rom.vhd
+set_global_assignment -name VHDL_FILE ../Cyclone2/char_rom.vhd
+set_global_assignment -name VHDL_FILE ../Cyclone2/keymap_rom.vhd
+set_global_assignment -name VHDL_FILE ../Cyclone2/ram_2k.vhd
+set_global_assignment -name QIP_FILE ../Cyclone2/pll.qip
+set_instance_assignment -name PARTITION_HIERARCHY root_partition -to | -section_id Top
\ No newline at end of file
Index: System09_Terasic_DE1/system09_assignment_defaults.qdf
===================================================================
--- System09_Terasic_DE1/system09_assignment_defaults.qdf (nonexistent)
+++ System09_Terasic_DE1/system09_assignment_defaults.qdf (revision 117)
@@ -0,0 +1,642 @@
+# -------------------------------------------------------------------------- #
+#
+# Copyright (C) 1991-2009 Altera Corporation
+# Your use of Altera Corporation's design tools, logic functions
+# and other software and tools, and its AMPP partner logic
+# functions, and any output files from any of the foregoing
+# (including device programming or simulation files), and any
+# associated documentation or information are expressly subject
+# to the terms and conditions of the Altera Program License
+# Subscription Agreement, Altera MegaCore Function License
+# Agreement, or other applicable license agreement, including,
+# without limitation, that your use is for the sole purpose of
+# programming logic devices manufactured by Altera and sold by
+# Altera or its authorized distributors. Please refer to the
+# applicable agreement for further details.
+#
+# -------------------------------------------------------------------------- #
+#
+# Quartus II
+# Version 9.0 Build 235 06/17/2009 Service Pack 2 SJ Full Version
+# Date created = 17:10:05 March 10, 2010
+#
+# -------------------------------------------------------------------------- #
+#
+# Note:
+#
+# 1) Do not modify this file. This file was generated
+# automatically by the Quartus II software and is used
+# to preserve global assignments across Quartus II versions.
+#
+# -------------------------------------------------------------------------- #
+
+set_global_assignment -name PROJECT_SHOW_ENTITY_NAME On
+set_global_assignment -name PROJECT_USE_SIMPLIFIED_NAMES Off
+set_global_assignment -name ENABLE_REDUCED_MEMORY_MODE Off
+set_global_assignment -name VER_COMPATIBLE_DB_DIR export_db
+set_global_assignment -name AUTO_EXPORT_VER_COMPATIBLE_DB Off
+set_global_assignment -name SMART_RECOMPILE Off
+set_global_assignment -name FLOW_DISABLE_ASSEMBLER Off
+set_global_assignment -name FLOW_ENABLE_HC_COMPARE Off
+set_global_assignment -name HC_OUTPUT_DIR hc_output
+set_global_assignment -name SAVE_MIGRATION_INFO_DURING_COMPILATION Off
+set_global_assignment -name FLOW_ENABLE_IO_ASSIGNMENT_ANALYSIS Off
+set_global_assignment -name RUN_FULL_COMPILE_ON_DEVICE_CHANGE On
+set_global_assignment -name FLOW_ENABLE_RTL_VIEWER Off
+set_global_assignment -name READ_OR_WRITE_IN_BYTE_ADDRESS "Use global settings"
+set_global_assignment -name FLOW_HARDCOPY_DESIGN_READINESS_CHECK On
+set_global_assignment -name DEFAULT_HOLD_MULTICYCLE "Same as Multicycle"
+set_global_assignment -name CUT_OFF_PATHS_BETWEEN_CLOCK_DOMAINS On
+set_global_assignment -name CUT_OFF_READ_DURING_WRITE_PATHS On
+set_global_assignment -name CUT_OFF_IO_PIN_FEEDBACK On
+set_global_assignment -name DO_COMBINED_ANALYSIS Off
+set_global_assignment -name IGNORE_CLOCK_SETTINGS Off
+set_global_assignment -name ANALYZE_LATCHES_AS_SYNCHRONOUS_ELEMENTS On
+set_global_assignment -name ENABLE_RECOVERY_REMOVAL_ANALYSIS Off
+set_global_assignment -name ENABLE_CLOCK_LATENCY Off
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER Off -family ACEX1K
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER Off -family MAX7000B
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER Off -family "HardCopy II"
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER Off -family FLEX10KA
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER On -family "Stratix IV"
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER On -family "Cyclone III"
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER Off -family "HardCopy Stratix"
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER Off -family APEX20KE
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER Off -family MAX7000AE
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER Off -family Cyclone
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER Off -family "Stratix II GX"
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER Off -family FLEX10K
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER Off -family "MAX II"
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER Off -family APEX20KC
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER On -family "Arria II GX"
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER Off -family "Stratix GX"
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER On -family "HardCopy III"
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER Off -family MAX7000S
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER Off -family FLEX6000
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER Off -family "APEX II"
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER Off -family FLEX10KE
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER Off -family "Cyclone II"
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER On -family "HardCopy IV"
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER On -family "Cyclone III LS"
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER On -family "Stratix III"
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER On -family "Arria GX"
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER Off -family MAX3000A
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER Off -family "Stratix II"
+set_global_assignment -name USE_TIMEQUEST_TIMING_ANALYZER Off -family Stratix
+set_global_assignment -name NUMBER_OF_SOURCES_PER_DESTINATION_TO_REPORT 10
+set_global_assignment -name NUMBER_OF_DESTINATION_TO_REPORT 10
+set_global_assignment -name NUMBER_OF_PATHS_TO_REPORT 200
+set_global_assignment -name DO_MIN_ANALYSIS Off
+set_global_assignment -name DO_MIN_TIMING Off
+set_global_assignment -name REPORT_IO_PATHS_SEPARATELY Off
+set_global_assignment -name FLOW_ENABLE_TIMING_CONSTRAINT_CHECK Off
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS Off -family ACEX1K
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS Off -family MAX7000B
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS On -family "HardCopy II"
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS Off -family FLEX10KA
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS On -family "Stratix IV"
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS On -family "Cyclone III"
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS Off -family "HardCopy Stratix"
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS Off -family APEX20KE
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS Off -family MAX7000AE
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS Off -family Cyclone
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS On -family "Stratix II GX"
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS Off -family FLEX10K
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS Off -family "MAX II"
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS Off -family APEX20KC
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS On -family "Arria II GX"
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS Off -family "Stratix GX"
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS On -family "HardCopy III"
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS Off -family MAX7000S
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS Off -family FLEX6000
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS Off -family "APEX II"
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS Off -family FLEX10KE
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS On -family "Cyclone II"
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS On -family "HardCopy IV"
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS On -family "Cyclone III LS"
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS On -family "Stratix III"
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS On -family "Arria GX"
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS Off -family MAX3000A
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS On -family "Stratix II"
+set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS Off -family Stratix
+set_global_assignment -name TIMEQUEST_DO_REPORT_TIMING Off
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL Off -family ACEX1K
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL Off -family MAX7000B
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL Off -family "HardCopy II"
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL Off -family FLEX10KA
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL On -family "Stratix IV"
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL On -family "Cyclone III"
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL Off -family "HardCopy Stratix"
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL Off -family APEX20KE
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL Off -family MAX7000AE
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL Off -family Cyclone
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL Off -family "Stratix II GX"
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL Off -family FLEX10K
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL Off -family "MAX II"
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL Off -family APEX20KC
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL On -family "Arria II GX"
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL Off -family "Stratix GX"
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL On -family "HardCopy III"
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL Off -family MAX7000S
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL Off -family FLEX6000
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL Off -family "APEX II"
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL Off -family FLEX10KE
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL Off -family "Cyclone II"
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL On -family "HardCopy IV"
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL On -family "Cyclone III LS"
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL On -family "Stratix III"
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL Off -family "Arria GX"
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL Off -family MAX3000A
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL Off -family "Stratix II"
+set_global_assignment -name TIMEQUEST_DO_CCPP_REMOVAL Off -family Stratix
+set_global_assignment -name MUX_RESTRUCTURE Auto
+set_global_assignment -name ENABLE_IP_DEBUG Off
+set_global_assignment -name SAVE_DISK_SPACE On
+set_global_assignment -name DISABLE_OCP_HW_EVAL Off
+set_global_assignment -name DEVICE_FILTER_PACKAGE Any
+set_global_assignment -name DEVICE_FILTER_PIN_COUNT Any
+set_global_assignment -name DEVICE_FILTER_SPEED_GRADE Any
+set_global_assignment -name EDA_DESIGN_ENTRY_SYNTHESIS_TOOL ""
+set_global_assignment -name VERILOG_INPUT_VERSION Verilog_2001
+set_global_assignment -name VHDL_INPUT_VERSION VHDL93
+set_global_assignment -name FAMILY "Stratix II"
+set_global_assignment -name TRUE_WYSIWYG_FLOW Off
+set_global_assignment -name SMART_COMPILE_IGNORES_TDC_FOR_STRATIX_PLL_CHANGES Off
+set_global_assignment -name STATE_MACHINE_PROCESSING Auto
+set_global_assignment -name SAFE_STATE_MACHINE Off
+set_global_assignment -name EXTRACT_VERILOG_STATE_MACHINES On
+set_global_assignment -name EXTRACT_VHDL_STATE_MACHINES On
+set_global_assignment -name IGNORE_VERILOG_INITIAL_CONSTRUCTS Off
+set_global_assignment -name VERILOG_CONSTANT_LOOP_LIMIT 5000
+set_global_assignment -name VERILOG_NON_CONSTANT_LOOP_LIMIT 250
+set_global_assignment -name ADD_PASS_THROUGH_LOGIC_TO_INFERRED_RAMS On
+set_global_assignment -name PARALLEL_SYNTHESIS Off
+set_global_assignment -name DSP_BLOCK_BALANCING Auto
+set_global_assignment -name MAX_BALANCING_DSP_BLOCKS "-1 (Unlimited)"
+set_global_assignment -name NOT_GATE_PUSH_BACK On
+set_global_assignment -name ALLOW_POWER_UP_DONT_CARE On
+set_global_assignment -name REMOVE_REDUNDANT_LOGIC_CELLS Off
+set_global_assignment -name REMOVE_DUPLICATE_REGISTERS On
+set_global_assignment -name IGNORE_CARRY_BUFFERS Off
+set_global_assignment -name IGNORE_CASCADE_BUFFERS Off
+set_global_assignment -name IGNORE_GLOBAL_BUFFERS Off
+set_global_assignment -name IGNORE_ROW_GLOBAL_BUFFERS Off
+set_global_assignment -name IGNORE_LCELL_BUFFERS Off
+set_global_assignment -name MAX7000_IGNORE_LCELL_BUFFERS AUTO
+set_global_assignment -name IGNORE_SOFT_BUFFERS On
+set_global_assignment -name MAX7000_IGNORE_SOFT_BUFFERS Off
+set_global_assignment -name LIMIT_AHDL_INTEGERS_TO_32_BITS Off
+set_global_assignment -name AUTO_GLOBAL_CLOCK_MAX On
+set_global_assignment -name AUTO_GLOBAL_OE_MAX On
+set_global_assignment -name MAX_AUTO_GLOBAL_REGISTER_CONTROLS On
+set_global_assignment -name AUTO_IMPLEMENT_IN_ROM Off
+set_global_assignment -name APEX20K_TECHNOLOGY_MAPPER Lut
+set_global_assignment -name OPTIMIZATION_TECHNIQUE Balanced
+set_global_assignment -name STRATIXII_OPTIMIZATION_TECHNIQUE Balanced
+set_global_assignment -name CYCLONE_OPTIMIZATION_TECHNIQUE Balanced
+set_global_assignment -name CYCLONEII_OPTIMIZATION_TECHNIQUE Balanced
+set_global_assignment -name STRATIX_OPTIMIZATION_TECHNIQUE Balanced
+set_global_assignment -name MAXII_OPTIMIZATION_TECHNIQUE Balanced
+set_global_assignment -name MAX7000_OPTIMIZATION_TECHNIQUE Speed
+set_global_assignment -name APEX20K_OPTIMIZATION_TECHNIQUE Balanced
+set_global_assignment -name MERCURY_OPTIMIZATION_TECHNIQUE Area
+set_global_assignment -name FLEX6K_OPTIMIZATION_TECHNIQUE Area
+set_global_assignment -name FLEX10K_OPTIMIZATION_TECHNIQUE Area
+set_global_assignment -name ALLOW_XOR_GATE_USAGE On
+set_global_assignment -name AUTO_LCELL_INSERTION On
+set_global_assignment -name CARRY_CHAIN_LENGTH 48
+set_global_assignment -name FLEX6K_CARRY_CHAIN_LENGTH 32
+set_global_assignment -name FLEX10K_CARRY_CHAIN_LENGTH 32
+set_global_assignment -name MERCURY_CARRY_CHAIN_LENGTH 48
+set_global_assignment -name STRATIX_CARRY_CHAIN_LENGTH 70
+set_global_assignment -name STRATIXII_CARRY_CHAIN_LENGTH 70
+set_global_assignment -name CASCADE_CHAIN_LENGTH 2
+set_global_assignment -name PARALLEL_EXPANDER_CHAIN_LENGTH 16
+set_global_assignment -name MAX7000_PARALLEL_EXPANDER_CHAIN_LENGTH 4
+set_global_assignment -name AUTO_CARRY_CHAINS On
+set_global_assignment -name AUTO_CASCADE_CHAINS On
+set_global_assignment -name AUTO_PARALLEL_EXPANDERS On
+set_global_assignment -name AUTO_OPEN_DRAIN_PINS On
+set_global_assignment -name ADV_NETLIST_OPT_SYNTH_WYSIWYG_REMAP Off
+set_global_assignment -name AUTO_ROM_RECOGNITION On
+set_global_assignment -name AUTO_RAM_RECOGNITION On
+set_global_assignment -name AUTO_DSP_RECOGNITION On
+set_global_assignment -name AUTO_SHIFT_REGISTER_RECOGNITION Auto
+set_global_assignment -name AUTO_CLOCK_ENABLE_RECOGNITION On
+set_global_assignment -name STRICT_RAM_RECOGNITION Off
+set_global_assignment -name ALLOW_SYNCH_CTRL_USAGE On
+set_global_assignment -name FORCE_SYNCH_CLEAR Off
+set_global_assignment -name AUTO_RAM_BLOCK_BALANCING On
+set_global_assignment -name AUTO_RAM_TO_LCELL_CONVERSION Off
+set_global_assignment -name AUTO_RESOURCE_SHARING Off
+set_global_assignment -name ALLOW_ANY_RAM_SIZE_FOR_RECOGNITION Off
+set_global_assignment -name ALLOW_ANY_ROM_SIZE_FOR_RECOGNITION Off
+set_global_assignment -name ALLOW_ANY_SHIFT_REGISTER_SIZE_FOR_RECOGNITION Off
+set_global_assignment -name MAX7000_FANIN_PER_CELL 100
+set_global_assignment -name USE_LOGICLOCK_CONSTRAINTS_IN_BALANCING On
+set_global_assignment -name MAX_RAM_BLOCKS_M512 "-1 (Unlimited)"
+set_global_assignment -name MAX_RAM_BLOCKS_M4K "-1 (Unlimited)"
+set_global_assignment -name MAX_RAM_BLOCKS_MRAM "-1 (Unlimited)"
+set_global_assignment -name IGNORE_TRANSLATE_OFF_AND_SYNTHESIS_OFF Off
+set_global_assignment -name STRATIXGX_BYPASS_REMAPPING_OF_FORCE_SIGNAL_DETECT_SIGNAL_THRESHOLD_SELECT Off
+set_global_assignment -name SYNTH_TIMING_DRIVEN_SYNTHESIS Off
+set_global_assignment -name SHOW_PARAMETER_SETTINGS_TABLES_IN_SYNTHESIS_REPORT On
+set_global_assignment -name IGNORE_MAX_FANOUT_ASSIGNMENTS Off
+set_global_assignment -name SYNCHRONIZATION_REGISTER_CHAIN_LENGTH 2
+set_global_assignment -name OPTIMIZE_POWER_DURING_SYNTHESIS "Normal compilation"
+set_global_assignment -name HDL_MESSAGE_LEVEL Level2
+set_global_assignment -name USE_HIGH_SPEED_ADDER Auto
+set_global_assignment -name NUMBER_OF_REMOVED_REGISTERS_REPORTED 100
+set_global_assignment -name NUMBER_OF_INVERTED_REGISTERS_REPORTED 100
+set_global_assignment -name SYNTH_CLOCK_MUX_PROTECTION On
+set_global_assignment -name SYNTH_GATED_CLOCK_CONVERSION Off
+set_global_assignment -name BLOCK_DESIGN_NAMING Auto
+set_global_assignment -name SYNTH_PROTECT_SDC_CONSTRAINT Off
+set_global_assignment -name SYNTHESIS_EFFORT Auto
+set_global_assignment -name SHIFT_REGISTER_RECOGNITION_ACLR_SIGNAL On
+set_global_assignment -name PRE_MAPPING_RESYNTHESIS Off
+set_global_assignment -name SYNTH_MESSAGE_LEVEL Medium
+set_global_assignment -name ROUTER_TIMING_OPTIMIZATION_LEVEL Normal
+set_global_assignment -name PLACEMENT_EFFORT_MULTIPLIER 1.0
+set_global_assignment -name ROUTER_EFFORT_MULTIPLIER 1.0
+set_global_assignment -name FIT_ATTEMPTS_TO_SKIP 0.0
+set_global_assignment -name ECO_ALLOW_ROUTING_CHANGES Off
+set_global_assignment -name DEVICE AUTO
+set_global_assignment -name BASE_PIN_OUT_FILE_ON_SAMEFRAME_DEVICE Off
+set_global_assignment -name ENABLE_JTAG_BST_SUPPORT Off
+set_global_assignment -name MAX7000_ENABLE_JTAG_BST_SUPPORT On
+set_global_assignment -name RESERVE_NCEO_AFTER_CONFIGURATION "Use as regular IO"
+set_global_assignment -name CYCLONEII_RESERVE_NCEO_AFTER_CONFIGURATION "Use as programming pin"
+set_global_assignment -name STRATIXIII_UPDATE_MODE Standard
+set_global_assignment -name STRATIX_UPDATE_MODE Standard
+set_global_assignment -name STRATIXIII_CONFIGURATION_SCHEME "Passive Serial"
+set_global_assignment -name CYCLONEIII_CONFIGURATION_SCHEME "Active Serial"
+set_global_assignment -name STRATIXII_CONFIGURATION_SCHEME "Passive Serial"
+set_global_assignment -name CYCLONEII_CONFIGURATION_SCHEME "Active Serial"
+set_global_assignment -name APEX20K_CONFIGURATION_SCHEME "Passive Serial"
+set_global_assignment -name STRATIX_CONFIGURATION_SCHEME "Passive Serial"
+set_global_assignment -name CYCLONE_CONFIGURATION_SCHEME "Active Serial"
+set_global_assignment -name MERCURY_CONFIGURATION_SCHEME "Passive Serial"
+set_global_assignment -name FLEX6K_CONFIGURATION_SCHEME "Passive Serial"
+set_global_assignment -name FLEX10K_CONFIGURATION_SCHEME "Passive Serial"
+set_global_assignment -name APEXII_CONFIGURATION_SCHEME "Passive Serial"
+set_global_assignment -name USER_START_UP_CLOCK Off
+set_global_assignment -name ENABLE_VREFA_PIN Off
+set_global_assignment -name ENABLE_VREFB_PIN Off
+set_global_assignment -name ALWAYS_ENABLE_INPUT_BUFFERS Off
+set_global_assignment -name ENABLE_ASMI_FOR_FLASH_LOADER Off
+set_global_assignment -name ENABLE_DEVICE_WIDE_RESET Off
+set_global_assignment -name ENABLE_DEVICE_WIDE_OE Off
+set_global_assignment -name RESERVE_ALL_UNUSED_PINS "As output driving ground"
+set_global_assignment -name FLEX10K_ENABLE_LOCK_OUTPUT Off
+set_global_assignment -name ENABLE_INIT_DONE_OUTPUT Off
+set_global_assignment -name RESERVE_NWS_NRS_NCS_CS_AFTER_CONFIGURATION "Use as regular IO"
+set_global_assignment -name RESERVE_RDYNBUSY_AFTER_CONFIGURATION "Use as regular IO"
+set_global_assignment -name RESERVE_DATA7_THROUGH_DATA1_AFTER_CONFIGURATION "Use as regular IO"
+set_global_assignment -name RESERVE_DATA0_AFTER_CONFIGURATION "As input tri-stated"
+set_global_assignment -name RESERVE_ASDO_AFTER_CONFIGURATION "Use as regular IO"
+set_global_assignment -name RESERVE_DATA1_AFTER_CONFIGURATION "As input tri-stated"
+set_global_assignment -name RESERVE_DATA7_THROUGH_DATA2_AFTER_CONFIGURATION "Use as regular IO"
+set_global_assignment -name RESERVE_FLASH_NCE_AFTER_CONFIGURATION "As input tri-stated"
+set_global_assignment -name RESERVE_OTHER_AP_PINS_AFTER_CONFIGURATION "Use as regular IO"
+set_global_assignment -name RESERVE_DCLK_AFTER_CONFIGURATION "Use as programming pin"
+set_global_assignment -name CRC_ERROR_CHECKING Off
+set_global_assignment -name OPTIMIZE_HOLD_TIMING "IO Paths and Minimum TPD Paths" -family "Stratix GX"
+set_global_assignment -name OPTIMIZE_HOLD_TIMING -value "ALL PATHS" -family "HardCopy III"
+set_global_assignment -name OPTIMIZE_HOLD_TIMING "IO Paths and Minimum TPD Paths" -family "Cyclone II"
+set_global_assignment -name OPTIMIZE_HOLD_TIMING "IO Paths and Minimum TPD Paths" -family "HardCopy II"
+set_global_assignment -name OPTIMIZE_HOLD_TIMING -value "ALL PATHS" -family "Stratix IV"
+set_global_assignment -name OPTIMIZE_HOLD_TIMING -value "ALL PATHS" -family "HardCopy IV"
+set_global_assignment -name OPTIMIZE_HOLD_TIMING -value "ALL PATHS" -family "Cyclone III LS"
+set_global_assignment -name OPTIMIZE_HOLD_TIMING -value "ALL PATHS" -family "Cyclone III"
+set_global_assignment -name OPTIMIZE_HOLD_TIMING -value "ALL PATHS" -family "Stratix III"
+set_global_assignment -name OPTIMIZE_HOLD_TIMING "IO Paths and Minimum TPD Paths" -family "HardCopy Stratix"
+set_global_assignment -name OPTIMIZE_HOLD_TIMING -value "ALL PATHS" -family "Arria GX"
+set_global_assignment -name OPTIMIZE_HOLD_TIMING "IO Paths and Minimum TPD Paths" -family "Stratix II GX"
+set_global_assignment -name OPTIMIZE_HOLD_TIMING "IO Paths and Minimum TPD Paths" -family Cyclone
+set_global_assignment -name OPTIMIZE_HOLD_TIMING "IO Paths and Minimum TPD Paths" -family "Stratix II"
+set_global_assignment -name OPTIMIZE_HOLD_TIMING "IO Paths and Minimum TPD Paths" -family "MAX II"
+set_global_assignment -name OPTIMIZE_HOLD_TIMING "IO Paths and Minimum TPD Paths" -family Stratix
+set_global_assignment -name OPTIMIZE_HOLD_TIMING -value "ALL PATHS" -family "Arria II GX"
+set_global_assignment -name OPTIMIZE_MULTI_CORNER_TIMING Off
+set_global_assignment -name BLOCK_RAM_TO_MLAB_CELL_CONVERSION On
+set_global_assignment -name BLOCK_RAM_AND_MLAB_EQUIVALENT_POWER_UP_CONDITIONS Auto
+set_global_assignment -name BLOCK_RAM_AND_MLAB_EQUIVALENT_PAUSED_READ_CAPABILITIES Care
+set_global_assignment -name PROGRAMMABLE_POWER_TECHNOLOGY_SETTING "Force All Tiles with Failing Timing Paths to High Speed"
+set_global_assignment -name PROGRAMMABLE_POWER_MAXIMUM_HIGH_SPEED_FRACTION_OF_USED_LAB_TILES 1.0
+set_global_assignment -name GUARANTEE_MIN_DELAY_CORNER_IO_ZERO_HOLD_TIME On
+set_global_assignment -name OPTIMIZE_POWER_DURING_FITTING "Normal compilation"
+set_global_assignment -name OPTIMIZE_SSN Off -family "Cyclone III LS"
+set_global_assignment -name OPTIMIZE_SSN Off -family "Cyclone III"
+set_global_assignment -name OPTIMIZE_SSN Off -family "Stratix III"
+set_global_assignment -name OPTIMIZE_SSN Off -family "HardCopy III"
+set_global_assignment -name OPTIMIZE_SSN Off -family "HardCopy IV"
+set_global_assignment -name OPTIMIZE_TIMING "Normal compilation"
+set_global_assignment -name ECO_OPTIMIZE_TIMING Off
+set_global_assignment -name ECO_REGENERATE_REPORT Off
+set_global_assignment -name OPTIMIZE_IOC_REGISTER_PLACEMENT_FOR_TIMING On
+set_global_assignment -name FIT_ONLY_ONE_ATTEMPT Off
+set_global_assignment -name FINAL_PLACEMENT_OPTIMIZATION Automatically
+set_global_assignment -name FITTER_AGGRESSIVE_ROUTABILITY_OPTIMIZATION Automatically
+set_global_assignment -name SEED 1
+set_global_assignment -name SLOW_SLEW_RATE Off
+set_global_assignment -name PCI_IO Off
+set_global_assignment -name TURBO_BIT On
+set_global_assignment -name WEAK_PULL_UP_RESISTOR Off
+set_global_assignment -name ENABLE_BUS_HOLD_CIRCUITRY Off
+set_global_assignment -name AUTO_GLOBAL_MEMORY_CONTROLS Off
+set_global_assignment -name MIGRATION_CONSTRAIN_CORE_RESOURCES On
+set_global_assignment -name AUTO_PACKED_REGISTERS_STRATIXII AUTO
+set_global_assignment -name AUTO_PACKED_REGISTERS_MAXII AUTO
+set_global_assignment -name AUTO_PACKED_REGISTERS_CYCLONE Auto
+set_global_assignment -name AUTO_PACKED_REGISTERS Off
+set_global_assignment -name AUTO_PACKED_REGISTERS_STRATIX AUTO
+set_global_assignment -name NORMAL_LCELL_INSERT On
+set_global_assignment -name CARRY_OUT_PINS_LCELL_INSERT On
+set_global_assignment -name AUTO_DELAY_CHAINS On
+set_global_assignment -name XSTL_INPUT_ALLOW_SE_BUFFER Off
+set_global_assignment -name TREAT_BIDIR_AS_OUTPUT Off
+set_global_assignment -name AUTO_MERGE_PLLS On
+set_global_assignment -name IGNORE_MODE_FOR_MERGE Off
+set_global_assignment -name AUTO_TURBO_BIT ON
+set_global_assignment -name PHYSICAL_SYNTHESIS_COMBO_LOGIC_FOR_AREA Off
+set_global_assignment -name PHYSICAL_SYNTHESIS_COMBO_LOGIC Off
+set_global_assignment -name PHYSICAL_SYNTHESIS_LOG_FILE Off
+set_global_assignment -name PHYSICAL_SYNTHESIS_REGISTER_DUPLICATION Off
+set_global_assignment -name PHYSICAL_SYNTHESIS_MAP_LOGIC_TO_MEMORY_FOR_AREA Off
+set_global_assignment -name PHYSICAL_SYNTHESIS_REGISTER_RETIMING Off
+set_global_assignment -name PHYSICAL_SYNTHESIS_ASYNCHRONOUS_SIGNAL_PIPELINING Off
+set_global_assignment -name IO_PLACEMENT_OPTIMIZATION On
+set_global_assignment -name ALLOW_LVTTL_LVCMOS_INPUT_LEVELS_TO_OVERDRIVE_INPUT_BUFFER Off
+set_global_assignment -name OVERRIDE_DEFAULT_ELECTROMIGRATION_PARAMETERS Off
+set_global_assignment -name FITTER_EFFORT "Auto Fit"
+set_global_assignment -name FITTER_AUTO_EFFORT_DESIRED_SLACK_MARGIN 0ns
+set_global_assignment -name PHYSICAL_SYNTHESIS_EFFORT Normal
+set_global_assignment -name ROUTER_LCELL_INSERTION_AND_LOGIC_DUPLICATION AUTO
+set_global_assignment -name ROUTER_REGISTER_DUPLICATION AUTO
+set_global_assignment -name STRATIXGX_ALLOW_CLOCK_FANOUT_WITH_ANALOG_RESET Off
+set_global_assignment -name AUTO_GLOBAL_CLOCK On
+set_global_assignment -name AUTO_GLOBAL_OE On
+set_global_assignment -name AUTO_GLOBAL_REGISTER_CONTROLS On
+set_global_assignment -name FITTER_EARLY_TIMING_ESTIMATE_MODE Realistic
+set_global_assignment -name STRATIXGX_ALLOW_GIGE_UNDER_FULL_DATARATE_RANGE Off
+set_global_assignment -name STRATIXGX_ALLOW_RX_CORECLK_FROM_NON_RX_CLKOUT_SOURCE_IN_DOUBLE_DATA_WIDTH_MODE Off
+set_global_assignment -name STRATIXGX_ALLOW_GIGE_IN_DOUBLE_DATA_WIDTH_MODE Off
+set_global_assignment -name STRATIXGX_ALLOW_PARALLEL_LOOPBACK_IN_DOUBLE_DATA_WIDTH_MODE Off
+set_global_assignment -name STRATIXGX_ALLOW_XAUI_IN_SINGLE_DATA_WIDTH_MODE Off
+set_global_assignment -name STRATIXGX_ALLOW_XAUI_WITH_CORECLK_SELECTED_AT_RATE_MATCHER Off
+set_global_assignment -name STRATIXGX_ALLOW_XAUI_WITH_RX_CORECLK_FROM_NON_TXPLL_SOURCE Off
+set_global_assignment -name STRATIXGX_ALLOW_GIGE_WITH_CORECLK_SELECTED_AT_RATE_MATCHER Off
+set_global_assignment -name STRATIXGX_ALLOW_GIGE_WITHOUT_8B10B Off
+set_global_assignment -name STRATIXGX_ALLOW_GIGE_WITH_RX_CORECLK_FROM_NON_TXPLL_SOURCE Off
+set_global_assignment -name STRATIXGX_ALLOW_POST8B10B_LOOPBACK Off
+set_global_assignment -name STRATIXGX_ALLOW_REVERSE_PARALLEL_LOOPBACK Off
+set_global_assignment -name STRATIXGX_ALLOW_USE_OF_GXB_COUPLED_IOS Off
+set_global_assignment -name GENERATE_GXB_RECONFIG_MIF Off
+set_global_assignment -name GENERATE_GXB_RECONFIG_MIF_WITH_PLL Off
+set_global_assignment -name RESERVE_ALL_UNUSED_PINS_WEAK_PULLUP "As input tri-stated with weak pull-up"
+set_global_assignment -name STOP_AFTER_CONGESTION_MAP Off
+set_global_assignment -name SAVE_INTERMEDIATE_FITTING_RESULTS Off
+set_global_assignment -name ENABLE_HOLD_BACK_OFF On
+set_global_assignment -name CONFIGURATION_VCCIO_LEVEL Auto
+set_global_assignment -name FORCE_CONFIGURATION_VCCIO Off
+set_global_assignment -name SYNCHRONIZER_IDENTIFICATION Off
+set_global_assignment -name ENABLE_BENEFICIAL_SKEW_OPTIMIZATION -value OFF
+set_global_assignment -name OPTIMIZE_FOR_METASTABILITY On
+set_global_assignment -name CRC_ERROR_OPEN_DRAIN Off
+set_global_assignment -name MAX_GLOBAL_CLOCKS_ALLOWED "-1 (Unlimited)"
+set_global_assignment -name MAX_REGIONAL_CLOCKS_ALLOWED "-1 (Unlimited)"
+set_global_assignment -name MAX_PERIPHERY_CLOCKS_ALLOWED "-1 (Unlimited)"
+set_global_assignment -name MAX_CLOCKS_ALLOWED "-1 (Unlimited)"
+set_global_assignment -name ACTIVE_SERIAL_CLOCK FREQ_40MHz
+set_global_assignment -name STRATIXIII_MRAM_COMPATIBILITY On
+set_global_assignment -name FORCE_FITTER_TO_AVOID_PERIPHERY_PLACEMENT_WARNINGS Off
+set_global_assignment -name EDA_SIMULATION_TOOL ""
+set_global_assignment -name EDA_TIMING_ANALYSIS_TOOL ""
+set_global_assignment -name EDA_BOARD_DESIGN_TIMING_TOOL ""
+set_global_assignment -name EDA_BOARD_DESIGN_SYMBOL_TOOL ""
+set_global_assignment -name EDA_BOARD_DESIGN_SIGNAL_INTEGRITY_TOOL ""
+set_global_assignment -name EDA_BOARD_DESIGN_BOUNDARY_SCAN_TOOL ""
+set_global_assignment -name EDA_BOARD_DESIGN_TOOL ""
+set_global_assignment -name EDA_FORMAL_VERIFICATION_TOOL ""
+set_global_assignment -name EDA_RESYNTHESIS_TOOL ""
+set_global_assignment -name ON_CHIP_BITSTREAM_DECOMPRESSION On
+set_global_assignment -name COMPRESSION_MODE Off
+set_global_assignment -name CLOCK_SOURCE Internal
+set_global_assignment -name CONFIGURATION_CLOCK_FREQUENCY "10 MHz"
+set_global_assignment -name CONFIGURATION_CLOCK_DIVISOR 1
+set_global_assignment -name ENABLE_LOW_VOLTAGE_MODE_ON_CONFIG_DEVICE On
+set_global_assignment -name FLEX6K_ENABLE_LOW_VOLTAGE_MODE_ON_CONFIG_DEVICE Off
+set_global_assignment -name FLEX10K_ENABLE_LOW_VOLTAGE_MODE_ON_CONFIG_DEVICE On
+set_global_assignment -name MAX7000S_JTAG_USER_CODE FFFF
+set_global_assignment -name STRATIX_JTAG_USER_CODE FFFFFFFF
+set_global_assignment -name APEX20K_JTAG_USER_CODE FFFFFFFF
+set_global_assignment -name MERCURY_JTAG_USER_CODE FFFFFFFF
+set_global_assignment -name FLEX10K_JTAG_USER_CODE 7F
+set_global_assignment -name MAX7000_JTAG_USER_CODE FFFFFFFF
+set_global_assignment -name MAX7000_USE_CHECKSUM_AS_USERCODE Off
+set_global_assignment -name USE_CHECKSUM_AS_USERCODE Off
+set_global_assignment -name SECURITY_BIT Off
+set_global_assignment -name USE_CONFIGURATION_DEVICE On -family ACEX1K
+set_global_assignment -name USE_CONFIGURATION_DEVICE On -family MAX7000B
+set_global_assignment -name USE_CONFIGURATION_DEVICE On -family "HardCopy II"
+set_global_assignment -name USE_CONFIGURATION_DEVICE On -family FLEX10KA
+set_global_assignment -name USE_CONFIGURATION_DEVICE Off -family "Stratix IV"
+set_global_assignment -name USE_CONFIGURATION_DEVICE Off -family "Cyclone III"
+set_global_assignment -name USE_CONFIGURATION_DEVICE On -family "HardCopy Stratix"
+set_global_assignment -name USE_CONFIGURATION_DEVICE On -family APEX20KE
+set_global_assignment -name USE_CONFIGURATION_DEVICE On -family MAX7000AE
+set_global_assignment -name USE_CONFIGURATION_DEVICE On -family Cyclone
+set_global_assignment -name USE_CONFIGURATION_DEVICE On -family "Stratix II GX"
+set_global_assignment -name USE_CONFIGURATION_DEVICE On -family FLEX10K
+set_global_assignment -name USE_CONFIGURATION_DEVICE On -family "MAX II"
+set_global_assignment -name USE_CONFIGURATION_DEVICE On -family APEX20KC
+set_global_assignment -name USE_CONFIGURATION_DEVICE Off -family "Arria II GX"
+set_global_assignment -name USE_CONFIGURATION_DEVICE On -family "Stratix GX"
+set_global_assignment -name USE_CONFIGURATION_DEVICE Off -family "HardCopy III"
+set_global_assignment -name USE_CONFIGURATION_DEVICE On -family MAX7000S
+set_global_assignment -name USE_CONFIGURATION_DEVICE On -family FLEX6000
+set_global_assignment -name USE_CONFIGURATION_DEVICE On -family "APEX II"
+set_global_assignment -name USE_CONFIGURATION_DEVICE On -family FLEX10KE
+set_global_assignment -name USE_CONFIGURATION_DEVICE On -family "Cyclone II"
+set_global_assignment -name USE_CONFIGURATION_DEVICE Off -family "HardCopy IV"
+set_global_assignment -name USE_CONFIGURATION_DEVICE Off -family "Cyclone III LS"
+set_global_assignment -name USE_CONFIGURATION_DEVICE Off -family "Stratix III"
+set_global_assignment -name USE_CONFIGURATION_DEVICE On -family "Arria GX"
+set_global_assignment -name USE_CONFIGURATION_DEVICE On -family MAX3000A
+set_global_assignment -name USE_CONFIGURATION_DEVICE On -family "Stratix II"
+set_global_assignment -name USE_CONFIGURATION_DEVICE On -family Stratix
+set_global_assignment -name CYCLONEIII_CONFIGURATION_DEVICE Auto
+set_global_assignment -name STRATIXII_CONFIGURATION_DEVICE Auto
+set_global_assignment -name APEX20K_CONFIGURATION_DEVICE Auto
+set_global_assignment -name MERCURY_CONFIGURATION_DEVICE Auto
+set_global_assignment -name FLEX6K_CONFIGURATION_DEVICE Auto
+set_global_assignment -name FLEX10K_CONFIGURATION_DEVICE Auto
+set_global_assignment -name CYCLONE_CONFIGURATION_DEVICE Auto
+set_global_assignment -name STRATIX_CONFIGURATION_DEVICE Auto
+set_global_assignment -name APEX20K_CONFIG_DEVICE_JTAG_USER_CODE FFFFFFFF
+set_global_assignment -name STRATIX_CONFIG_DEVICE_JTAG_USER_CODE FFFFFFFF
+set_global_assignment -name MERCURY_CONFIG_DEVICE_JTAG_USER_CODE FFFFFFFF
+set_global_assignment -name FLEX10K_CONFIG_DEVICE_JTAG_USER_CODE FFFFFFFF
+set_global_assignment -name EPROM_USE_CHECKSUM_AS_USERCODE Off
+set_global_assignment -name AUTO_INCREMENT_CONFIG_DEVICE_JTAG_USER_CODE On
+set_global_assignment -name DISABLE_NCS_AND_OE_PULLUPS_ON_CONFIG_DEVICE Off
+set_global_assignment -name GENERATE_TTF_FILE Off
+set_global_assignment -name GENERATE_RBF_FILE Off
+set_global_assignment -name GENERATE_HEX_FILE Off
+set_global_assignment -name HEXOUT_FILE_START_ADDRESS 0
+set_global_assignment -name HEXOUT_FILE_COUNT_DIRECTION Up
+set_global_assignment -name RESERVE_ALL_UNUSED_PINS_NO_OUTPUT_GND "As output driving an unspecified signal"
+set_global_assignment -name RELEASE_CLEARS_BEFORE_TRI_STATES Off
+set_global_assignment -name AUTO_RESTART_CONFIGURATION On
+set_global_assignment -name HARDCOPYII_POWER_ON_EXTRA_DELAY Off
+set_global_assignment -name STRATIXII_MRAM_COMPATIBILITY Off
+set_global_assignment -name CYCLONEII_M4K_COMPATIBILITY On
+set_global_assignment -name ENABLE_OCT_DONE Off
+set_global_assignment -name USE_CHECKERED_PATTERN_AS_UNINITIALIZED_RAM_CONTENT Off
+set_global_assignment -name START_TIME 0ns
+set_global_assignment -name SIMULATION_MODE TIMING
+set_global_assignment -name AUTO_USE_SIMULATION_PDB_NETLIST Off
+set_global_assignment -name ADD_DEFAULT_PINS_TO_SIMULATION_OUTPUT_WAVEFORMS On
+set_global_assignment -name SETUP_HOLD_DETECTION Off
+set_global_assignment -name SETUP_HOLD_DETECTION_INPUT_REGISTERS_BIDIR_PINS_DISABLED Off
+set_global_assignment -name CHECK_OUTPUTS Off
+set_global_assignment -name SIMULATION_COVERAGE On
+set_global_assignment -name SIMULATION_COMPLETE_COVERAGE_REPORT_PANEL On
+set_global_assignment -name SIMULATION_MISSING_1_VALUE_COVERAGE_REPORT_PANEL On
+set_global_assignment -name SIMULATION_MISSING_0_VALUE_COVERAGE_REPORT_PANEL On
+set_global_assignment -name GLITCH_DETECTION Off
+set_global_assignment -name GLITCH_INTERVAL 1ns
+set_global_assignment -name SIMULATOR_GENERATE_SIGNAL_ACTIVITY_FILE Off
+set_global_assignment -name SIMULATION_WITH_GLITCH_FILTERING_WHEN_GENERATING_SAF On
+set_global_assignment -name SIMULATION_BUS_CHANNEL_GROUPING Off
+set_global_assignment -name SIMULATION_VDB_RESULT_FLUSH On
+set_global_assignment -name VECTOR_COMPARE_TRIGGER_MODE INPUT_EDGE
+set_global_assignment -name SIMULATION_NETLIST_VIEWER Off
+set_global_assignment -name SIMULATION_INTERCONNECT_DELAY_MODEL_TYPE TRANSPORT
+set_global_assignment -name SIMULATION_CELL_DELAY_MODEL_TYPE TRANSPORT
+set_global_assignment -name SIMULATOR_GENERATE_POWERPLAY_VCD_FILE Off
+set_global_assignment -name SIMULATOR_PVT_TIMING_MODEL_TYPE AUTO
+set_global_assignment -name SIMULATION_WITH_AUTO_GLITCH_FILTERING AUTO
+set_global_assignment -name DRC_TOP_FANOUT 50
+set_global_assignment -name DRC_FANOUT_EXCEEDING 30
+set_global_assignment -name DRC_GATED_CLOCK_FEED 30
+set_global_assignment -name HARDCOPY_FLOW_AUTOMATION MIGRATION_ONLY
+set_global_assignment -name ENABLE_DRC_SETTINGS Off
+set_global_assignment -name CLK_RULE_CLKNET_CLKSPINES_THRESHOLD 25
+set_global_assignment -name DRC_DETAIL_MESSAGE_LIMIT 10
+set_global_assignment -name DRC_VIOLATION_MESSAGE_LIMIT 30
+set_global_assignment -name DRC_DEADLOCK_STATE_LIMIT 2
+set_global_assignment -name MERGE_HEX_FILE Off
+set_global_assignment -name GENERATE_SVF_FILE Off
+set_global_assignment -name GENERATE_ISC_FILE Off
+set_global_assignment -name GENERATE_JAM_FILE Off
+set_global_assignment -name GENERATE_JBC_FILE Off
+set_global_assignment -name GENERATE_JBC_FILE_COMPRESSED On
+set_global_assignment -name GENERATE_CONFIG_SVF_FILE Off
+set_global_assignment -name GENERATE_CONFIG_ISC_FILE Off
+set_global_assignment -name GENERATE_CONFIG_JAM_FILE Off
+set_global_assignment -name GENERATE_CONFIG_JBC_FILE Off
+set_global_assignment -name GENERATE_CONFIG_JBC_FILE_COMPRESSED On
+set_global_assignment -name GENERATE_CONFIG_HEXOUT_FILE Off
+set_global_assignment -name ISP_CLAMP_STATE_DEFAULT "Tri-state"
+set_global_assignment -name SIGNALPROBE_ALLOW_OVERUSE Off
+set_global_assignment -name SIGNALPROBE_DURING_NORMAL_COMPILATION Off
+set_global_assignment -name LOGICLOCK_INCREMENTAL_COMPILE_ASSIGNMENT Off
+set_global_assignment -name POWER_DEFAULT_TOGGLE_RATE 12.5%
+set_global_assignment -name POWER_DEFAULT_INPUT_IO_TOGGLE_RATE 12.5%
+set_global_assignment -name POWER_USE_PVA On
+set_global_assignment -name POWER_USE_INPUT_FILE "No File"
+set_global_assignment -name POWER_USE_INPUT_FILES Off
+set_global_assignment -name POWER_VCD_FILTER_GLITCHES On
+set_global_assignment -name POWER_REPORT_SIGNAL_ACTIVITY Off
+set_global_assignment -name POWER_REPORT_POWER_DISSIPATION Off
+set_global_assignment -name POWER_USE_DEVICE_CHARACTERISTICS TYPICAL
+set_global_assignment -name POWER_AUTO_COMPUTE_TJ On
+set_global_assignment -name POWER_TJ_VALUE 25
+set_global_assignment -name POWER_USE_TA_VALUE 25
+set_global_assignment -name POWER_USE_CUSTOM_COOLING_SOLUTION Off
+set_global_assignment -name POWER_BOARD_TEMPERATURE 25
+set_global_assignment -name INCREMENTAL_COMPILATION FULL_INCREMENTAL_COMPILATION
+set_global_assignment -name AUTO_EXPORT_INCREMENTAL_COMPILATION Off
+set_global_assignment -name INCREMENTAL_COMPILATION_EXPORT_NETLIST_TYPE POST_FIT
+set_global_assignment -name OUTPUT_IO_TIMING_ENDPOINT "Near End"
+set_global_assignment -name RTLV_REMOVE_FANOUT_FREE_REGISTERS On
+set_global_assignment -name RTLV_SIMPLIFIED_LOGIC On
+set_global_assignment -name RTLV_GROUP_RELATED_NODES On
+set_global_assignment -name RTLV_GROUP_COMB_LOGIC_IN_CLOUD Off
+set_global_assignment -name RTLV_GROUP_COMB_LOGIC_IN_CLOUD_TMV Off
+set_global_assignment -name RTLV_GROUP_RELATED_NODES_TMV On
+set_global_assignment -name EQC_CONSTANT_DFF_DETECTION On
+set_global_assignment -name EQC_DUPLICATE_DFF_DETECTION On
+set_global_assignment -name EQC_BBOX_MERGE On
+set_global_assignment -name EQC_LVDS_MERGE On
+set_global_assignment -name EQC_RAM_UNMERGING On
+set_global_assignment -name EQC_DFF_SS_EMULATION On
+set_global_assignment -name EQC_RAM_REGISTER_UNPACK On
+set_global_assignment -name EQC_MAC_REGISTER_UNPACK On
+set_global_assignment -name EQC_SET_PARTITION_BB_TO_VCC_GND On
+set_global_assignment -name EQC_STRUCTURE_MATCHING On
+set_global_assignment -name EQC_AUTO_BREAK_CONE On
+set_global_assignment -name EQC_POWER_UP_COMPARE Off
+set_global_assignment -name EQC_AUTO_COMP_LOOP_CUT On
+set_global_assignment -name EQC_AUTO_INVERSION On
+set_global_assignment -name EQC_AUTO_TERMINATE On
+set_global_assignment -name EQC_SUB_CONE_REPORT Off
+set_global_assignment -name EQC_RENAMING_RULES On
+set_global_assignment -name EQC_PARAMETER_CHECK On
+set_global_assignment -name EQC_AUTO_PORTSWAP On
+set_global_assignment -name EQC_DETECT_DONT_CARES On
+set_global_assignment -name EQC_SHOW_ALL_MAPPED_POINTS Off
+set_global_assignment -name DUTY_CYCLE 50 -section_id ?
+set_global_assignment -name INVERT_BASE_CLOCK Off -section_id ?
+set_global_assignment -name MULTIPLY_BASE_CLOCK_PERIOD_BY 1 -section_id ?
+set_global_assignment -name DIVIDE_BASE_CLOCK_PERIOD_BY 1 -section_id ?
+set_global_assignment -name EDA_INPUT_GND_NAME GND -section_id ?
+set_global_assignment -name EDA_INPUT_VCC_NAME VCC -section_id ?
+set_global_assignment -name EDA_INPUT_DATA_FORMAT NONE -section_id ?
+set_global_assignment -name EDA_SHOW_LMF_MAPPING_MESSAGES Off -section_id ?
+set_global_assignment -name EDA_RUN_TOOL_AUTOMATICALLY Off -section_id ?
+set_global_assignment -name RESYNTHESIS_RETIMING FULL -section_id ?
+set_global_assignment -name RESYNTHESIS_OPTIMIZATION_EFFORT Normal -section_id ?
+set_global_assignment -name RESYNTHESIS_PHYSICAL_SYNTHESIS Normal -section_id ?
+set_global_assignment -name USE_GENERATED_PHYSICAL_CONSTRAINTS On -section_id ?
+set_global_assignment -name VCCPD_VOLTAGE 3.3V -section_id ?
+set_global_assignment -name EDA_USER_COMPILED_SIMULATION_LIBRARY_DIRECTORY "" -section_id ?
+set_global_assignment -name EDA_LAUNCH_CMD_LINE_TOOL Off -section_id ?
+set_global_assignment -name EDA_NATIVELINK_GENERATE_SCRIPT_ONLY Off -section_id ?
+set_global_assignment -name EDA_WAIT_FOR_GUI_TOOL_COMPLETION Off -section_id ?
+set_global_assignment -name EDA_TRUNCATE_LONG_HIERARCHY_PATHS Off -section_id ?
+set_global_assignment -name EDA_FLATTEN_BUSES Off -section_id ?
+set_global_assignment -name EDA_MAP_ILLEGAL_CHARACTERS Off -section_id ?
+set_global_assignment -name EDA_GENERATE_TIMING_CLOSURE_DATA Off -section_id ?
+set_global_assignment -name EDA_GENERATE_POWER_INPUT_FILE Off -section_id ?
+set_global_assignment -name EDA_TEST_BENCH_ENABLE_STATUS NOT_USED -section_id ?
+set_global_assignment -name EDA_RTL_SIM_MODE NOT_USED -section_id ?
+set_global_assignment -name EDA_MAINTAIN_DESIGN_HIERARCHY Off -section_id ?
+set_global_assignment -name EDA_GENERATE_FUNCTIONAL_NETLIST Off -section_id ?
+set_global_assignment -name EDA_WRITE_DEVICE_CONTROL_PORTS Off -section_id ?
+set_global_assignment -name EDA_SIMULATION_VCD_OUTPUT_TCL_FILE Off -section_id ?
+set_global_assignment -name EDA_SIMULATION_VCD_OUTPUT_SIGNALS_TO_TCL_FILE "All Except Combinational Logic Element Outputs" -section_id ?
+set_global_assignment -name EDA_ENABLE_GLITCH_FILTERING Off -section_id ?
+set_global_assignment -name EDA_WRITE_NODES_FOR_POWER_ESTIMATION OFF -section_id ?
+set_global_assignment -name EDA_SETUP_HOLD_DETECTION_INPUT_REGISTERS_BIDIR_PINS_DISABLED Off -section_id ?
+set_global_assignment -name EDA_WRITER_DONT_WRITE_TOP_ENTITY Off -section_id ?
+set_global_assignment -name EDA_VHDL_ARCH_NAME structure -section_id ?
+set_global_assignment -name EDA_IBIS_MODEL_SELECTOR Off -section_id ?
+set_global_assignment -name EDA_IBIS_MUTUAL_COUPLING Off -section_id ?
+set_global_assignment -name EDA_FORMAL_VERIFICATION_ALLOW_RETIMING Off -section_id ?
+set_global_assignment -name EDA_BOARD_BOUNDARY_SCAN_OPERATION PRE_CONFIG -section_id ?
+set_global_assignment -name EDA_GENERATE_RTL_SIMULATION_COMMAND_SCRIPT Off -section_id ?
+set_global_assignment -name EDA_GENERATE_GATE_LEVEL_SIMULATION_COMMAND_SCRIPT Off -section_id ?
+set_global_assignment -name SIM_VECTOR_COMPARED_CLOCK_OFFSET 0ns -section_id ?
+set_global_assignment -name SIM_VECTOR_COMPARED_CLOCK_DUTY_CYCLE 50 -section_id ?
+set_global_assignment -name APEX20K_CLIQUE_TYPE LAB -section_id ? -entity ?
+set_global_assignment -name MAX7K_CLIQUE_TYPE LAB -section_id ? -entity ?
+set_global_assignment -name MERCURY_CLIQUE_TYPE LAB -section_id ? -entity ?
+set_global_assignment -name FLEX6K_CLIQUE_TYPE LAB -section_id ? -entity ?
+set_global_assignment -name FLEX10K_CLIQUE_TYPE LAB -section_id ? -entity ?
+set_global_assignment -name PARTITION_IMPORT_ASSIGNMENTS On -section_id ? -entity ?
+set_global_assignment -name PARTITION_IMPORT_EXISTING_ASSIGNMENTS REPLACE_CONFLICTING -section_id ? -entity ?
+set_global_assignment -name PARTITION_IMPORT_EXISTING_LOGICLOCK_REGIONS REPLACE_CONFLICTING -section_id ? -entity ?
+set_global_assignment -name PARTITION_IMPORT_PROMOTE_ASSIGNMENTS On -section_id ? -entity ?
Index: System09_Terasic_DE1/system09.qws
===================================================================
--- System09_Terasic_DE1/system09.qws (nonexistent)
+++ System09_Terasic_DE1/system09.qws (revision 117)
@@ -0,0 +1,18 @@
+[ProjectWorkspace]
+ptn_Child1=Frames
+[ProjectWorkspace.Frames]
+ptn_Child1=ChildFrames
+[ProjectWorkspace.Frames.ChildFrames]
+ptn_Child1=Document-0
+ptn_Child2=Document-1
+ptn_Child3=Document-2
+[ProjectWorkspace.Frames.ChildFrames.Document-0]
+ptn_Child1=ViewFrame-0
+[ProjectWorkspace.Frames.ChildFrames.Document-0.ViewFrame-0]
+DocPathName=../VHDL/ps2_keyboard.vhd
+DocumentCLSID={ca385d57-a4c7-11d1-a098-0020affa43f2}
+IsChildFrameDetached=False
+IsActiveChildFrame=False
+ptn_Child1=StateMap
+[ProjectWorkspace.Frames.ChildFrames.Document-0.ViewFrame-0.StateMap]
+AFC_IN_REPORT=False
Index: System09_Terasic_DE1/System09_Terasic_DE1.vhd.bak
===================================================================
--- System09_Terasic_DE1/System09_Terasic_DE1.vhd.bak (nonexistent)
+++ System09_Terasic_DE1/System09_Terasic_DE1.vhd.bak (revision 117)
@@ -0,0 +1,1116 @@
+--=============================================================================--
+-- --
+-- System09 - Synthesizable System On a Chip - VHDL FPGA core top level file. --
+-- --
+--=============================================================================--
+--
+--
+-- File name : System09_Terasic_DE1.vhd
+--
+-- Entity name : System09
+--
+-- Purpose : Top level file for 6809 compatible system on a chip
+-- Designed with Alera EP2C20 Cyclone 2 FPGA.
+-- Implemented with Terasic DE1 FPGA board,
+--
+-- Dependencies : ieee.Std_Logic_1164
+-- ieee.std_logic_unsigned
+-- ieee.std_logic_arith
+-- ieee.numeric_std
+--
+-- Uses : cpu09 (..\VHDL\cpu09.vhd) CPU core
+-- dat_ram (..\VHDL\datram.vhd) Dynamic Address Translation
+-- mon_rom (..\Cyclone2\mon_rom.vhd) Monitor ROM
+-- acia6850 (..\VHDL\acia6850.vhd) ACIA (UART)
+-- ACIA_Clock (..\VHDL\ACIA_Clock.vhd) ACIA Baud Rate Clock Divider
+-- keyboard (..\VHDL\keyboard.vhd) PS/2 Keyboard register interface
+-- ps2_keyboard (..\VHDL\ps2_keyboard.vhd) PS/2 Keyboard interface logic
+-- keymap_rom (..\Cyclone2\keymap_rom.vhd) PS/2 Keyboard key code look up table
+-- vdu8 (..\VHDL\vdu8.vhd) Video Display Unit
+-- (..\Cyclone2\char_rom.vhd) Character Generator ROM (B16_RAM)
+-- (..\Cyclone2\ram_2k.vhd) Text & Attribute RAM Buffer
+-- seven_segment (..\VHDL\SevenSegment.vhd) Seven Segment Display
+--
+-- Author : John E. Kent
+-- dilbert57@opencores.org
+--
+-- Memory Map :
+--
+-- $0000 - $DFFF System RAM (512K Mapped via DAT)
+-- $E000 - ACIA (SWTPc)
+-- $E010 - Reserved for SWTPc FD-01 FD1771 FDC
+-- $E020 - Keyboard
+-- $E030 - VDU
+-- $E040 - Reserved for SWTPc MP-T (was Compact Flash)
+-- $E050 - Timer
+-- $E060 - Reserved for Bus Trap (Hardware Breakpoint Logic)
+-- $E070 - Reserved for Trace Buffer
+-- $E080 - Reserved for SWTPc MP-ID 6821 PIA (?)
+-- $E090 - Reserved for SWTPc MP-ID 6840 PTM (?)
+-- $E0A0 - Switches in / LEDS out
+-- $E0B0 - 7 Segment hex display
+-- $E0C0 - Reserved
+-- $E0D0 - Reserved
+-- $E0E0 - Reserved
+-- $E0F0 - Reserved
+-- $E100 - $E13F Reserved IDE / Compact Flash Card
+-- $E140 - $E17F Reserved for Ethernet MAC (XESS)
+-- $E180 - $E1BF Reserved for Expansion Slot 0 (XESS)
+-- $E1C0 - $E1FF Reserved for Expansion Slot 1 (XESS)
+-- $E200 - $EFFF Reserved for Future I/O
+-- $F000 - $F7FF RAM for Sys09bug monitor extensions
+-- $F800 - $FFFF Sys09bug ROM (Read only)
+-- $FFF0 - $FFFF DAT - Dynamic Address Translation (Write Only)
+--
+--
+-- Copyright (C) 2003 - 2010 John Kent
+--
+-- This program is free software: you can redistribute it and/or modify
+-- it under the terms of the GNU General Public License as published by
+-- the Free Software Foundation, either version 3 of the License, or
+-- (at your option) any later version.
+--
+-- This program is distributed in the hope that it will be useful,
+-- but WITHOUT ANY WARRANTY; without even the implied warranty of
+-- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+-- GNU General Public License for more details.
+--
+-- You should have received a copy of the GNU General Public License
+-- along with this program. If not, see .
+--
+--===========================================================================--
+--
+-- Revision History:
+--
+--===========================================================================--
+--
+-- Version 0.1 - 20 March 2003
+-- Version 0.2 - 30 March 2003
+-- Version 0.3 - 29 April 2003
+-- Version 0.4 - 29 June 2003
+--
+-- Version 0.5 - 19 July 2003
+-- prints out "Hello World"
+--
+-- Version 0.6 - 5 September 2003
+-- Runs SBUG
+--
+-- Version 1.0- 6 Sep 2003 - John Kent
+-- Inverted sys_clk
+-- Initial release to Open Cores
+--
+-- Version 1.1 - 17 Jan 2004 - John Kent
+-- Updated miniUart.
+--
+-- Version 1.2 - 25 Jan 2004 - John Kent
+-- removed signals "test_alu" and "test_cc"
+-- Trap hardware re-instated.
+--
+-- Version 1.3 - 11 Feb 2004 - John Kent
+-- Designed forked off to produce System09_VDU
+-- Added VDU component
+-- VDU runs at 25MHz and divides the clock by 2 for the CPU
+-- UART Runs at 57.6 Kbps
+--
+-- Version 2.0 - 2 September 2004 - John Kent
+-- ported to Digilent Xilinx Spartan3 starter board
+-- removed Compaact Flash and Trap Logic.
+-- Replaced SBUG with KBug9s
+--
+-- Version 2.1 - 21 November 2006 - John Kent
+-- Replaced KBug9s with Sys09bug 1.0
+-- Inverted bottom nybble of DAT register outputs
+-- Changed ROM & I/O decoding to be compatible with SWTPc
+-- Upped the serial baud rate to 115.2 KBd
+-- added multiple global clock buffers
+-- (Uart would not operate correctly)
+--
+-- Version 2.2 - 22 December 2006 - John Kent
+-- Increased CPU clock from 12.5MHz to 25 MHz.
+-- Removed some of the global clock buffers
+-- Added LED output register
+-- Changed address decoding to 4K Blocks
+--
+-- Version 2.3 - 1 June 2007 - John Kent
+-- Updated VDU & ACIA
+-- Changed decoding for Sys09Bug
+--
+-- Version 2.4 - 31 January 2008 - John Kent
+-- ACIA does not appear to work.
+-- Made RAM OE and WE strobes synchonous to sys_clk
+--
+-- Version 2.5 - 23rd Feburary 2009 - John Kent
+-- Implemented recommendation to remove vga_clk clock buffer
+--
+-- Version 2.6 - 5th september 2010 - John Kent
+-- Renamed ACIA_6850 to acia6850
+-- Updated generics on VDU8
+-- Shortened the "keyboard" label
+-- Fixed up address label on CPU09
+-- Removed Flex RAM
+-- Map RAM at $F000 - $F7FF
+--
+-- Vesrion 2.7 - 22nd October 2010 - John Kent
+-- Ported from Digilent XC3S200 Starter to
+-- Terasic EP2C20 DE1 board.
+--
+--===========================================================================--
+library ieee;
+ use ieee.std_logic_1164.all;
+ use IEEE.STD_LOGIC_ARITH.ALL;
+ use IEEE.STD_LOGIC_UNSIGNED.ALL;
+ use ieee.numeric_std.all;
+
+entity System09_Terasic_DE1 is
+ port(
+ -- clocks
+ clock_24 : in std_logic_vector(1 downto 0);
+ clock_27 : in std_logic;
+ clock_50 : in std_logic; -- System Clock input
+ ext_clock : in std_logic;
+
+ -- push button keys
+ key : in std_logic_vector(3 downto 0); -- RST, NMI
+
+ -- SRAM interface signals
+
+ sram_ce_n : out std_logic;
+ sram_we_n : out std_logic;
+ sram_oe_n : out std_logic;
+ sram_ub_n : out std_logic;
+ sram_lb_n : out std_logic;
+ sram_addr : out std_logic_vector(17 downto 0);
+ sram_dq : inout std_logic_vector(15 downto 0);
+
+ -- PS/2 Keyboard
+ ps2_clk : inout Std_logic;
+ ps2_dat : inout Std_Logic;
+
+ -- ACIA/UART Interface
+ uart_rxd : in Std_Logic;
+ uart_txd : out Std_Logic;
+
+ -- CRTC output signals
+ vga_r : out std_logic_vector(3 downto 0);
+ vga_g : out std_logic_vector(3 downto 0);
+ vga_b : out std_logic_vector(3 downto 0);
+ vga_hs : out Std_Logic;
+ vga_vs : out Std_Logic;
+
+ -- LEDS & Switches
+ ledg : out std_logic_vector(7 downto 0);
+ ledr : out std_logic_vector(9 downto 0);
+ sw : in std_logic_vector(9 downto 0);
+
+ -- hexadecimal display
+ hex0 : out std_logic_vector(6 downto 0);
+ hex1 : out std_logic_vector(6 downto 0);
+ hex2 : out std_logic_vector(6 downto 0);
+ hex3 : out std_logic_vector(6 downto 0);
+
+ -- gnereal purpose I/O
+ gpio_0 : in std_logic_vector(35 downto 0);
+ gpio_1 : in std_logic_vector(35 downto 0);
+
+ -- i2c interface
+ i2c_sclk : in std_logic;
+ i2c_sdat : in std_logic;
+
+ -- audio codec
+ aud_adcdat : in std_logic;
+ aud_adclrck : in std_logic;
+ aud_bclk : in std_logic;
+ aud_dacdat : in std_logic;
+ aud_daclrck : in std_logic;
+ aud_xck : in std_logic;
+
+ -- dram
+ dram_addr : out std_logic_vector(11 downto 0);
+ dram_dq : in std_logic_vector(15 downto 0);
+ dram_cs_n : out std_logic;
+ dram_ba_0 : in std_logic;
+ dram_ba_1 : in std_logic;
+ dram_ldqm : in std_logic;
+ dram_udqm : in std_logic;
+ dram_ras_n : out std_logic;
+ dram_cas_n : out std_logic;
+ dram_we_n : out std_logic;
+ dram_cke : in std_logic;
+ dram_clk : in std_logic;
+
+ -- Flash memory
+ fl_addr : out std_logic_vector(21 downto 0);
+ fl_dq : in std_logic_vector(7 downto 0);
+ fl_rst_n : in std_logic;
+ fl_oe_n : out std_logic;
+ fl_we_n : out std_logic;
+
+ -- JTAG
+ tck : in std_logic;
+ tcs : in std_logic;
+ tdi : in std_logic;
+ tdo : in std_logic
+ );
+end System09_Terasic_DE1;
+
+-------------------------------------------------------------------------------
+-- Architecture for System09
+-------------------------------------------------------------------------------
+architecture my_computer of System09_Terasic_DE1 is
+ -----------------------------------------------------------------------------
+ -- constants
+ -----------------------------------------------------------------------------
+ constant SYS_CLK_FREQ : integer := 50000000; -- FPGA System Clock
+ constant VGA_CLK_FREQ : integer := 25000000; -- VGA Pixel Clock
+ constant CPU_CLK_FREQ : integer := 25000000; -- CPU Clock
+ constant BAUD_Rate : integer := 57600; -- Baud Rate
+ constant ACIA_CLK_FREQ : integer := BAUD_Rate * 16;
+
+ type hold_state_type is ( hold_release_state, hold_request_state );
+
+ -----------------------------------------------------------------------------
+ -- Signals
+ -----------------------------------------------------------------------------
+
+ signal sys_clk : std_logic;
+ signal vga_clk : std_logic;
+ signal pll_locked : std_logic;
+
+ -- CPU Interface signals
+ signal cpu_clk : std_logic;
+ signal cpu_rst : std_logic;
+ signal cpu_rw : std_logic;
+ signal cpu_vma : std_logic;
+ signal cpu_halt : std_logic;
+ signal cpu_hold : std_logic;
+ signal cpu_firq : std_logic;
+ signal cpu_irq : std_logic;
+ signal cpu_nmi : std_logic;
+ signal cpu_addr : std_logic_vector(15 downto 0);
+ signal cpu_data_in : std_logic_vector(7 downto 0);
+ signal cpu_data_out : std_logic_vector(7 downto 0);
+
+ -- Dynamic Address Translation
+ signal dat_cs : std_logic;
+ signal dat_addr : std_logic_vector(7 downto 0);
+
+ -- BOOT ROM
+ signal rom_cs : Std_logic;
+ signal rom_data_out : Std_Logic_Vector(7 downto 0);
+
+ -- ACIA Interface signals
+ signal acia_clk : std_logic;
+ signal acia_cs : Std_Logic;
+ signal acia_data_out : Std_Logic_Vector(7 downto 0);
+ signal acia_irq : Std_Logic;
+ signal acia_rxd : Std_Logic;
+ signal acia_txd : Std_Logic;
+ signal acia_dcd_n : Std_Logic;
+-- signal acia_rts_n : Std_Logic;
+ signal acia_cts_n : Std_Logic;
+
+ -- keyboard port
+ signal kbd_data_out : std_logic_vector(7 downto 0);
+ signal kbd_cs : std_logic;
+ signal kbd_irq : std_logic;
+
+ -- LEDs
+ signal leds_data_out : std_logic_vector(7 downto 0);
+ signal leds_cs : std_logic;
+
+ -- Video Display Unit
+ signal vdu_cs : std_logic;
+ signal vdu_data_out : std_logic_vector(7 downto 0);
+ signal vga_red : std_logic;
+ signal vga_green : std_logic;
+ signal vga_blue : std_logic;
+
+ -- LEDs
+ signal led_cs : std_logic;
+ signal led_data_out : std_logic_vector(7 downto 0);
+
+ -- 7 Segment Display
+ signal hex_cs : std_logic;
+ signal hex_data_out : std_logic_vector(7 downto 0);
+ signal hex0_reg : std_logic_vector(7 downto 0);
+ signal hex1_reg : std_logic_vector(7 downto 0);
+ signal hex2_reg : std_logic_vector(7 downto 0);
+ signal hex3_reg : std_logic_vector(7 downto 0);
+
+ -- interrupt timer
+ signal tmr_data_out : std_logic_vector(7 downto 0);
+ signal tmr_cs : std_logic;
+ signal tmr_irq : std_logic;
+
+ -- hardware break point (trap)
+ signal hbp_data_out : std_logic_vector(7 downto 0);
+ signal hbp_cs : std_logic;
+ signal hbp_irq : std_logic;
+
+ -- RAM
+ signal sram_cs : std_logic; -- memory chip select
+ signal sram_data_out : std_logic_vector(7 downto 0);
+ signal sram_ce : std_logic;
+ signal sram_ub : std_logic;
+ signal sram_lb : std_logic;
+ signal sram_we : std_logic;
+ signal sram_oe : std_logic;
+
+ -- System Clock Prescaler
+ signal clk_count : std_logic;
+
+-----------------------------------------------------------------
+--
+-- CPU09 CPU core
+--
+-----------------------------------------------------------------
+
+component cpu09
+ port (
+ clk : in std_logic;
+ rst : in std_logic;
+ vma : out std_logic;
+ addr : out std_logic_vector(15 downto 0);
+ rw : out std_logic;
+ data_in : in std_logic_vector(7 downto 0);
+ data_out : out std_logic_vector(7 downto 0);
+ halt : in std_logic;
+ hold : in std_logic;
+ irq : in std_logic;
+ nmi : in std_logic;
+ firq : in std_logic
+ );
+end component;
+
+----------------------------------------
+--
+-- Dynamic Address Translation Registers
+--
+----------------------------------------
+component dat_ram
+ port (
+ clk : in std_logic;
+ rst : in std_logic;
+ cs : in std_logic;
+ rw : in std_logic;
+ addr_lo : in std_logic_vector(3 downto 0);
+ addr_hi : in std_logic_vector(3 downto 0);
+ data_in : in std_logic_vector(7 downto 0);
+ data_out : out std_logic_vector(7 downto 0)
+ );
+end component;
+
+----------------------------------------
+--
+-- 4KByte Block RAM Monitor ROM
+--
+----------------------------------------
+component mon_rom
+ Port (
+ clk : in std_logic;
+ rst : in std_logic;
+ cs : in std_logic;
+ rw : in std_logic;
+ addr : in std_logic_vector (10 downto 0);
+ data_in : in std_logic_vector (7 downto 0);
+ data_out : out std_logic_vector (7 downto 0)
+ );
+end component;
+
+-----------------------------------------------------------------
+--
+-- 6850 ACIA
+--
+-----------------------------------------------------------------
+
+component acia6850
+ port (
+ clk : in Std_Logic; -- System Clock
+ rst : in Std_Logic; -- Reset input (active high)
+ cs : in Std_Logic; -- ACIA Chip Select
+ rw : in Std_Logic; -- Read / Not Write
+ addr : in Std_Logic; -- Register Select
+ data_in : in Std_Logic_Vector(7 downto 0); -- Data Bus In
+ data_out : out Std_Logic_Vector(7 downto 0); -- Data Bus Out
+ irq : out Std_Logic; -- Interrupt
+ RxC : in Std_Logic; -- Receive Baud Clock
+ TxC : in Std_Logic; -- Transmit Baud Clock
+ RxD : in Std_Logic; -- Receive Data
+ TxD : out Std_Logic; -- Transmit Data
+ DCD_n : in Std_Logic; -- Data Carrier Detect
+ CTS_n : in Std_Logic; -- Clear To Send
+ RTS_n : out Std_Logic -- Request To send
+ );
+end component;
+
+-----------------------------------------------------------------
+--
+-- ACIA Clock divider
+--
+-----------------------------------------------------------------
+
+component ACIA_Clock
+ generic (
+ SYS_CLK_FREQ : integer := SYS_CLK_FREQ;
+ ACIA_CLK_FREQ : integer := ACIA_CLK_FREQ
+ );
+ port (
+ clk : in Std_Logic; -- System Clock Input
+ acia_clk : out Std_logic -- ACIA Clock output
+ );
+end component;
+
+----------------------------------------
+--
+-- PS/2 Keyboard
+--
+----------------------------------------
+
+component keyboard
+ generic(
+ KBD_CLK_FREQ : integer := CPU_CLK_FREQ
+ );
+ port(
+ clk : in std_logic;
+ rst : in std_logic;
+ cs : in std_logic;
+ addr : in std_logic;
+ rw : in std_logic;
+ data_in : in std_logic_vector(7 downto 0);
+ data_out : out std_logic_vector(7 downto 0);
+ irq : out std_logic;
+ kbd_clk : inout std_logic;
+ kbd_data : inout std_logic
+ );
+end component;
+
+----------------------------------------
+--
+-- Video Display Unit.
+--
+----------------------------------------
+component vdu8
+ generic(
+ VGA_CLK_FREQ : integer := VGA_CLK_FREQ; -- HZ
+ VGA_HOR_CHARS : integer := 80; -- CHARACTERS 25.6us
+ VGA_HOR_CHAR_PIXELS : integer := 8; -- PIXELS 0.32us
+ VGA_HOR_FRONT_PORCH : integer := 16; -- PIXELS 0.64us
+ VGA_HOR_SYNC : integer := 96; -- PIXELS 3.84us
+ VGA_HOR_BACK_PORCH : integer := 48; -- PIXELS 1.92us
+ VGA_VER_CHARS : integer := 25; -- CHARACTERS 12.8ms
+ VGA_VER_CHAR_LINES : integer := 16; -- LINES 0.512ms
+ VGA_VER_FRONT_PORCH : integer := 10; -- LINES 0.320ms
+ VGA_VER_SYNC : integer := 2; -- LINES 0.064ms
+ VGA_VER_BACK_PORCH : integer := 34 -- LINES 1.088ms
+ );
+ port(
+ -- control register interface
+ vdu_clk : in std_logic; -- CPU Clock - 12.5MHz
+ vdu_rst : in std_logic;
+ vdu_cs : in std_logic;
+ vdu_rw : in std_logic;
+ vdu_addr : in std_logic_vector(2 downto 0);
+ vdu_data_in : in std_logic_vector(7 downto 0);
+ vdu_data_out : out std_logic_vector(7 downto 0);
+
+ -- vga port connections
+ vga_clk : in std_logic; -- VGA Pixel Clock - 25 MHz
+ vga_red_o : out std_logic;
+ vga_green_o : out std_logic;
+ vga_blue_o : out std_logic;
+ vga_hsync_o : out std_logic;
+ vga_vsync_o : out std_logic
+ );
+end component;
+
+----------------------------------------
+--
+-- Interrupt timer
+--
+----------------------------------------
+
+component timer is
+ port (
+ clk : in std_logic;
+ rst : in std_logic;
+ cs : in std_logic;
+ addr : in std_logic;
+ rw : in std_logic;
+ data_in : in std_logic_vector(7 downto 0);
+ data_out : out std_logic_vector(7 downto 0);
+ irq : out std_logic
+ );
+end component;
+
+----------------------------------------
+--
+-- hardware break point (bus trap)
+--
+----------------------------------------
+
+component trap is
+ port (
+ clk : in std_logic;
+ rst : in std_logic;
+ cs : in std_logic;
+ rw : in std_logic;
+ vma : in std_logic;
+ addr : in std_logic_vector(15 downto 0);
+ data_in : in std_logic_vector(7 downto 0);
+ data_out : out std_logic_vector(7 downto 0);
+ irq : out std_logic
+ );
+end component;
+
+
+component pll IS
+ PORT
+ (
+ areset : IN STD_LOGIC := '0';
+ inclk0 : IN STD_LOGIC := '0';
+ c0 : OUT STD_LOGIC ;
+ c1 : OUT STD_LOGIC ;
+ c2 : OUT STD_LOGIC ;
+ locked : OUT STD_LOGIC
+ );
+END component;
+
+begin
+ -----------------------------------------------------------------------------
+ -- Instantiation of internal components
+ -----------------------------------------------------------------------------
+
+my_cpu : cpu09 port map (
+ clk => cpu_clk,
+ rst => cpu_rst,
+ vma => cpu_vma,
+ addr => cpu_addr(15 downto 0),
+ rw => cpu_rw,
+ data_in => cpu_data_in,
+ data_out => cpu_data_out,
+ halt => cpu_halt,
+ hold => cpu_hold,
+ irq => cpu_irq,
+ nmi => cpu_nmi,
+ firq => cpu_firq
+ );
+
+my_dat : dat_ram port map (
+ clk => cpu_clk,
+ rst => cpu_rst,
+ cs => dat_cs,
+ addr_hi => cpu_addr(15 downto 12),
+ addr_lo => cpu_addr(3 downto 0),
+ rw => cpu_rw,
+ data_in => cpu_data_out,
+ data_out => dat_addr(7 downto 0)
+ );
+
+my_rom : mon_rom port map (
+ clk => cpu_clk,
+ rst => cpu_rst,
+ cs => rom_cs,
+ rw => '1',
+ addr => cpu_addr(10 downto 0),
+ data_in => cpu_data_out,
+ data_out => rom_data_out
+ );
+
+my_acia : acia6850 port map (
+ clk => cpu_clk,
+ rst => cpu_rst,
+ cs => acia_cs,
+ addr => cpu_addr(0),
+ rw => cpu_rw,
+ data_in => cpu_data_out,
+ data_out => acia_data_out,
+ irq => acia_irq,
+ RxC => acia_clk,
+ TxC => acia_clk,
+ RxD => acia_rxd,
+ TxD => acia_txd,
+ DCD_n => acia_dcd_n,
+ CTS_n => acia_cts_n,
+ RTS_n => open
+ );
+
+
+----------------------------------------
+--
+-- ACIA Clock
+--
+----------------------------------------
+my_ACIA_Clock : ACIA_Clock
+ generic map(
+ SYS_CLK_FREQ => SYS_CLK_FREQ,
+ ACIA_CLK_FREQ => ACIA_CLK_FREQ
+ )
+ port map(
+ clk => sys_clk,
+ acia_clk => acia_clk
+ );
+
+
+----------------------------------------
+--
+-- PS/2 Keyboard Interface
+--
+----------------------------------------
+my_keyboard : keyboard
+ generic map (
+ KBD_CLK_FREQ => CPU_CLK_FREQ
+ )
+ port map(
+ clk => cpu_clk,
+ rst => cpu_rst,
+ cs => kbd_cs,
+ addr => cpu_addr(0),
+ rw => cpu_rw,
+ data_in => cpu_data_out(7 downto 0),
+ data_out => kbd_data_out(7 downto 0),
+ irq => kbd_irq,
+ kbd_clk => ps2_clk,
+ kbd_data => ps2_dat
+ );
+
+----------------------------------------
+--
+-- Video Display Unit instantiation
+--
+----------------------------------------
+my_vdu : vdu8
+ generic map(
+ VGA_CLK_FREQ => VGA_CLK_FREQ, -- 25MHZ
+ VGA_HOR_CHARS => 80, -- CHARACTERS 25.6us
+ VGA_HOR_CHAR_PIXELS => 8, -- PIXELS 0.32us
+ VGA_HOR_FRONT_PORCH => 16, -- PIXELS 0.64us
+ VGA_HOR_SYNC => 96, -- PIXELS 3.84us
+ VGA_HOR_BACK_PORCH => 48, -- PIXELS 1.92us
+ VGA_VER_CHARS => 25, -- CHARACTERS 12.8ms
+ VGA_VER_CHAR_LINES => 16, -- LINES 0.512ms
+ VGA_VER_FRONT_PORCH => 10, -- LINES 0.320ms
+ VGA_VER_SYNC => 2, -- LINES 0.064ms
+ VGA_VER_BACK_PORCH => 34 -- LINES 1.088ms
+ )
+ port map(
+
+ -- Control Registers
+ vdu_clk => cpu_clk, -- 12.5 MHz System Clock in
+ vdu_rst => cpu_rst,
+ vdu_cs => vdu_cs,
+ vdu_addr => cpu_addr(2 downto 0),
+ vdu_rw => cpu_rw,
+ vdu_data_in => cpu_data_out,
+ vdu_data_out => vdu_data_out,
+
+ -- vga port connections
+ vga_clk => vga_clk, -- 25 MHz pixel clock
+ vga_red_o => vga_red,
+ vga_green_o => vga_green,
+ vga_blue_o => vga_blue,
+ vga_hsync_o => vga_hs,
+ vga_vsync_o => vga_vs
+ );
+
+----------------------------------------
+--
+-- Interrupt timer
+--
+----------------------------------------
+
+my_timer : timer
+ port map (
+ clk => cpu_clk,
+ rst => cpu_rst,
+ cs => tmr_cs,
+ addr => cpu_addr(0),
+ rw => cpu_rw,
+ data_in => cpu_data_out,
+ data_out => tmr_data_out,
+ irq => tmr_irq
+ );
+
+----------------------------------------
+--
+-- hardware break point (bus trap)
+--
+----------------------------------------
+
+my_hw_bp : trap
+ port map (
+ clk => cpu_clk,
+ rst => cpu_rst,
+ cs => hbp_cs,
+ rw => cpu_rw,
+ vma => cpu_vma,
+ addr => cpu_addr,
+ data_in => cpu_data_out,
+ data_out => hbp_data_out,
+ irq => hbp_irq
+ );
+
+----------------------------------------
+--
+-- Phase Locked Loop Clock divider
+--
+
+my_pll : pll
+ PORT MAP
+ (
+ areset => '0',
+ inclk0 => clock_50,
+ c0 => sys_clk,
+ c1 => cpu_clk,
+ c2 => vga_clk,
+ locked => pll_locked
+ );
+
+----------------------------------------------------------------------
+--
+-- Process to decode memory map
+--
+----------------------------------------------------------------------
+
+mem_decode: process( cpu_addr, cpu_rw, cpu_vma,
+ dat_cs, dat_addr,
+ rom_data_out,
+ acia_data_out,
+ kbd_data_out,
+ vdu_data_out,
+ hex_data_out,
+ led_data_out,
+ tmr_data_out,
+ hbp_data_out,
+ sram_data_out
+ )
+begin
+ cpu_data_in <= (others=>'0');
+ dat_cs <= '0';
+ rom_cs <= '0';
+ acia_cs <= '0';
+ kbd_cs <= '0';
+ vdu_cs <= '0';
+ hex_cs <= '0';
+ led_cs <= '0';
+ sram_cs <= '0';
+ tmr_cs <= '0';
+ hbp_cs <= '0';
+-- pb_cs <= '0';
+-- ide_cs <= '0';
+-- ether_cs <= '0';
+-- slot1_cs <= '0';
+-- slot2_cs <= '0';
+
+ if cpu_addr( 15 downto 8 ) = "11111111" then
+ cpu_data_in <= rom_data_out;
+ dat_cs <= cpu_vma; -- write DAT
+ rom_cs <= cpu_vma; -- read ROM
+ --
+ -- Sys09Bug Monitor ROM $F000 - $FFFF
+ --
+ elsif dat_addr(3 downto 0) = "1111" then -- $XF000 - $XFFFF
+ if cpu_addr(11) = '1' then
+ --
+ -- Monitor ROM $F800 - $FFFF
+ --
+ cpu_data_in <= rom_data_out;
+ rom_cs <= cpu_vma; -- read ROM
+ else
+ --
+ -- SRAM $F000 - $F7FF
+ --
+ cpu_data_in <= sram_data_out;
+ sram_cs <= cpu_vma;
+ end if;
+ --
+ -- IO Devices $E000 - $EFFF
+ --
+ elsif dat_addr(3 downto 0) = "1110" then -- $XE000 - $XEFFF
+ case cpu_addr(11 downto 8) is
+ --
+ -- SWTPC peripherals from $E000 to $E0FF
+ --
+ when "0000" =>
+ case cpu_addr(7 downto 4) is
+ --
+ -- ACIA ($E000 - $E00F)
+ --
+ when "0000" =>
+ cpu_data_in <= acia_data_out;
+ acia_cs <= cpu_vma;
+
+ --
+ -- Reserved - FD1771 FDC ($E010 - $E01F) (SWTPC)
+ --
+
+ --
+ -- Keyboard port ($E020 - $E02F)
+ --
+ when "0010" =>
+ cpu_data_in <= kbd_data_out;
+ kbd_cs <= cpu_vma;
+
+ --
+ -- VDU port ($E030 - $E03F)
+ --
+ when "0011" =>
+ cpu_data_in <= vdu_data_out;
+ vdu_cs <= cpu_vma;
+
+ --
+ -- Reserved - SWTPc MP-T ($E040 - $E04F)
+ --
+
+ --
+ -- Reserved - Timer ($E050 - $E05F) (B5-X300)
+ --
+ when "0101" =>
+ cpu_data_in <= tmr_data_out;
+ tmr_cs <= cpu_vma;
+
+ --
+ -- Reserved - hardware break point (Bus Trap) ($E060 - $E06F)
+ --
+ when "0110" =>
+ cpu_data_in <= hbp_data_out;
+ hbp_cs <= cpu_vma;
+
+ --
+ -- Reserved - I/O port ($E070 - $E07F) (B5-X300)
+ --
+
+ --
+ -- Reserved - PTM 6840 ($E080 - $E08F) (SWTPC)
+ --
+
+ --
+ -- Reserved - PIA Timer ($E090 - $E09F) (SWTPC)
+ --
+
+ --
+ -- Read Switched port ($E0A0 - $E0AF)
+ -- Write LEDS
+ --
+ when "1010" =>
+ cpu_data_in <= led_data_out;
+ led_cs <= cpu_vma;
+
+ --
+ -- 7 segment display port ($E0B0 - $E0BF)
+ --
+ when "1011" =>
+ cpu_data_in <= hex_data_out;
+ hex_cs <= cpu_vma;
+
+
+ when others => -- $EXC0 to $EXFF
+ null;
+ end case;
+ --
+ -- $E100 to $EFFF reserved for future use
+ --
+ when others =>
+ null;
+ end case;
+ --
+ -- Everything else is RAM
+ --
+ else
+ cpu_data_in <= sram_data_out;
+ sram_cs <= cpu_vma;
+ end if;
+end process;
+
+
+--
+-- 1M byte SRAM Control
+-- Processes to read and write memory based on bus signals
+--
+sram_process: process( sys_clk, cpu_rst,
+ cpu_addr, cpu_rw, cpu_vma, cpu_data_out,
+ dat_addr, sram_cs,
+ sram_ce, sram_ub, sram_lb, sram_dq,
+ sram_we, sram_oe )
+begin
+ --
+ -- Clock Hold on rising edge
+ --
+ if( sys_clk'event and sys_clk='1' ) then
+ --
+ -- sram_hold signal helps
+ --
+ if( cpu_rst = '1' ) then
+ sram_we <= '0';
+ sram_oe <= '0';
+ else
+ if (sram_cs = '1') and (sram_we = '0') and (sram_oe = '0') then
+ sram_we <= not cpu_rw;
+ sram_oe <= cpu_rw;
+ else
+ sram_we <= '0';
+ sram_oe <= '0';
+ end if;
+ end if;
+ end if;
+
+ sram_we_n <= not sram_we;
+ sram_oe_n <= not sram_oe;
+
+ sram_ce <= sram_cs;
+ sram_ub <= not cpu_addr(0);
+ sram_lb <= cpu_addr(0);
+ sram_ce_n <= not sram_ce;
+ sram_ub_n <= not sram_ub;
+ sram_lb_n <= not sram_lb;
+
+ sram_addr(17 downto 11) <= dat_addr(6 downto 0);
+ sram_addr(10 downto 0) <= cpu_addr(11 downto 1);
+
+ if sram_we = '1' and sram_ce = '1' and sram_lb = '1' then
+ sram_dq(7 downto 0) <= cpu_data_out;
+ else
+ sram_dq(7 downto 0) <= "ZZZZZZZZ";
+ end if;
+
+ if sram_we = '1' and sram_ce = '1' and sram_ub = '1' then
+ sram_dq(15 downto 8) <= cpu_data_out;
+ else
+ sram_dq(15 downto 8) <= "ZZZZZZZZ";
+ end if;
+
+ if cpu_addr(0) = '0' then
+ sram_data_out <= sram_dq(15 downto 8);
+ else
+ sram_data_out <= sram_dq(7 downto 0);
+ end if;
+
+end process;
+
+--
+-- LEDS output register
+--
+led_output : process( cpu_clk, cpu_rst, led_cs, cpu_rw, cpu_addr, cpu_data_out, sw )
+begin
+ if cpu_clk'event and cpu_clk='0' then
+ if cpu_rst = '1' then
+ ledr <= (others=>'0');
+ ledg <= (others=>'0');
+ else
+ if led_cs = '1' and cpu_rw = '0' then
+ if cpu_addr(0) = '0' then
+ ledr(7 downto 0) <= cpu_data_out;
+ else
+ ledg(7 downto 0) <= cpu_data_out;
+ end if;
+ end if;
+ end if;
+ end if;
+ led_data_out <= sw(7 downto 0);
+end process;
+
+--
+-- 7 segment HEX display output register
+--
+hex_output : process( cpu_clk, cpu_rst, hex_cs, cpu_rw, cpu_addr, cpu_data_out,
+ hex0_reg, hex1_reg, hex2_reg, hex3_reg )
+begin
+ if cpu_clk'event and cpu_clk='0' then
+ if cpu_rst = '1' then
+ hex0_reg <= (others=>'0');
+ hex1_reg <= (others=>'0');
+ hex2_reg <= (others=>'0');
+ hex3_reg <= (others=>'0');
+ else
+ if hex_cs = '1' and cpu_rw = '0' then
+ case cpu_addr(1 downto 0) is
+ when "00" =>
+ hex0_reg <= cpu_data_out;
+ when "01" =>
+ hex1_reg <= cpu_data_out;
+ when "10" =>
+ hex2_reg <= cpu_data_out;
+ when "11" =>
+ hex3_reg <= cpu_data_out;
+ end case;
+ end if;
+ end if;
+ end if;
+
+ case cpu_addr(1 downto 0) is
+ when "00" =>
+ hex_data_out <= hex0_reg;
+ when "01" =>
+ hex_data_out <= hex1_reg;
+ when "10" =>
+ hex_data_out <= hex2_reg;
+ when "11" =>
+ hex_data_out <= hex3_reg;
+ end case;
+
+ hex0 <= not hex0_reg(6 downto 0);
+ hex1 <= not hex1_reg(6 downto 0);
+ hex2 <= not hex2_reg(6 downto 0);
+ hex3 <= not hex3_reg(6 downto 0);
+
+end process;
+
+--
+-- Interrupts and other bus control signals
+--
+interrupts : process( key, pll_locked,
+ acia_irq, kbd_irq, hbp_irq, tmr_irq )
+begin
+ cpu_rst <= not key(0); -- CPU reset is active high
+ cpu_firq <= kbd_irq;
+ cpu_nmi <= (not key(1)) or hbp_irq;
+ cpu_irq <= acia_irq or tmr_irq;
+ cpu_halt <= '0';
+ cpu_hold <= '0';
+end process;
+
+--
+-- ACIA pin assignments
+--
+acia_assignments : process( uart_rxd, acia_txd )
+begin
+ acia_dcd_n <= '0';
+ acia_cts_n <= '0';
+ acia_rxd <= uart_rxd;
+ uart_txd <= acia_txd;
+end process;
+
+--
+-- assign vga colour bits to single bit RGB output of VDU
+--
+vga_assignments : process( vga_red, vga_green, vga_blue )
+begin
+ vga_r <= (others=>vga_red);
+ vga_g <= (others=>vga_green);
+ vga_b <= (others=>vga_blue);
+end process;
+
+--
+-- assign dram signals
+--
+dram_assign : process( all )
+begin
+ dram_addr <= (others=>'0');
+ dram_cs_n <= '1';
+ dram_ras_n <= '1';
+ dram_cas_n <= '1';
+ dram_we_n <= '1';
+end process;
+
+--
+-- assign flash memory signals
+--
+flash_assign : process( all )
+begin
+ fl_addr <= (others=>'0');
+ fl_oe_n <= '1';
+ fl_we_n <= '1';
+
+end process;
+
+end my_computer; --===================== End of architecture =======================--
+
Index: System09_Terasic_DE1/undo_redo.txt
===================================================================
--- System09_Terasic_DE1/undo_redo.txt (nonexistent)
+++ System09_Terasic_DE1/undo_redo.txt (revision 117)
@@ -0,0 +1,15 @@
+RPW
+
+ Undo Commands
+ 1. ||Compilation Report||Flow Summary
+ 2. ||Compilation Report||Timing Analyzer||Clock Hold: 'pll:my_pll|altpll:altpll_component|_clk2'
+ 3. ||Compilation Report||Timing Analyzer||Clock Hold: 'pll:my_pll|altpll:altpll_component|_clk1'
+ 4. ||Compilation Report||Timing Analyzer||Clock Hold: 'pll:my_pll|altpll:altpll_component|_clk0'
+ 5. ||Compilation Report||Timing Analyzer||Clock Setup: 'pll:my_pll|altpll:altpll_component|_clk2'
+ 6. ||Compilation Report||Timing Analyzer||Clock Setup: 'pll:my_pll|altpll:altpll_component|_clk1'
+ 7. ||Compilation Report||Timing Analyzer||Clock Setup: 'pll:my_pll|altpll:altpll_component|_clk0'
+ 8. ||Compilation Report||Timing Analyzer||Clock Settings Summary
+ 9. ||Compilation Report||Flow Summary
+ 10. ||Compilation Report||Timing Analyzer||Timing Analyzer Summary
+
+