URL
https://opencores.org/ocsvn/socgen/socgen/trunk
Subversion Repositories socgen
Compare Revisions
- This comparison shows the changes necessary to convert path
/socgen
- from Rev 43 to Rev 44
- ↔ Reverse comparison
Rev 43 → Rev 44
/trunk/bench/verilog/models/ic_test_probe.v
0,0 → 1,54
|
|
|
module ic_test_probe (signal,assert_value,drive_value,clk,tgen_out,probe_type ); |
|
parameter SIGNAL_NAME = "undefined"; |
parameter SIGNAL_WIDTH = 1; |
|
|
output [SIGNAL_WIDTH-1:0] signal; |
input [SIGNAL_WIDTH-1:0] drive_value; |
input [SIGNAL_WIDTH-1:0] assert_value; |
input clk; |
input tgen_out; |
input [1:0] probe_type; |
|
|
wire [SIGNAL_WIDTH-1:0] signal; |
|
reg [SIGNAL_WIDTH-1:0] drive_latch; |
reg [SIGNAL_WIDTH-1:0] test; |
|
initial |
begin |
drive_latch = {SIGNAL_WIDTH{1'bz}}; |
test = {SIGNAL_WIDTH{1'bz}}; |
end |
|
|
|
always@(drive_value or tgen_out) |
if(tgen_out) drive_latch = drive_value; |
else drive_latch = drive_latch; |
|
always@( probe_type or drive_value or tgen_out) |
if(tgen_out) test = drive_value; |
else |
case(probe_type) |
2'b00: test = drive_latch; |
2'b01: test = ~drive_latch; |
2'b10: test = {SIGNAL_WIDTH{1'b0}}; |
2'b11: test = {SIGNAL_WIDTH{1'b1}}; |
endcase // case(probe_type) |
|
|
|
assign signal = test; |
|
|
|
|
|
endmodule |
|
trunk/bench/verilog/models/ic_test_probe.v
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/lib/cde_lifo/cde_lifo.v
===================================================================
--- trunk/lib/cde_lifo/cde_lifo.v (nonexistent)
+++ trunk/lib/cde_lifo/cde_lifo.v (revision 44)
@@ -0,0 +1,124 @@
+/**********************************************************************/
+/* */
+/* ------- */
+/* / SOC \ */
+/* / GEN \ */
+/* / LIB \ */
+/* ============== */
+/* | | */
+/* |____________| */
+/* */
+/* Generic model for a lifo */
+/* */
+/* */
+/* Author(s): */
+/* - John Eaton, jt_eaton@opencores.org */
+/* */
+/**********************************************************************/
+/* */
+/* Copyright (C) <2010> */
+/* */
+/* This source file may be used and distributed without */
+/* restriction provided that this copyright statement is not */
+/* removed from the file and that any derivative work contains */
+/* the original copyright notice and the associated disclaimer. */
+/* */
+/* This source file is free software; you can redistribute it */
+/* and/or modify it under the terms of the GNU Lesser General */
+/* Public License as published by the Free Software Foundation; */
+/* either version 2.1 of the License, or (at your option) any */
+/* later version. */
+/* */
+/* This source 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 Lesser General Public License for more */
+/* details. */
+/* */
+/* You should have received a copy of the GNU Lesser General */
+/* Public License along with this source; if not, download it */
+/* from http://www.opencores.org/lgpl.shtml */
+/* */
+/**********************************************************************/
+
+
+
+
+
+module
+cde_lifo
+#(parameter WIDTH = 8,
+ parameter SIZE = 2, // DEPTH = 2 ^ SIZE
+ parameter WORDS = 4
+)
+
+(
+input wire clk,
+input wire reset,
+input wire push,
+input wire [WIDTH-1:0] din,
+input wire pop,
+output wire [WIDTH-1:0] dout
+
+);
+
+
+
+reg [SIZE-1:0] push_pointer;
+reg [SIZE-1:0] pop_pointer;
+
+
+
+
+always@(posedge clk)
+ if(reset)
+ push_pointer <= {SIZE{1'b0}};
+ else
+ if( push && ~pop) push_pointer <= push_pointer + 1;
+ else
+ if(~push && pop) push_pointer <= push_pointer - 1;
+ else
+ push_pointer <= push_pointer;
+
+
+
+
+always@(posedge clk)
+ if(reset)
+ pop_pointer <= {SIZE{1'b1}};
+ else
+ if( push && ~pop) pop_pointer <= pop_pointer + 1;
+ else
+ if(~push && pop) pop_pointer <= pop_pointer - 1;
+ else
+ pop_pointer <= pop_pointer;
+
+
+
+
+
+
+
+
+
+cde_sram
+ #(.ADDR (SIZE),
+ .WIDTH (WIDTH),
+ .WORDS (WORDS)
+ )
+fifo
+ (
+ .clk ( clk ),
+ .cs ( 1'b1 ),
+ .waddr ( push_pointer ),
+ .raddr ( pop_pointer ),
+ .wr ( push ),
+ .rd ( 1'b1 ),
+ .wdata ( din ),
+ .rdata ( dout )
+ );
+
+
+
+
+endmodule
trunk/lib/cde_lifo/cde_lifo.v
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/ip/T6502/sim/run/kim_2/liblist
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/kim_2/liblist (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/kim_2/liblist (revision 44)
@@ -0,0 +1,10 @@
+`include "../../lib/cde_sram/cde_sram.v"
+`include "../../lib/cde_divider/cde_divider.v"
+`include "../../lib/cde_fifo/cde_fifo.v"
+`include "../../lib/cde_lifo/cde_lifo.v"
+`include "../../lib/cde_serial_rcvr/cde_serial_rcvr.v"
+`include "../../lib/cde_serial_xmit/cde_serial_xmit.v"
+`include "../../lib/cde_synchronizers/cde_sync_with_hysteresis.v"
+
+
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/kim_2/TB.defs
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/kim_2/TB.defs (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/kim_2/TB.defs (revision 44)
@@ -0,0 +1,17 @@
+`define TIMEOUT 800000
+
+
+
+`define PROG_ROM_WORDS 2048
+`define PROG_ROM_ADD 11
+`define PROG_ROM_FILE "../../../../../../Mos6502/sw/kim_2/kim_2.abs16"
+
+
+
+`define ROM_WORDS 128
+`define ROM_ADD 7
+`define ROM_FILE "../../../../../../Mos6502/sw/table_tim1/table_tim1.abs16"
+
+
+
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/kim_2/test_define
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/kim_2/test_define (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/kim_2/test_define (revision 44)
@@ -0,0 +1,47 @@
+initial
+begin
+$display(" ");
+$display(" ===================================================");
+$display(" Test Start");
+$display(" ===================================================");
+$display(" ");
+cg.next(20);
+cg.reset_off;
+fork
+begin
+end
+
+begin
+cg.next(400000);
+
+uart_model.send_byte(8'h34);
+cg.next(10000);
+
+uart_model.send_byte(8'h30);
+cg.next(10000);
+uart_model.send_byte(8'h30);
+cg.next(10000);
+uart_model.send_byte(8'h31);
+cg.next(10000);
+uart_model.send_byte(8'h20);
+cg.next(10000);
+uart_model.send_byte(8'h38);
+cg.next(10000);
+uart_model.send_byte(8'h36);
+cg.next(10000);
+uart_model.send_byte(8'h2e);
+
+
+
+
+
+cg.next(80000);
+
+end
+join
+
+cg.exit;
+end
+
+
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/kim_2/dmp_define
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/kim_2/dmp_define (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/kim_2/dmp_define (revision 44)
@@ -0,0 +1,7 @@
+ $dumpfile ("TestBench.vcd");
+ $dumpvars (0, TB);
+
+
+
+
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/kim_2/wave.sav
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/kim_2/wave.sav (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/kim_2/wave.sav (revision 44)
@@ -0,0 +1,20 @@
+[size] 1470 761
+[pos] 193 -382
+*-21.266296 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1
+[treeopen] TB.
+[treeopen] TB.dut.
+[treeopen] TB.dut.io_module.
+[treeopen] TB.dut.io_module.ps2.
+@28
+TB.ps2_clk
+TB.ps2_data
+TB.dut.io_module.ps2.rx_data_avail
+@22
+TB.dut.io_module.ps2.rcv_data[7:0]
+TB.dut.io_module.ps2.cntrl[7:0]
+@28
+TB.dut.io_module.ps2.tx_ack_error
+TB.dut.io_module.ps2.rx_parity_error
+@22
+TB.dut.gpio_0_out[7:0]
+TB.dut.gpio_1_out[7:0]
Index: trunk/projects/Mos6502/ip/T6502/sim/run/kim_2/filelist
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/kim_2/filelist (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/kim_2/filelist (revision 44)
@@ -0,0 +1,7 @@
+`include "../../../rtl/gen/sim/T6502.v"
+`include "../../../../../children/logic/ip/io_module/rtl/gen/sim/io_module.v"
+`include "../../../../../children/logic/ip/uart/rtl/gen/sim/uart.v"
+`include "../../../../../children/logic/ip/serial_rcvr/rtl/gen/sim/serial_rcvr.v"
+`include "../../../../../children/logic/ip/ps2_interface/rtl/gen/sim/ps2_interface.v"
+`include "../../../../../children/logic/ip/vga_char_ctrl/rtl/gen/sim/vga_char_ctrl.v"
+`include "../../../../../children/logic/ip/flash_memcontrl/rtl/gen/sim/flash_memcontrl.v"
\ No newline at end of file
Index: trunk/projects/Mos6502/ip/T6502/sim/run/kim_2/modellist
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/kim_2/modellist (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/kim_2/modellist (revision 44)
@@ -0,0 +1,8 @@
+`include "../../bench/verilog/models/clock_gen.v"
+`include "../../bench/verilog/models/ps2_model.v"
+`include "../../bench/verilog/models/iobuftri.v"
+`include "../../bench/verilog/models/uart_model.v"
+`include "../../bench/verilog/models/io_probe.v"
+`include "../../bench/verilog/models/mt45w8mw12.v"
+
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/kim_2/dut
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/kim_2/dut (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/kim_2/dut (revision 44)
@@ -0,0 +1,360 @@
+
+
+wire serial_txd;
+wire serial_rxd;
+
+wire [7:0] alu_status;
+
+wire [23:1] ext_add;
+wire [15:0] ext_wdata;
+wire [15:0] ext_rdata;
+wire ext_ub;
+wire ext_lb;
+wire ext_rd;
+wire ext_wr;
+wire [1:0] ext_cs;
+
+
+wire [7:0] gpio_0_out;
+wire [7:0] gpio_1_out;
+
+wire ps2_clk_in;
+wire ps2_data_in;
+wire ps2_clk_oe;
+wire ps2_data_oe;
+
+
+wire ps2_clk;
+wire ps2_data;
+
+
+
+
+T6502
+
+#(.ROM_WORDS(`ROM_WORDS),
+ .ROM_ADD (`ROM_ADD),
+ .ROM_FILE (`ROM_FILE),
+
+ .PROG_ROM_WORDS(`PROG_ROM_WORDS),
+ .PROG_ROM_ADD (`PROG_ROM_ADD),
+ .PROG_ROM_FILE (`PROG_ROM_FILE)
+
+
+ )
+
+dut
+(
+ .clk ( clk ),
+ .reset ( reset ),
+ .alu_status ( alu_status ),
+ .ext_irq_in ( 4'b0000 ),
+ .ext_add ( ext_add ),
+ .ext_wdata ( ext_wdata ),
+ .ext_rdata ( ext_rdata ),
+ .ext_ub ( ext_ub ),
+ .ext_lb ( ext_lb ),
+ .ext_rd ( ext_rd ),
+ .ext_wr ( ext_wr ),
+ .ext_cs ( ext_cs ),
+
+ .gpio_0_out ( gpio_0_out ),
+ .gpio_0_in ( gpio_0_out ),
+ .gpio_0_oe ( ),
+ .gpio_0_lat ( ),
+
+ .gpio_1_out ( gpio_1_out ),
+ .gpio_1_in ( gpio_1_out ),
+ .gpio_1_oe ( ),
+ .gpio_1_lat ( ),
+
+ .ps2_clk_oe ( ps2_clk_oe ),
+ .ps2_clk_in ( ps2_clk_in ),
+ .ps2_data_oe ( ps2_data_oe ),
+ .ps2_data_in ( ps2_data_in ),
+
+ .txd_pad_out ( serial_txd ),
+ .rxd_pad_in ( serial_rxd ),
+ .cts_pad_in ( loop ),
+ .rts_pad_out ( loop )
+);
+
+
+
+
+
+
+
+iobuftri
+data_tri_buf
+ (
+ .i ( 1'b0 ),
+ .oe ( ps2_data_oe ),
+ .o ( ps2_data_in ),
+ .pad ( ps2_data )
+ );
+
+
+iobuftri
+clk_tri_buf
+ (
+ .i ( 1'b0 ),
+ .oe ( ps2_clk_oe ),
+ .o ( ps2_clk_in ),
+ .pad ( ps2_clk )
+ );
+
+
+
+pullup ua0(ps2_clk);
+pullup ua1(ps2_data);
+
+
+ps2_model
+#(.CLKCNT(10'h177))
+ps2_model
+(
+ .clk ( clk ),
+ .reset ( reset ),
+ .ps2_clk ( ps2_clk ),
+ .ps2_data ( ps2_data )
+
+
+
+);
+
+
+
+
+
+ uart_model #(.CLKCNT(4'hc))
+ uart_model (
+ .clk ( clk ),
+ .reset ( reset ),
+ .txd_in ( serial_txd ),
+ .rxd_out ( serial_rxd )
+ );
+
+
+
+
+
+
+
+
+
+
+
+
+wire [23:1] memadr_out;
+wire memoe_n_out;
+wire memdb_oe;
+wire [15:0] memdb_out;
+wire [15:0] memdb_in;
+wire [15:0] memdb_io;
+wire memwr_n_out;
+wire ramcs_n_out;
+wire ramlb_n_out;
+wire ramadv_out_n;
+wire ramclk_out;
+wire ramcre_out;
+wire ramub_n_out;
+
+
+
+
+
+
+flash_memcontrl
+flash_memcontrl
+(
+ .clk ( clk ),
+ .reset ( reset ),
+
+ .addr ( ext_add ),
+ .wdata ( ext_wdata ),
+ .cs ( ext_cs ),
+ .stb (|ext_cs ),
+ .rd ( ext_rd ),
+ .wr ( ext_wr ),
+ .ub ( ext_ub ),
+ .lb ( ext_lb ),
+
+ .rdata ( ext_rdata ),
+
+ .memadr_out ( memadr_out ),
+ .memoe_n_out ( memoe_n_out ),
+ .memdb_oe ( memdb_oe ),
+ .memdb_out ( memdb_out ),
+ .memdb_in ( memdb_in ),
+ .memwr_n_out ( memwr_n_out ),
+ .ramcs_n_out ( ramcs_n_out ),
+ .ramlb_n_out ( ramlb_n_out ),
+ .ramadv_out_n ( ramadv_out_n ),
+ .ramclk_out ( ramclk_out ),
+ .ramcre_out ( ramcre_out ),
+ .ramub_n_out ( ramub_n_out )
+ );
+
+
+
+
+
+
+
+
+
+iobuftri memdb_buff_0
+ (
+ .i (memdb_out[0] ),
+ .oe (memdb_oe ),
+ .o (memdb_in[0] ),
+ .pad (memdb_io[0] )
+ );
+
+iobuftri memdb_buff_1
+ (
+ .i (memdb_out[1] ),
+ .oe (memdb_oe ),
+ .o (memdb_in[1] ),
+ .pad (memdb_io[1] )
+ );
+
+iobuftri memdb_buff_2
+ (
+ .i (memdb_out[2] ),
+ .oe (memdb_oe ),
+ .o (memdb_in[2] ),
+ .pad (memdb_io[2] )
+ );
+
+iobuftri memdb_buff_3
+ (
+ .i (memdb_out[3] ),
+ .oe (memdb_oe ),
+ .o (memdb_in[3] ),
+ .pad (memdb_io[3] )
+ );
+
+iobuftri memdb_buff_4
+ (
+ .i (memdb_out[4] ),
+ .oe (memdb_oe ),
+ .o (memdb_in[4] ),
+ .pad (memdb_io[4] )
+ );
+
+iobuftri memdb_buff_5
+ (
+ .i (memdb_out[5] ),
+ .oe (memdb_oe ),
+ .o (memdb_in[5] ),
+ .pad (memdb_io[5] )
+ );
+
+
+iobuftri memdb_buff_6
+ (
+ .i (memdb_out[6] ),
+ .oe (memdb_oe ),
+ .o (memdb_in[6] ),
+ .pad (memdb_io[6] )
+ );
+
+iobuftri memdb_buff_7
+ (
+ .i (memdb_out[7] ),
+ .oe (memdb_oe ),
+ .o (memdb_in[7] ),
+ .pad (memdb_io[7] )
+ );
+
+iobuftri memdb_buff_8
+ (
+ .i (memdb_out[8] ),
+ .oe (memdb_oe ),
+ .o (memdb_in[8] ),
+ .pad (memdb_io[8] )
+ );
+
+iobuftri memdb_buff_9
+ (
+ .i (memdb_out[9] ),
+ .oe (memdb_oe ),
+ .o (memdb_in[9] ),
+ .pad (memdb_io[9] )
+ );
+
+iobuftri memdb_buff_10
+ (
+ .i (memdb_out[10] ),
+ .oe (memdb_oe ),
+ .o (memdb_in[10] ),
+ .pad (memdb_io[10] )
+ );
+
+
+iobuftri memdb_buff_11
+ (
+ .i (memdb_out[11] ),
+ .oe (memdb_oe ),
+ .o (memdb_in[11] ),
+ .pad (memdb_io[11] )
+ );
+
+iobuftri memdb_buff_12
+ (
+ .i (memdb_out[12] ),
+ .oe (memdb_oe ),
+ .o (memdb_in[12] ),
+ .pad (memdb_io[12] )
+ );
+
+iobuftri memdb_buff_13
+ (
+ .i (memdb_out[13] ),
+ .oe (memdb_oe ),
+ .o (memdb_in[13] ),
+ .pad (memdb_io[13] )
+ );
+
+iobuftri memdb_buff_14
+ (
+ .i (memdb_out[14] ),
+ .oe (memdb_oe ),
+ .o (memdb_in[14] ),
+ .pad (memdb_io[14] )
+ );
+
+
+iobuftri memdb_buff_15
+ (
+ .i (memdb_out[15] ),
+ .oe (memdb_oe ),
+ .o (memdb_in[15] ),
+ .pad (memdb_io[15] )
+ );
+
+
+pullup pu_ramwait ( ramwait_n );
+
+mt45w8mw12
+psram (
+ .clk ( ramclk_out ),
+ .adv_n ( ramadv_out_n ),
+ .cre ( ramcre_out ),
+ .o_wait ( ramwait_n ),
+ .ce_n ( ramcs_n_out ),
+ .oe_n ( memoe_n_out ),
+ .we_n ( memwr_n_out ),
+ .lb_n ( ramlb_n_out ),
+ .ub_n ( ramub_n_out ),
+ .addr ( memadr_out ),
+ .dq ( memdb_io )
+);
+
+
+
+
+
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/io_irq_2/liblist
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/io_irq_2/liblist (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/io_irq_2/liblist (revision 44)
@@ -0,0 +1,10 @@
+`include "../../lib/cde_sram/cde_sram.v"
+`include "../../lib/cde_fifo/cde_fifo.v"
+`include "../../lib/cde_lifo/cde_lifo.v"
+`include "../../lib/cde_divider/cde_divider.v"
+`include "../../lib/cde_serial_rcvr/cde_serial_rcvr.v"
+`include "../../lib/cde_serial_xmit/cde_serial_xmit.v"
+`include "../../lib/cde_synchronizers/cde_sync_with_hysteresis.v"
+
+
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/io_irq_2/TB.defs
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/io_irq_2/TB.defs (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/io_irq_2/TB.defs (revision 44)
@@ -0,0 +1,10 @@
+`define ROM_WORDS 128
+`define ROM_ADD 7
+`define ROM_FILE "NONE"
+
+
+`define PROG_ROM_WORDS 128
+`define PROG_ROM_ADD 7
+`define PROG_ROM_FILE "../../../../../../Mos6502/sw/io_irq_2/io_irq_2.abs16"
+
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/io_irq_2/test_define
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/io_irq_2/test_define (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/io_irq_2/test_define (revision 44)
@@ -0,0 +1,22 @@
+initial
+begin
+$display(" ");
+$display(" ===================================================");
+$display(" Test Start");
+$display(" ===================================================");
+$display(" ");
+cg.next(20);
+cg.reset_off;
+uart_model.rcv_byte(8'h42);
+uart_model.send_byte(8'h65);
+uart_model.rcv_byte(8'h67);
+uart_model.send_byte(8'h37);
+uart_model.rcv_byte(8'h39);
+uart_model.send_byte(8'h20);
+uart_model.rcv_byte(8'h22);
+cg.next(4000);
+cg.exit;
+end
+
+
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/io_irq_2/dmp_define
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/io_irq_2/dmp_define (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/io_irq_2/dmp_define (revision 44)
@@ -0,0 +1,7 @@
+ $dumpfile ("TestBench.vcd");
+ $dumpvars (0, TB);
+
+
+
+
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/io_irq_2/filelist
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/io_irq_2/filelist (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/io_irq_2/filelist (revision 44)
@@ -0,0 +1,7 @@
+`include "../../../rtl/gen/sim/T6502.v"
+`include "../../../../../children/logic/ip/io_module/rtl/gen/sim/io_module.v"
+`include "../../../../../children/logic/ip/uart/rtl/gen/sim/uart.v"
+`include "../../../../../children/logic/ip/serial_rcvr/rtl/gen/sim/serial_rcvr.v"
+`include "../../../../../children/logic/ip/ps2_interface/rtl/gen/sim/ps2_interface.v"
+`include "../../../../../children/logic/ip/vga_char_ctrl/rtl/gen/sim/vga_char_ctrl.v"
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/io_irq_2/modellist
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/io_irq_2/modellist (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/io_irq_2/modellist (revision 44)
@@ -0,0 +1,3 @@
+`include "../../bench/verilog/models/clock_gen.v"
+`include "../../bench/verilog/models/uart_model.v"
+`include "../../bench/verilog/models/io_probe.v"
\ No newline at end of file
Index: trunk/projects/Mos6502/ip/T6502/sim/run/io_irq_2/dut
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/io_irq_2/dut (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/io_irq_2/dut (revision 44)
@@ -0,0 +1,66 @@
+
+
+
+wire [15:0] addr_pin;
+wire [7:0] gpio_0_out;
+wire [7:0] gpio_1_out;
+
+wire serial_txd;
+wire serial_rxd;
+
+
+
+T6502
+ #(.ROM_WORDS (`ROM_WORDS),
+ .ROM_ADD (`ROM_ADD),
+ .ROM_FILE (`ROM_FILE),
+ .PROG_ROM_WORDS (`PROG_ROM_WORDS),
+ .PROG_ROM_ADD (`PROG_ROM_ADD),
+ .PROG_ROM_FILE (`PROG_ROM_FILE),
+ .RAM_WORDS (4096)
+
+ ) dut (
+ .clk ( clk ),
+ .reset ( reset ),
+
+ .ext_irq_in ( 4'h0 ),
+
+ .gpio_0_out ( gpio_0_out ),
+ .gpio_0_in ( gpio_0_out ),
+ .gpio_0_oe ( ),
+ .gpio_0_lat ( ),
+
+ .gpio_1_out ( gpio_1_out ),
+ .gpio_1_in ( gpio_1_out ),
+ .gpio_1_oe ( ),
+ .gpio_1_lat ( ),
+
+ .ps2_clk_oe ( ),
+ .ps2_clk_in ( 1'b1 ),
+ .ps2_data_oe ( ),
+ .ps2_data_in ( 1'b1 ),
+
+
+ .txd_pad_out ( serial_txd ),
+ .rxd_pad_in ( serial_rxd ),
+ .cts_pad_in ( loop ),
+ .rts_pad_out ( loop )
+
+
+
+
+
+);
+
+
+
+
+
+uart_model #(.CLKCNT(4'hc))
+uart_model (
+ .clk ( clk ),
+ .reset ( reset ),
+ .txd_in ( serial_txd ),
+ .rxd_out ( serial_rxd )
+ );
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/irq_2_test/liblist
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/irq_2_test/liblist (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/irq_2_test/liblist (revision 44)
@@ -0,0 +1,9 @@
+`include "../../lib/cde_sram/cde_sram.v"
+`include "../../lib/cde_divider/cde_divider.v"
+`include "../../lib/cde_fifo/cde_fifo.v"
+`include "../../lib/cde_lifo/cde_lifo.v"
+`include "../../lib/cde_serial_rcvr/cde_serial_rcvr.v"
+`include "../../lib/cde_serial_xmit/cde_serial_xmit.v"
+`include "../../lib/cde_synchronizers/cde_sync_with_hysteresis.v"
+
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/irq_2_test/TB.defs
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/irq_2_test/TB.defs (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/irq_2_test/TB.defs (revision 44)
@@ -0,0 +1,15 @@
+`define TIMEOUT 100000
+
+`define ROM_WORDS 128
+`define ROM_ADD 7
+`define ROM_FILE "NONE"
+
+
+
+`define PROG_ROM_WORDS 2048
+`define PROG_ROM_ADD 11
+`define PROG_ROM_FILE "../../../../../../Mos6502/sw/irq_2_test/irq_2_test.abs16"
+
+
+
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/irq_2_test/wav.sav
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/irq_2_test/wav.sav (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/irq_2_test/wav.sav (revision 44)
@@ -0,0 +1,25 @@
+[timestart] 55709
+[size] 1694 1099
+[pos] 74 4
+*-8.000000 56504 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1
+[treeopen] TB.
+[treeopen] TB.dut.
+[treeopen] TB.dut.core.
+@22
+TB.dut.addr_pin[15:0]
+@28
+TB.dut.irq_in
+@820
+TB.dut.core.A_cmd[63:0]
+@28
+TB.dut.core.inst_decode.now_fetch_op
+@820
+TB.dut.core.A_instr[55:0]
+TB.dut.core.A_state[79:0]
+@22
+TB.dut.core.prog_counter[15:0]
+TB.dut.core.prog_data[15:0]
+@28
+TB.dut.core.stk_push
+@22
+TB.dut.core.stk_push_data[15:0]
Index: trunk/projects/Mos6502/ip/T6502/sim/run/irq_2_test/test_define
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/irq_2_test/test_define (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/irq_2_test/test_define (revision 44)
@@ -0,0 +1,15 @@
+initial
+begin
+$display(" ");
+$display(" ===================================================");
+$display(" Test Start");
+$display(" ===================================================");
+$display(" ");
+cg.next(20);
+while (gpio_0_out != 8'h00) cg.next(1);
+cg.reset_off;
+while (gpio_1_out == 8'hff) cg.next(10);
+cg.next(50000);
+cg.exit;
+end
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/irq_2_test/dmp_define
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/irq_2_test/dmp_define (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/irq_2_test/dmp_define (revision 44)
@@ -0,0 +1,7 @@
+ $dumpfile ("TestBench.vcd");
+ $dumpvars (0, TB);
+
+
+
+
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/irq_2_test/filelist
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/irq_2_test/filelist (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/irq_2_test/filelist (revision 44)
@@ -0,0 +1,9 @@
+`include "../../../rtl/gen/sim/T6502.v"
+`include "../../../../../children/logic/ip/io_module/rtl/gen/sim/io_module.v"
+`include "../../../../../children/logic/ip/uart/rtl/gen/sim/uart.v"
+`include "../../../../../children/logic/ip/serial_rcvr/rtl/gen/sim/serial_rcvr.v"
+`include "../../../../../children/logic/ip/ps2_interface/rtl/gen/sim/ps2_interface.v"
+`include "../../../../../children/logic/ip/vga_char_ctrl/rtl/gen/sim/vga_char_ctrl.v"
+
+
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/irq_2_test/dut
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/irq_2_test/dut (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/irq_2_test/dut (revision 44)
@@ -0,0 +1,136 @@
+
+
+wire serial_txd;
+wire serial_rxd;
+
+wire [7:0] alu_status;
+
+wire [23:1] ext_add;
+wire [15:0] ext_wdata;
+wire [15:0] ext_rdata;
+wire ext_ub;
+wire ext_lb;
+wire ext_rd;
+wire ext_wr;
+wire [1:0] ext_cs;
+
+
+wire [7:0] gpio_0_out;
+wire [7:0] gpio_1_out;
+
+wire ps2_clk_in;
+wire ps2_data_in;
+wire ps2_clk_oe;
+wire ps2_data_oe;
+
+
+wire ps2_clk;
+wire ps2_data;
+
+
+
+
+T6502
+
+#(.ROM_WORDS(`ROM_WORDS),
+ .ROM_ADD (`ROM_ADD),
+ .ROM_FILE (`ROM_FILE),
+
+ .PROG_ROM_WORDS(`PROG_ROM_WORDS),
+ .PROG_ROM_ADD (`PROG_ROM_ADD),
+ .PROG_ROM_FILE (`PROG_ROM_FILE)
+
+
+ )
+
+dut
+(
+ .clk ( clk ),
+ .reset ( reset ),
+ .alu_status ( alu_status ),
+ .ext_irq_in ( 4'b0000 ),
+ .ext_add ( ext_add ),
+ .ext_wdata ( ext_wdata ),
+ .ext_rdata ( 16'h0000 ),
+ .ext_ub ( ext_ub ),
+ .ext_lb ( ext_lb ),
+ .ext_rd ( ext_rd ),
+ .ext_wr ( ext_wr ),
+ .ext_cs ( ext_cs ),
+
+ .gpio_0_out ( gpio_0_out ),
+ .gpio_0_in ( gpio_0_out ),
+ .gpio_0_oe ( ),
+ .gpio_0_lat ( ),
+
+ .gpio_1_out ( gpio_1_out ),
+ .gpio_1_in ( gpio_1_out ),
+ .gpio_1_oe ( ),
+ .gpio_1_lat ( ),
+
+ .ps2_clk_oe ( ps2_clk_oe ),
+ .ps2_clk_in ( ps2_clk_in ),
+ .ps2_data_oe ( ps2_data_oe ),
+ .ps2_data_in ( ps2_data_in ),
+
+ .txd_pad_out ( serial_txd ),
+ .rxd_pad_in ( serial_rxd ),
+ .cts_pad_in ( loop ),
+ .rts_pad_out ( loop )
+);
+
+
+
+
+
+
+
+iobuftri
+data_tri_buf
+ (
+ .i ( 1'b0 ),
+ .oe ( ps2_data_oe ),
+ .o ( ps2_data_in ),
+ .pad ( ps2_data )
+ );
+
+
+iobuftri
+clk_tri_buf
+ (
+ .i ( 1'b0 ),
+ .oe ( ps2_clk_oe ),
+ .o ( ps2_clk_in ),
+ .pad ( ps2_clk )
+ );
+
+
+
+pullup ua0(ps2_clk);
+pullup ua1(ps2_data);
+
+
+ps2_model
+#(.CLKCNT(10'h177))
+ps2_model
+(
+ .clk ( clk ),
+ .reset ( reset ),
+ .ps2_clk ( ps2_clk ),
+ .ps2_data ( ps2_data )
+
+
+
+);
+
+
+
+
+
+ uart_model #(.CLKCNT(4'hc))
+ uart_model (
+ .clk ( clk ),
+ .reset ( reset ),
+ .txd_in ( serial_txd ),
+ .rxd_out ( serial_rxd )
+ );
Index: trunk/projects/Mos6502/ip/T6502/sim/run/irq_2_test/modellist
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/irq_2_test/modellist (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/irq_2_test/modellist (revision 44)
@@ -0,0 +1,5 @@
+`include "../../bench/verilog/models/clock_gen.v"
+`include "../../bench/verilog/models/ps2_model.v"
+`include "../../bench/verilog/models/iobuftri.v"
+`include "../../bench/verilog/models/uart_model.v"
+`include "../../bench/verilog/models/io_probe.v"
\ No newline at end of file
Index: trunk/projects/Mos6502/ip/T6502/sim/run/inst_2_test/liblist
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/inst_2_test/liblist (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/inst_2_test/liblist (revision 44)
@@ -0,0 +1,9 @@
+`include "../../lib/cde_sram/cde_sram.v"
+`include "../../lib/cde_divider/cde_divider.v"
+`include "../../lib/cde_fifo/cde_fifo.v"
+`include "../../lib/cde_lifo/cde_lifo.v"
+`include "../../lib/cde_serial_rcvr/cde_serial_rcvr.v"
+`include "../../lib/cde_serial_xmit/cde_serial_xmit.v"
+`include "../../lib/cde_synchronizers/cde_sync_with_hysteresis.v"
+
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/inst_2_test/TB.defs
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/inst_2_test/TB.defs (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/inst_2_test/TB.defs (revision 44)
@@ -0,0 +1,15 @@
+`define TIMEOUT 100000
+
+
+
+
+`define PROG_ROM_WORDS 2048
+`define PROG_ROM_ADD 11
+`define PROG_ROM_FILE "../../../../../../Mos6502/sw/inst_2_test/inst_2_test.abs16"
+
+
+
+`define ROM_WORDS 128
+`define ROM_ADD 7
+`define ROM_FILE "../../../../../../Mos6502/sw/table/table.abs16"
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/inst_2_test/wav.sav
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/inst_2_test/wav.sav (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/inst_2_test/wav.sav (revision 44)
@@ -0,0 +1,111 @@
+[timestart] 76690
+[size] 1699 1056
+[pos] 46 -500
+*-8.000000 77260 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1
+[treeopen] TB.
+[treeopen] TB.dut.
+[treeopen] TB.dut.core.
+[treeopen] TB.dut.core.t6502_alu_ctrl.
+[treeopen] TB.dut.stack_ram.
+@22
+TB.gpio_0_out[7:0]
+TB.gpio_1_out[7:0]
+@28
+TB.dut.core.clk
+TB.dut.core.enable
+@22
+TB.dut.core.prog_counter[15:0]
+TB.dut.core.prog_data[7:0]
+@820
+TB.dut.core.A_instr[55:0]
+@28
+TB.dut.core.length[1:0]
+@820
+TB.dut.core.A_ins_type[39:0]
+TB.dut.core.A_state[79:0]
+TB.dut.core.A_ctrl[55:0]
+TB.dut.core.A_alu_mode[23:0]
+TB.dut.core.A_dest[23:0]
+TB.dut.core.A_alu_status_update[31:0]
+TB.dut.core.A_alu_op_a_sel[23:0]
+TB.dut.core.A_alu_op_b_sel[23:0]
+TB.dut.core.A_alu_op_b_inv[23:0]
+TB.dut.core.A_alu_op_c_sel[23:0]
+@22
+TB.dut.core.sequencer.operand[7:0]
+TB.dut.core.sequencer.alu_result[7:0]
+@200
+-
+-
+@28
+TB.dut.core.jsr
+TB.dut.core.stack
+@200
+-
+@22
+TB.dut.core.mem_add[15:0]
+@28
+TB.dut.core.mem_rd
+@22
+TB.dut.core.mem_rdata[7:0]
+@28
+TB.dut.core.mem_wr
+@22
+TB.dut.core.mem_wdata[7:0]
+TB.dut.stk_pull_data[15:0]
+TB.dut.stk_push_data[15:0]
+TB.dut.stack_ram.push_pointer[7:0]
+TB.dut.stack_ram.pop_pointer[7:0]
+@28
+TB.dut.stk_pull
+TB.dut.stk_push
+@29
+TB.dut.core.sequencer.stk_push_p
+@200
+-
+@28
+TB.dut.core.inst_decode.now_fetch_op
+@22
+TB.dut.pg0_add[7:0]
+@28
+TB.dut.pg0_rd
+TB.dut.pg0_wr
+@200
+-
+@28
+TB.dut.core.alu_enable_s
+TB.dut.core.implied
+TB.dut.core.t6502_alu_ctrl.alu_enable
+TB.dut.core.t6502_alu_ctrl.alu_mode[2:0]
+@22
+TB.dut.core.t6502_alu_ctrl.alu_op_b[7:0]
+@28
+TB.dut.core.t6502_alu_ctrl.alu_op_a_sel[2:0]
+@22
+TB.dut.core.sequencer.operand[7:0]
+@820
+TB.dut.core.A_alu_op_a_sel[23:0]
+@200
+-
+-
+@22
+TB.dut.core.t6502_alu_ctrl.alu_a[7:0]
+TB.dut.core.t6502_alu_ctrl.alu_x[7:0]
+TB.dut.core.t6502_alu_ctrl.alu_y[7:0]
+TB.dut.core.t6502_alu_ctrl.alu_status[7:0]
+@28
+TB.dut.core.branch_inst
+TB.dut.core.jsr
+TB.dut.core.jump
+TB.dut.core.jump_indirect
+TB.dut.core.rti
+TB.dut.core.rts
+TB.dut.core.brk
+@22
+TB.dut.stack_ram.din[15:0]
+TB.dut.stack_ram.dout[15:0]
+TB.dut.stack_ram.in_buf[15:0]
+@28
+TB.dut.core.fetch_op
+TB.dut.core.inst_decode.now_fetch_op
+TB.dut.core.inst_decode.implied
Index: trunk/projects/Mos6502/ip/T6502/sim/run/inst_2_test/test_define
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/inst_2_test/test_define (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/inst_2_test/test_define (revision 44)
@@ -0,0 +1,16 @@
+initial
+begin
+$display(" ");
+$display(" ===================================================");
+$display(" Test Start");
+$display(" ===================================================");
+$display(" ");
+cg.next(20);
+while (gpio_0_out != 8'h00) cg.next(1);
+while (gpio_1_out != 8'h00) cg.next(1);
+cg.reset_off;
+while (gpio_1_out == 8'h00) cg.next(10);
+cg.next(300);
+cg.exit;
+end
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/inst_2_test/dmp_define
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/inst_2_test/dmp_define (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/inst_2_test/dmp_define (revision 44)
@@ -0,0 +1,7 @@
+ $dumpfile ("TestBench.vcd");
+ $dumpvars (0, TB);
+
+
+
+
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/inst_2_test/filelist
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/inst_2_test/filelist (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/inst_2_test/filelist (revision 44)
@@ -0,0 +1,9 @@
+`include "../../../rtl/gen/sim/T6502.v"
+`include "../../../../../children/logic/ip/io_module/rtl/gen/sim/io_module.v"
+`include "../../../../../children/logic/ip/uart/rtl/gen/sim/uart.v"
+`include "../../../../../children/logic/ip/serial_rcvr/rtl/gen/sim/serial_rcvr.v"
+`include "../../../../../children/logic/ip/ps2_interface/rtl/gen/sim/ps2_interface.v"
+`include "../../../../../children/logic/ip/vga_char_ctrl/rtl/gen/sim/vga_char_ctrl.v"
+
+
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/inst_2_test/modellist
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/inst_2_test/modellist (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/inst_2_test/modellist (revision 44)
@@ -0,0 +1,5 @@
+`include "../../bench/verilog/models/clock_gen.v"
+`include "../../bench/verilog/models/ps2_model.v"
+`include "../../bench/verilog/models/iobuftri.v"
+`include "../../bench/verilog/models/uart_model.v"
+`include "../../bench/verilog/models/io_probe.v"
\ No newline at end of file
Index: trunk/projects/Mos6502/ip/T6502/sim/run/inst_2_test/dut
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/inst_2_test/dut (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/inst_2_test/dut (revision 44)
@@ -0,0 +1,136 @@
+
+
+wire serial_txd;
+wire serial_rxd;
+
+wire [7:0] alu_status;
+
+wire [23:1] ext_add;
+wire [15:0] ext_wdata;
+wire [15:0] ext_rdata;
+wire ext_ub;
+wire ext_lb;
+wire ext_rd;
+wire ext_wr;
+wire [1:0] ext_cs;
+
+
+wire [7:0] gpio_0_out;
+wire [7:0] gpio_1_out;
+
+wire ps2_clk_in;
+wire ps2_data_in;
+wire ps2_clk_oe;
+wire ps2_data_oe;
+
+
+wire ps2_clk;
+wire ps2_data;
+
+
+
+
+T6502
+
+#(.ROM_WORDS(`ROM_WORDS),
+ .ROM_ADD (`ROM_ADD),
+ .ROM_FILE (`ROM_FILE),
+
+ .PROG_ROM_WORDS(`PROG_ROM_WORDS),
+ .PROG_ROM_ADD (`PROG_ROM_ADD),
+ .PROG_ROM_FILE (`PROG_ROM_FILE)
+
+
+ )
+
+dut
+(
+ .clk ( clk ),
+ .reset ( reset ),
+ .alu_status ( alu_status ),
+ .ext_irq_in ( 4'b0000 ),
+ .ext_add ( ext_add ),
+ .ext_wdata ( ext_wdata ),
+ .ext_rdata ( 16'h0000 ),
+ .ext_ub ( ext_ub ),
+ .ext_lb ( ext_lb ),
+ .ext_rd ( ext_rd ),
+ .ext_wr ( ext_wr ),
+ .ext_cs ( ext_cs ),
+
+ .gpio_0_out ( gpio_0_out ),
+ .gpio_0_in ( gpio_0_out ),
+ .gpio_0_oe ( ),
+ .gpio_0_lat ( ),
+
+ .gpio_1_out ( gpio_1_out ),
+ .gpio_1_in ( gpio_1_out ),
+ .gpio_1_oe ( ),
+ .gpio_1_lat ( ),
+
+ .ps2_clk_oe ( ps2_clk_oe ),
+ .ps2_clk_in ( ps2_clk_in ),
+ .ps2_data_oe ( ps2_data_oe ),
+ .ps2_data_in ( ps2_data_in ),
+
+ .txd_pad_out ( serial_txd ),
+ .rxd_pad_in ( serial_rxd ),
+ .cts_pad_in ( loop ),
+ .rts_pad_out ( loop )
+);
+
+
+
+
+
+
+
+iobuftri
+data_tri_buf
+ (
+ .i ( 1'b0 ),
+ .oe ( ps2_data_oe ),
+ .o ( ps2_data_in ),
+ .pad ( ps2_data )
+ );
+
+
+iobuftri
+clk_tri_buf
+ (
+ .i ( 1'b0 ),
+ .oe ( ps2_clk_oe ),
+ .o ( ps2_clk_in ),
+ .pad ( ps2_clk )
+ );
+
+
+
+pullup ua0(ps2_clk);
+pullup ua1(ps2_data);
+
+
+ps2_model
+#(.CLKCNT(10'h177))
+ps2_model
+(
+ .clk ( clk ),
+ .reset ( reset ),
+ .ps2_clk ( ps2_clk ),
+ .ps2_data ( ps2_data )
+
+
+
+);
+
+
+
+
+
+ uart_model #(.CLKCNT(4'hc))
+ uart_model (
+ .clk ( clk ),
+ .reset ( reset ),
+ .txd_in ( serial_txd ),
+ .rxd_out ( serial_rxd )
+ );
Index: trunk/projects/Mos6502/ip/T6502/sim/run/io_poll_2/liblist
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/io_poll_2/liblist (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/io_poll_2/liblist (revision 44)
@@ -0,0 +1,10 @@
+`include "../../lib/cde_sram/cde_sram.v"
+`include "../../lib/cde_fifo/cde_fifo.v"
+`include "../../lib/cde_lifo/cde_lifo.v"
+`include "../../lib/cde_divider/cde_divider.v"
+`include "../../lib/cde_serial_rcvr/cde_serial_rcvr.v"
+`include "../../lib/cde_serial_xmit/cde_serial_xmit.v"
+`include "../../lib/cde_synchronizers/cde_sync_with_hysteresis.v"
+
+
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/io_poll_2/TB.defs
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/io_poll_2/TB.defs (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/io_poll_2/TB.defs (revision 44)
@@ -0,0 +1,11 @@
+`define TIMEOUT 800000
+
+`define ROM_WORDS 128
+`define ROM_ADD 7
+`define ROM_FILE "NONE"
+
+
+
+`define PROG_ROM_WORDS 128
+`define PROG_ROM_ADD 7
+`define PROG_ROM_FILE "../../../../../../Mos6502/sw/io_poll_2/io_poll_2.abs16"
Index: trunk/projects/Mos6502/ip/T6502/sim/run/io_poll_2/test_define
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/io_poll_2/test_define (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/io_poll_2/test_define (revision 44)
@@ -0,0 +1,20 @@
+initial
+begin
+$display(" ");
+$display(" ===================================================");
+$display(" Test Start");
+$display(" ===================================================");
+$display(" ");
+cg.next(20);
+cg.reset_off;
+uart_model.rcv_byte(8'h42);
+uart_model.send_byte(8'h65);
+uart_model.rcv_byte(8'h67);
+uart_model.send_byte(8'h37);
+uart_model.rcv_byte(8'h39);
+cg.next(4000);
+cg.exit;
+end
+
+
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/io_poll_2/dmp_define
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/io_poll_2/dmp_define (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/io_poll_2/dmp_define (revision 44)
@@ -0,0 +1,7 @@
+ $dumpfile ("TestBench.vcd");
+ $dumpvars (0, TB);
+
+
+
+
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/io_poll_2/filelist
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/io_poll_2/filelist (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/io_poll_2/filelist (revision 44)
@@ -0,0 +1,7 @@
+`include "../../../rtl/gen/sim/T6502.v"
+`include "../../../../../children/logic/ip/io_module/rtl/gen/sim/io_module.v"
+`include "../../../../../children/logic/ip/uart/rtl/gen/sim/uart.v"
+`include "../../../../../children/logic/ip/serial_rcvr/rtl/gen/sim/serial_rcvr.v"
+`include "../../../../../children/logic/ip/ps2_interface/rtl/gen/sim/ps2_interface.v"
+`include "../../../../../children/logic/ip/vga_char_ctrl/rtl/gen/sim/vga_char_ctrl.v"
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/io_poll_2/dut
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/io_poll_2/dut (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/io_poll_2/dut (revision 44)
@@ -0,0 +1,66 @@
+
+
+
+wire [15:0] addr_pin;
+
+wire [7:0] gpio_0_out;
+wire [7:0] gpio_1_out;
+
+wire serial_txd;
+wire serial_rxd;
+
+
+
+T6502
+ #(.ROM_WORDS (`ROM_WORDS),
+ .ROM_ADD (`ROM_ADD),
+ .ROM_FILE (`ROM_FILE),
+ .PROG_ROM_WORDS (`PROG_ROM_WORDS),
+ .PROG_ROM_ADD (`PROG_ROM_ADD),
+ .PROG_ROM_FILE (`PROG_ROM_FILE),
+ .RAM_WORDS (4096)
+ ) dut (
+ .clk ( clk ),
+ .reset ( reset ),
+
+ .ext_irq_in ( 4'h0 ),
+
+ .gpio_0_out ( gpio_0_out ),
+ .gpio_0_in ( gpio_0_out ),
+ .gpio_0_oe ( ),
+ .gpio_0_lat ( ),
+
+ .gpio_1_out ( gpio_1_out ),
+ .gpio_1_in ( gpio_1_out ),
+ .gpio_1_oe ( ),
+ .gpio_1_lat ( ),
+
+ .ps2_clk_oe ( ),
+ .ps2_clk_in ( 1'b1 ),
+ .ps2_data_oe ( ),
+ .ps2_data_in ( 1'b1 ),
+
+
+ .txd_pad_out ( serial_txd ),
+ .rxd_pad_in ( serial_rxd ),
+ .cts_pad_in ( loop ),
+ .rts_pad_out ( loop )
+
+
+
+
+
+);
+
+
+
+
+
+uart_model #(.CLKCNT(4'hc))
+uart_model (
+ .clk ( clk ),
+ .reset ( reset ),
+ .txd_in ( serial_txd ),
+ .rxd_out ( serial_rxd )
+ );
+
Index: trunk/projects/Mos6502/ip/T6502/sim/run/io_poll_2/modellist
===================================================================
--- trunk/projects/Mos6502/ip/T6502/sim/run/io_poll_2/modellist (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/sim/run/io_poll_2/modellist (revision 44)
@@ -0,0 +1,3 @@
+`include "../../bench/verilog/models/clock_gen.v"
+`include "../../bench/verilog/models/uart_model.v"
+`include "../../bench/verilog/models/io_probe.v"
Index: trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/bsdl/xc3s1200e_fg320_1532.bsd
===================================================================
--- trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/bsdl/xc3s1200e_fg320_1532.bsd (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/bsdl/xc3s1200e_fg320_1532.bsd (revision 44)
@@ -0,0 +1,1591 @@
+--$ XILINX$RCSfile: xc3s1200e_fg320_1532.bsd,v $
+--$ XILINX$Revision: 1.2.124.1 $
+
+--###################################################################
+-- WARNING !!!! .. This is a 1532 PROTOTYPE BDSL file.
+--###################################################################
+--
+-- It should not be be used in place of, or along side of 1149.1 bsdl files.
+--
+-- This file conforms to the unapproved IEEE Standard 1532 BSDL draft
+-- Standard. It may not function as expected with IEEE 1149.1 BSDL
+-- and is subject to change pending the ratification of the 1532 Standard
+-- by the IEEE. When denoted as FINAL, it has been verified
+-- syntactically, and against hardware.
+--
+-- Prototype 1532 BSDL file for device XC3S1200E, package FG320
+-- Xilinx, Inc. $State: Exp $ $Date: 2008/07/07 22:23:21 $
+--
+-- Generated by BSDLnet bsdlnet Version 1.40
+------------------------------------------------------------------------
+-- Modification History
+-- | Generated on 05/28/08
+-- | CR # 471899
+-- | Details - Initial Release using BSDLnet.
+-- | Added 'attribute COMPLIANCE_PATTERNS' & changed boundary
+-- | register attribute to internal for PROG_B & PUDC_B.
+------------------------------------------------------------------------
+--
+-- createBSDL template $RCSfile: xc3s1200e_fg320_1532.bsd,v $ $Revision: 1.2.124.1 $ $Date: 2008/07/07 22:23:21 $
+--
+--###################################################################
+--
+--
+-- For technical support, contact Xilinx on the web at:
+--
+-- http://support.xilinx.com
+--
+-- Technical support can also take place via email or phone at:
+--
+-- North America 1-800-255-7778 hotline@xilinx.com
+-- United Kingdom (44) 1932 820821 ukhelp@xilinx.com
+-- France (33) 1 3463 0100 frhelp@xilinx.com
+-- Germany (49) 89 991 54930 dlhelp@xilinx.com
+-- Japan (81) 3-3297-9163 jhotline@xilinx.com
+--
+--
+-- This BSDL file reflects the pre-configuration JTAG behavior. To reflect
+-- the post-configuration JTAG behavior (if any), edit this file as described
+-- below. Many of these changes are demonstrated by commented-out template
+-- lines preceeding the lines they would replace:
+--
+-- 1. Set disable result of all pads as configured.
+-- 2. Set safe state of boundary cells as necessary.
+-- 3. Rename entity if necessary to avoid name collisions.
+-- 4. Modify USERCODE value in USERCODE_REGISTER declaration.
+--
+--###################################################################--
+
+----------------------------------
+
+-- BSDL File for 1532 Standard.
+
+----------------------------------
+
+entity XC3S1200E_FG320 is
+
+-- Generic Parameter
+
+generic (PHYSICAL_PIN_MAP : string := "FG320" );
+
+-- Logical Port Description
+
+port (
+ A10: inout bit; -- PAD40
+ A11: inout bit; -- PAD49
+ A12: inout bit; -- PAD54
+ A13: inout bit; -- PAD59
+ A14: inout bit; -- PAD62
+ A16: inout bit; -- PAD76
+ A4: inout bit; -- PAD5
+ A6: inout bit; -- PAD14
+ A7: inout bit; -- PAD20
+ A8: inout bit; -- PAD28
+ B10: inout bit; -- PAD41
+ B11: inout bit; -- PAD42
+ B13: inout bit; -- PAD58
+ B14: inout bit; -- PAD63
+ B16: inout bit; -- PAD77
+ B4: inout bit; -- PAD4
+ B6: inout bit; -- PAD15
+ C1: inout bit; -- PAD304
+ C11: inout bit; -- PAD48
+ C14: inout bit; -- PAD72
+ C17: inout bit; -- PAD80
+ C18: inout bit; -- PAD81
+ C2: inout bit; -- PAD303
+ C3: inout bit; -- PAD2
+ C4: inout bit; -- PAD6
+ C5: inout bit; -- PAD8
+ C7: inout bit; -- PAD27
+ C9: inout bit; -- PAD37
+ D1: inout bit; -- PAD302
+ D10: inout bit; -- PAD44
+ D11: inout bit; -- PAD47
+ D13: inout bit; -- PAD57
+ D14: inout bit; -- PAD73
+ D16: inout bit; -- PAD82
+ D17: inout bit; -- PAD83
+ D2: inout bit; -- PAD301
+ D4: inout bit; -- PAD298
+ D5: inout bit; -- PAD7
+ D6: inout bit; -- PAD12
+ D7: inout bit; -- PAD26
+ D9: inout bit; -- PAD36
+ DONE: inout bit;
+ E1: inout bit; -- PAD296
+ E10: inout bit; -- PAD43
+ E11: inout bit; -- PAD51
+ E12: inout bit; -- PAD55
+ E13: inout bit; -- PAD71
+ E15: inout bit; -- PAD85
+ E16: inout bit; -- PAD84
+ E2: inout bit; -- PAD297
+ E3: inout bit; -- PAD291
+ E4: inout bit; -- PAD292
+ E6: inout bit; -- PAD11
+ E7: inout bit; -- PAD21
+ E8: inout bit; -- PAD30
+ E9: inout bit; -- PAD34
+ F1: inout bit; -- PAD287
+ F11: inout bit; -- PAD50
+ F12: inout bit; -- PAD56
+ F14: inout bit; -- PAD92
+ F15: inout bit; -- PAD93
+ F17: inout bit; -- PAD99
+ F18: inout bit; -- PAD100
+ F2: inout bit; -- PAD286
+ F7: inout bit; -- PAD22
+ F8: inout bit; -- PAD29
+ F9: inout bit; -- PAD33
+ G13: inout bit; -- PAD97
+ G14: inout bit; -- PAD98
+ G15: inout bit; -- PAD103
+ G16: inout bit; -- PAD102
+ G3: inout bit; -- PAD285
+ G4: inout bit; -- PAD284
+ G5: inout bit; -- PAD281
+ G6: inout bit; -- PAD282
+ G9: inout bit; -- PAD35
+ GND: linkage bit_vector (1 to 28);
+ H1: inout bit; -- PAD274
+ H14: inout bit; -- PAD105
+ H15: inout bit; -- PAD104
+ H16: inout bit; -- PAD108
+ H17: inout bit; -- PAD107
+ H2: inout bit; -- PAD275
+ H3: inout bit; -- PAD276
+ H4: inout bit; -- PAD277
+ H5: inout bit; -- PAD279
+ H6: inout bit; -- PAD280
+ IPAD10: in bit;
+ IPAD101: in bit;
+ IPAD106: in bit;
+ IPAD111: in bit;
+ IPAD116: in bit;
+ IPAD121: in bit;
+ IPAD126: in bit;
+ IPAD131: in bit;
+ IPAD136: in bit;
+ IPAD141: in bit;
+ IPAD148: in bit;
+ IPAD155: in bit;
+ IPAD161: in bit;
+ IPAD162: in bit;
+ IPAD183: in bit;
+ IPAD184: in bit;
+ IPAD190: in bit;
+ IPAD191: in bit;
+ IPAD197: in bit;
+ IPAD198: in bit;
+ IPAD204: in bit;
+ IPAD205: in bit;
+ IPAD226: in bit;
+ IPAD227: in bit;
+ IPAD230: in bit;
+ IPAD231: in bit;
+ IPAD238: in bit;
+ IPAD243: in bit;
+ IPAD248: in bit;
+ IPAD253: in bit;
+ IPAD258: in bit;
+ IPAD263: in bit;
+ IPAD268: in bit;
+ IPAD273: in bit;
+ IPAD278: in bit;
+ IPAD283: in bit;
+ IPAD288: in bit;
+ IPAD293: in bit;
+ IPAD3: in bit;
+ IPAD300: in bit;
+ IPAD31: in bit;
+ IPAD32: in bit;
+ IPAD38: in bit;
+ IPAD39: in bit;
+ IPAD45: in bit;
+ IPAD46: in bit;
+ IPAD52: in bit;
+ IPAD53: in bit;
+ IPAD74: in bit;
+ IPAD75: in bit;
+ IPAD78: in bit;
+ IPAD79: in bit;
+ IPAD86: in bit;
+ IPAD9: in bit;
+ IPAD91: in bit;
+ IPAD96: in bit;
+ J1: inout bit; -- PAD270
+ J12: inout bit; -- PAD110
+ J13: inout bit; -- PAD109
+ J14: inout bit; -- PAD112
+ J15: inout bit; -- PAD113
+ J16: inout bit; -- PAD114
+ J17: inout bit; -- PAD115
+ J2: inout bit; -- PAD269
+ J4: inout bit; -- PAD271
+ J5: inout bit; -- PAD272
+ K12: inout bit; -- PAD119
+ K13: inout bit; -- PAD120
+ K14: inout bit; -- PAD117
+ K15: inout bit; -- PAD118
+ K3: inout bit; -- PAD267
+ K4: inout bit; -- PAD266
+ K5: inout bit; -- PAD264
+ K6: inout bit; -- PAD265
+ L1: inout bit; -- PAD262
+ L15: inout bit; -- PAD124
+ L16: inout bit; -- PAD125
+ L17: inout bit; -- PAD122
+ L18: inout bit; -- PAD123
+ L2: inout bit; -- PAD261
+ L3: inout bit; -- PAD260
+ L4: inout bit; -- PAD259
+ L5: inout bit; -- PAD256
+ L6: inout bit; -- PAD257
+ M10: inout bit; -- PAD186
+ M13: inout bit; -- PAD134
+ M14: inout bit; -- PAD135
+ M15: inout bit; -- PAD130
+ M16: inout bit; -- PAD129
+ M18: inout bit; -- PAD127
+ M3: inout bit; -- PAD254
+ M4: inout bit; -- PAD255
+ M5: inout bit; -- PAD252
+ M6: inout bit; -- PAD251
+ M9: inout bit; -- PAD195
+ N10: inout bit; -- PAD185
+ N11: inout bit; -- PAD181
+ N12: inout bit; -- PAD171
+ N14: inout bit; -- PAD139
+ N15: inout bit; -- PAD140
+ N18: inout bit; -- PAD128
+ N4: inout bit; -- PAD250
+ N5: inout bit; -- PAD249
+ N7: inout bit; -- PAD208
+ N8: inout bit; -- PAD202
+ N9: inout bit; -- PAD196
+ P1: inout bit; -- PAD244
+ P10: inout bit; -- PAD188
+ P11: inout bit; -- PAD182
+ P12: inout bit; -- PAD170
+ P13: inout bit; -- PAD167
+ P16: inout bit; -- PAD142
+ P17: inout bit; -- PAD133
+ P18: inout bit; -- PAD132
+ P2: inout bit; -- PAD245
+ P3: inout bit; -- PAD242
+ P4: inout bit; -- PAD241
+ P6: inout bit; -- PAD214
+ P7: inout bit; -- PAD207
+ P8: inout bit; -- PAD203
+ P9: inout bit; -- PAD201
+ PROG_B: in bit;
+ PUDC_B: in bit; -- PAD1
+ R10: inout bit; -- PAD189
+ R11: inout bit; -- PAD180
+ R12: inout bit; -- PAD173
+ R13: inout bit; -- PAD166
+ R14: inout bit; -- PAD159
+ R15: inout bit; -- PAD147
+ R16: inout bit; -- PAD146
+ R18: inout bit; -- PAD150
+ R2: inout bit; -- PAD234
+ R3: inout bit; -- PAD235
+ R5: inout bit; -- PAD222
+ R6: inout bit; -- PAD215
+ R8: inout bit; -- PAD200
+ R9: inout bit; -- PAD194
+ T1: inout bit; -- PAD232
+ T12: inout bit; -- PAD174
+ T14: inout bit; -- PAD160
+ T15: inout bit; -- PAD158
+ T16: inout bit; -- PAD154
+ T17: inout bit; -- PAD151
+ T18: inout bit; -- PAD149
+ T2: inout bit; -- PAD233
+ T3: inout bit; -- PAD228
+ T4: inout bit; -- PAD224
+ T5: inout bit; -- PAD221
+ T8: inout bit; -- PAD199
+ TCK: in bit;
+ TDI: in bit;
+ TDO: out bit;
+ TMS: in bit;
+ U13: inout bit; -- PAD172
+ U15: inout bit; -- PAD156
+ U16: inout bit; -- PAD153
+ U18: inout bit; -- PAD152
+ U3: inout bit; -- PAD229
+ U4: inout bit; -- PAD225
+ U5: inout bit; -- PAD223
+ U6: inout bit; -- PAD209
+ U9: inout bit; -- PAD193
+ V11: inout bit; -- PAD187
+ V12: inout bit; -- PAD179
+ V13: inout bit; -- PAD178
+ V15: inout bit; -- PAD157
+ V5: inout bit; -- PAD211
+ V6: inout bit; -- PAD210
+ V7: inout bit; -- PAD206
+ V9: inout bit; -- PAD192
+ VCCAUX: linkage bit_vector (1 to 8);
+ VCCINT: linkage bit_vector (1 to 8);
+ VCCO_0: linkage bit_vector (1 to 5);
+ VCCO_1: linkage bit_vector (1 to 5);
+ VCCO_2: linkage bit_vector (1 to 5);
+ VCCO_3: linkage bit_vector (1 to 5)
+); --end port list
+
+-- Use Statements
+
+use STD_1149_1_2001.all;
+use STD_1532_2002.all;
+
+-- Component Conformance Statement(s)
+
+attribute COMPONENT_CONFORMANCE of XC3S1200E_FG320 : entity is
+ "STD_1149_1_2001";
+
+-- Device Package Pin Mappings
+
+attribute PIN_MAP of XC3S1200E_FG320 : entity is PHYSICAL_PIN_MAP;
+
+constant FG320: PIN_MAP_STRING:=
+ "A10:A10," &
+ "A11:A11," &
+ "A12:A12," &
+ "A13:A13," &
+ "A14:A14," &
+ "A16:A16," &
+ "A4:A4," &
+ "A6:A6," &
+ "A7:A7," &
+ "A8:A8," &
+ "B10:B10," &
+ "B11:B11," &
+ "B13:B13," &
+ "B14:B14," &
+ "B16:B16," &
+ "B4:B4," &
+ "B6:B6," &
+ "C1:C1," &
+ "C11:C11," &
+ "C14:C14," &
+ "C17:C17," &
+ "C18:C18," &
+ "C2:C2," &
+ "C3:C3," &
+ "C4:C4," &
+ "C5:C5," &
+ "C7:C7," &
+ "C9:C9," &
+ "D1:D1," &
+ "D10:D10," &
+ "D11:D11," &
+ "D13:D13," &
+ "D14:D14," &
+ "D16:D16," &
+ "D17:D17," &
+ "D2:D2," &
+ "D4:D4," &
+ "D5:D5," &
+ "D6:D6," &
+ "D7:D7," &
+ "D9:D9," &
+ "DONE:V17," &
+ "E1:E1," &
+ "E10:E10," &
+ "E11:E11," &
+ "E12:E12," &
+ "E13:E13," &
+ "E15:E15," &
+ "E16:E16," &
+ "E2:E2," &
+ "E3:E3," &
+ "E4:E4," &
+ "E6:E6," &
+ "E7:E7," &
+ "E8:E8," &
+ "E9:E9," &
+ "F1:F1," &
+ "F11:F11," &
+ "F12:F12," &
+ "F14:F14," &
+ "F15:F15," &
+ "F17:F17," &
+ "F18:F18," &
+ "F2:F2," &
+ "F7:F7," &
+ "F8:F8," &
+ "F9:F9," &
+ "G13:G13," &
+ "G14:G14," &
+ "G15:G15," &
+ "G16:G16," &
+ "G3:G3," &
+ "G4:G4," &
+ "G5:G5," &
+ "G6:G6," &
+ "G9:G9," &
+ "GND:(A1,A18,B2,B17,C10,G7,G12,H8,H9,H10," &
+ "H11,J3,J8,J11,K8,K11,K16,L8,L9,L10," &
+ "L11,M7,M12,T9,U2,U17,V1,V18)," &
+ "H1:H1," &
+ "H14:H14," &
+ "H15:H15," &
+ "H16:H16," &
+ "H17:H17," &
+ "H2:H2," &
+ "H3:H3," &
+ "H4:H4," &
+ "H5:H5," &
+ "H6:H6," &
+ "IPAD10:A5," &
+ "IPAD101:H13," &
+ "IPAD106:G18," &
+ "IPAD111:H18," &
+ "IPAD116:K18," &
+ "IPAD121:K17," &
+ "IPAD126:L13," &
+ "IPAD131:L14," &
+ "IPAD136:N17," &
+ "IPAD141:P15," &
+ "IPAD148:R17," &
+ "IPAD155:V16," &
+ "IPAD161:U14," &
+ "IPAD162:V14," &
+ "IPAD183:U11," &
+ "IPAD184:T11," &
+ "IPAD190:T10," &
+ "IPAD191:U10," &
+ "IPAD197:V8," &
+ "IPAD198:U8," &
+ "IPAD204:R7," &
+ "IPAD205:T7," &
+ "IPAD226:V3," &
+ "IPAD227:V4," &
+ "IPAD230:V2," &
+ "IPAD231:U1," &
+ "IPAD238:R1," &
+ "IPAD243:R4," &
+ "IPAD248:N2," &
+ "IPAD253:N1," &
+ "IPAD258:M1," &
+ "IPAD263:K7," &
+ "IPAD268:K2," &
+ "IPAD273:J6," &
+ "IPAD278:J7," &
+ "IPAD283:G1," &
+ "IPAD288:F5," &
+ "IPAD293:F4," &
+ "IPAD3:A3," &
+ "IPAD300:D3," &
+ "IPAD31:D8," &
+ "IPAD32:C8," &
+ "IPAD38:B9," &
+ "IPAD39:B8," &
+ "IPAD45:G10," &
+ "IPAD46:F10," &
+ "IPAD52:D12," &
+ "IPAD53:C12," &
+ "IPAD74:A15," &
+ "IPAD75:B15," &
+ "IPAD78:C15," &
+ "IPAD79:B18," &
+ "IPAD86:D18," &
+ "IPAD9:B5," &
+ "IPAD91:E17," &
+ "IPAD96:E18," &
+ "J1:J1," &
+ "J12:J12," &
+ "J13:J13," &
+ "J14:J14," &
+ "J15:J15," &
+ "J16:J16," &
+ "J17:J17," &
+ "J2:J2," &
+ "J4:J4," &
+ "J5:J5," &
+ "K12:K12," &
+ "K13:K13," &
+ "K14:K14," &
+ "K15:K15," &
+ "K3:K3," &
+ "K4:K4," &
+ "K5:K5," &
+ "K6:K6," &
+ "L1:L1," &
+ "L15:L15," &
+ "L16:L16," &
+ "L17:L17," &
+ "L18:L18," &
+ "L2:L2," &
+ "L3:L3," &
+ "L4:L4," &
+ "L5:L5," &
+ "L6:L6," &
+ "M10:M10," &
+ "M13:M13," &
+ "M14:M14," &
+ "M15:M15," &
+ "M16:M16," &
+ "M18:M18," &
+ "M3:M3," &
+ "M4:M4," &
+ "M5:M5," &
+ "M6:M6," &
+ "M9:M9," &
+ "N10:N10," &
+ "N11:N11," &
+ "N12:N12," &
+ "N14:N14," &
+ "N15:N15," &
+ "N18:N18," &
+ "N4:N4," &
+ "N5:N5," &
+ "N7:N7," &
+ "N8:N8," &
+ "N9:N9," &
+ "P1:P1," &
+ "P10:P10," &
+ "P11:P11," &
+ "P12:P12," &
+ "P13:P13," &
+ "P16:P16," &
+ "P17:P17," &
+ "P18:P18," &
+ "P2:P2," &
+ "P3:P3," &
+ "P4:P4," &
+ "P6:P6," &
+ "P7:P7," &
+ "P8:P8," &
+ "P9:P9," &
+ "PROG_B:B1," &
+ "PUDC_B:B3," &
+ "R10:R10," &
+ "R11:R11," &
+ "R12:R12," &
+ "R13:R13," &
+ "R14:R14," &
+ "R15:R15," &
+ "R16:R16," &
+ "R18:R18," &
+ "R2:R2," &
+ "R3:R3," &
+ "R5:R5," &
+ "R6:R6," &
+ "R8:R8," &
+ "R9:R9," &
+ "T1:T1," &
+ "T12:T12," &
+ "T14:T14," &
+ "T15:T15," &
+ "T16:T16," &
+ "T17:T17," &
+ "T18:T18," &
+ "T2:T2," &
+ "T3:T3," &
+ "T4:T4," &
+ "T5:T5," &
+ "T8:T8," &
+ "TCK:A17," &
+ "TDI:A2," &
+ "TDO:C16," &
+ "TMS:D15," &
+ "U13:U13," &
+ "U15:U15," &
+ "U16:U16," &
+ "U18:U18," &
+ "U3:U3," &
+ "U4:U4," &
+ "U5:U5," &
+ "U6:U6," &
+ "U9:U9," &
+ "V11:V11," &
+ "V12:V12," &
+ "V13:V13," &
+ "V15:V15," &
+ "V5:V5," &
+ "V6:V6," &
+ "V7:V7," &
+ "V9:V9," &
+ "VCCAUX:(B7,B12,G2,G17,M2,M17,U7,U12)," &
+ "VCCINT:(E5,E14,F6,F13,N6,N13,P5,P14)," &
+ "VCCO_0:(A9,C6,C13,G8,G11)," &
+ "VCCO_1:(F16,H12,J18,L12,N16)," &
+ "VCCO_2:(M8,M11,T6,T13,V10)," &
+ "VCCO_3:(F3,H7,K1,L7,N3)";
+
+
+-- Scan Port Identification
+
+attribute TAP_SCAN_OUT of TDO : signal is true;
+attribute TAP_SCAN_IN of TDI : signal is true;
+attribute TAP_SCAN_CLOCK of TCK : signal is (10.0e6, both);
+attribute TAP_SCAN_MODE of TMS : signal is true;
+
+-- Compliance-Enable Description
+
+attribute COMPLIANCE_PATTERNS of XC3S1200E_FG320 : entity is
+ "(PROG_B, PUDC_B) (10)";
+
+-- Instruction Register Description
+
+attribute INSTRUCTION_LENGTH of XC3S1200E_FG320 : entity is 6;
+
+attribute INSTRUCTION_OPCODE of XC3S1200E_FG320 : entity is
+
+ "EXTEST (001111)," &
+ "SAMPLE (000001)," &
+ "PRELOAD (000001)," & -- Same as SAMPLE
+ "USER1 (000010)," & -- Not available until after configuration
+ "USER2 (000011)," & -- Not available until after configuration
+ "CFG_OUT (000100)," & -- Not available during configuration with another mode.
+ "CFG_IN (000101)," & -- Not available during configuration with another mode.
+ "INTEST (000111)," &
+ "USERCODE (001000)," &
+ "IDCODE (001001)," &
+ "HIGHZ (001010)," &
+ "JPROGRAM (001011)," & -- Not available during configuration with another mode.
+ "JSTART (001100)," & -- Not available during configuration with another mode.
+ "JSHUTDOWN (001101)," & -- Not available during configuration with another mode.
+ "BYPASS (111111)," &
+ "ISC_ENABLE (010000)," &
+ "ISC_PROGRAM (010001)," &
+ "ISC_NOOP (010100)," &
+ "ISC_READ (010101)," &
+ "ISC_DISABLE (010110)";
+
+attribute INSTRUCTION_CAPTURE of XC3S1200E_FG320 : entity is
+-- Bit 5 is 1 when DONE is released (part of startup sequence)
+-- Bit 4 is 1 if house-cleaning is complete
+-- Bit 3 is ISC_Enabled
+-- Bit 2 is ISC_Done
+ "XXXX01" ;
+
+attribute INSTRUCTION_PRIVATE of XC3S1200E_FG320 : entity is
+ "USER1," &
+ "USER2," &
+ "CFG_OUT," &
+ "CFG_IN," &
+ "JPROGRAM," &
+ "JSTART," &
+ "JSHUTDOWN," &
+ "ISC_ENABLE," &
+ "ISC_PROGRAM," &
+ "ISC_NOOP," &
+ "ISC_READ," &
+ "ISC_DISABLE";
+
+-- Optional Register Description
+
+attribute IDCODE_REGISTER of XC3S1200E_FG320 : entity is "XXXX" & -- version
+ "0001110" & -- family
+ "000101110" & -- array size
+ "00001001001" & -- manufacturer
+ "1"; -- required by 1149.1
+
+
+attribute USERCODE_REGISTER of XC3S1200E_FG320 : entity is "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX";
+
+-- Register Access Description
+
+attribute REGISTER_ACCESS of XC3S1200E_FG320 : entity is
+ "TEST1[8] (USER1)," &
+ "TEST2[16] (USER2)," &
+ "DEVICE_ID (USERCODE,IDCODE)," &
+ "BYPASS (BYPASS,HIGHZ,JPROGRAM,JSTART,JSHUTDOWN)," &
+ "CFG_DATA[3838752] (CFG_IN)," &
+ "ISC_PDATA[16] (ISC_PROGRAM),"&
+ "ISC_RDATA[16] (ISC_READ),"&
+ "ISC_DEFAULT[5] (ISC_NOOP)," &
+ "ISC_CONFIG[5] (ISC_ENABLE,ISC_DISABLE)," &
+ "BOUNDARY (EXTEST, SAMPLE, PRELOAD, INTEST)";
+
+-- Boundary-Scan Register Description
+
+attribute BOUNDARY_LENGTH of XC3S1200E_FG320 : entity is 772;
+
+attribute BOUNDARY_REGISTER of XC3S1200E_FG320 : entity is
+-- cellnum (type, port, function, safe[, ccell, disval, disrslt])
+ " 771 (BC_2, IPAD79, input, X)," &
+ " 770 (BC_2, C17, input, X)," & -- PAD80
+ " 769 (BC_2, C17, output3, X, 768, 1, PULL1)," & -- PAD80
+ " 768 (BC_2, *, controlr, 1)," &
+ " 767 (BC_2, C18, input, X)," & -- PAD81
+ " 766 (BC_2, C18, output3, X, 765, 1, PULL1)," & -- PAD81
+ " 765 (BC_2, *, controlr, 1)," &
+ " 764 (BC_2, D16, input, X)," & -- PAD82
+ " 763 (BC_2, D16, output3, X, 762, 1, PULL1)," & -- PAD82
+ " 762 (BC_2, *, controlr, 1)," &
+ " 761 (BC_2, D17, input, X)," & -- PAD83
+ " 760 (BC_2, D17, output3, X, 759, 1, PULL1)," & -- PAD83
+ " 759 (BC_2, *, controlr, 1)," &
+ " 758 (BC_2, E16, input, X)," & -- PAD84
+ " 757 (BC_2, E16, output3, X, 756, 1, PULL1)," & -- PAD84
+ " 756 (BC_2, *, controlr, 1)," &
+ " 755 (BC_2, E15, input, X)," & -- PAD85
+ " 754 (BC_2, E15, output3, X, 753, 1, PULL1)," & -- PAD85
+ " 753 (BC_2, *, controlr, 1)," &
+ " 752 (BC_2, IPAD86, input, X)," &
+ " 751 (BC_2, *, internal, X)," & -- PAD87.I
+ " 750 (BC_2, *, internal, X)," & -- PAD87.O
+ " 749 (BC_2, *, internal, 1)," & -- PAD87.T
+ " 748 (BC_2, *, internal, X)," & -- PAD88.I
+ " 747 (BC_2, *, internal, X)," & -- PAD88.O
+ " 746 (BC_2, *, internal, 1)," & -- PAD88.T
+ " 745 (BC_2, *, internal, X)," & -- PAD89.I
+ " 744 (BC_2, *, internal, X)," & -- PAD89.O
+ " 743 (BC_2, *, internal, 1)," & -- PAD89.T
+ " 742 (BC_2, *, internal, X)," & -- PAD90.I
+ " 741 (BC_2, *, internal, X)," & -- PAD90.O
+ " 740 (BC_2, *, internal, 1)," & -- PAD90.T
+ " 739 (BC_2, IPAD91, input, X)," &
+ " 738 (BC_2, F14, input, X)," & -- PAD92
+ " 737 (BC_2, F14, output3, X, 736, 1, PULL1)," & -- PAD92
+ " 736 (BC_2, *, controlr, 1)," &
+ " 735 (BC_2, F15, input, X)," & -- PAD93
+ " 734 (BC_2, F15, output3, X, 733, 1, PULL1)," & -- PAD93
+ " 733 (BC_2, *, controlr, 1)," &
+ " 732 (BC_2, *, internal, X)," & -- PAD94.I
+ " 731 (BC_2, *, internal, X)," & -- PAD94.O
+ " 730 (BC_2, *, internal, 1)," & -- PAD94.T
+ " 729 (BC_2, *, internal, X)," & -- PAD95.I
+ " 728 (BC_2, *, internal, X)," & -- PAD95.O
+ " 727 (BC_2, *, internal, 1)," & -- PAD95.T
+ " 726 (BC_2, IPAD96, input, X)," &
+ " 725 (BC_2, G13, input, X)," & -- PAD97
+ " 724 (BC_2, G13, output3, X, 723, 1, PULL1)," & -- PAD97
+ " 723 (BC_2, *, controlr, 1)," &
+ " 722 (BC_2, G14, input, X)," & -- PAD98
+ " 721 (BC_2, G14, output3, X, 720, 1, PULL1)," & -- PAD98
+ " 720 (BC_2, *, controlr, 1)," &
+ " 719 (BC_2, F17, input, X)," & -- PAD99
+ " 718 (BC_2, F17, output3, X, 717, 1, PULL1)," & -- PAD99
+ " 717 (BC_2, *, controlr, 1)," &
+ " 716 (BC_2, F18, input, X)," & -- PAD100
+ " 715 (BC_2, F18, output3, X, 714, 1, PULL1)," & -- PAD100
+ " 714 (BC_2, *, controlr, 1)," &
+ " 713 (BC_2, IPAD101, input, X)," &
+ " 712 (BC_2, G16, input, X)," & -- PAD102
+ " 711 (BC_2, G16, output3, X, 710, 1, PULL1)," & -- PAD102
+ " 710 (BC_2, *, controlr, 1)," &
+ " 709 (BC_2, G15, input, X)," & -- PAD103
+ " 708 (BC_2, G15, output3, X, 707, 1, PULL1)," & -- PAD103
+ " 707 (BC_2, *, controlr, 1)," &
+ " 706 (BC_2, H15, input, X)," & -- PAD104
+ " 705 (BC_2, H15, output3, X, 704, 1, PULL1)," & -- PAD104
+ " 704 (BC_2, *, controlr, 1)," &
+ " 703 (BC_2, H14, input, X)," & -- PAD105
+ " 702 (BC_2, H14, output3, X, 701, 1, PULL1)," & -- PAD105
+ " 701 (BC_2, *, controlr, 1)," &
+ " 700 (BC_2, IPAD106, input, X)," &
+ " 699 (BC_2, H17, input, X)," & -- PAD107
+ " 698 (BC_2, H17, output3, X, 697, 1, PULL1)," & -- PAD107
+ " 697 (BC_2, *, controlr, 1)," &
+ " 696 (BC_2, H16, input, X)," & -- PAD108
+ " 695 (BC_2, H16, output3, X, 694, 1, PULL1)," & -- PAD108
+ " 694 (BC_2, *, controlr, 1)," &
+ " 693 (BC_2, J13, input, X)," & -- PAD109
+ " 692 (BC_2, J13, output3, X, 691, 1, PULL1)," & -- PAD109
+ " 691 (BC_2, *, controlr, 1)," &
+ " 690 (BC_2, J12, input, X)," & -- PAD110
+ " 689 (BC_2, J12, output3, X, 688, 1, PULL1)," & -- PAD110
+ " 688 (BC_2, *, controlr, 1)," &
+ " 687 (BC_2, IPAD111, input, X)," &
+ " 686 (BC_2, J14, input, X)," & -- PAD112
+ " 685 (BC_2, J14, output3, X, 684, 1, PULL1)," & -- PAD112
+ " 684 (BC_2, *, controlr, 1)," &
+ " 683 (BC_2, J15, input, X)," & -- PAD113
+ " 682 (BC_2, J15, output3, X, 681, 1, PULL1)," & -- PAD113
+ " 681 (BC_2, *, controlr, 1)," &
+ " 680 (BC_2, J16, input, X)," & -- PAD114
+ " 679 (BC_2, J16, output3, X, 678, 1, PULL1)," & -- PAD114
+ " 678 (BC_2, *, controlr, 1)," &
+ " 677 (BC_2, J17, input, X)," & -- PAD115
+ " 676 (BC_2, J17, output3, X, 675, 1, PULL1)," & -- PAD115
+ " 675 (BC_2, *, controlr, 1)," &
+ " 674 (BC_2, IPAD116, input, X)," &
+ " 673 (BC_2, K14, input, X)," & -- PAD117
+ " 672 (BC_2, K14, output3, X, 671, 1, PULL1)," & -- PAD117
+ " 671 (BC_2, *, controlr, 1)," &
+ " 670 (BC_2, K15, input, X)," & -- PAD118
+ " 669 (BC_2, K15, output3, X, 668, 1, PULL1)," & -- PAD118
+ " 668 (BC_2, *, controlr, 1)," &
+ " 667 (BC_2, K12, input, X)," & -- PAD119
+ " 666 (BC_2, K12, output3, X, 665, 1, PULL1)," & -- PAD119
+ " 665 (BC_2, *, controlr, 1)," &
+ " 664 (BC_2, K13, input, X)," & -- PAD120
+ " 663 (BC_2, K13, output3, X, 662, 1, PULL1)," & -- PAD120
+ " 662 (BC_2, *, controlr, 1)," &
+ " 661 (BC_2, IPAD121, input, X)," &
+ " 660 (BC_2, L17, input, X)," & -- PAD122
+ " 659 (BC_2, L17, output3, X, 658, 1, PULL1)," & -- PAD122
+ " 658 (BC_2, *, controlr, 1)," &
+ " 657 (BC_2, L18, input, X)," & -- PAD123
+ " 656 (BC_2, L18, output3, X, 655, 1, PULL1)," & -- PAD123
+ " 655 (BC_2, *, controlr, 1)," &
+ " 654 (BC_2, L15, input, X)," & -- PAD124
+ " 653 (BC_2, L15, output3, X, 652, 1, PULL1)," & -- PAD124
+ " 652 (BC_2, *, controlr, 1)," &
+ " 651 (BC_2, L16, input, X)," & -- PAD125
+ " 650 (BC_2, L16, output3, X, 649, 1, PULL1)," & -- PAD125
+ " 649 (BC_2, *, controlr, 1)," &
+ " 648 (BC_2, IPAD126, input, X)," &
+ " 647 (BC_2, M18, input, X)," & -- PAD127
+ " 646 (BC_2, M18, output3, X, 645, 1, PULL1)," & -- PAD127
+ " 645 (BC_2, *, controlr, 1)," &
+ " 644 (BC_2, N18, input, X)," & -- PAD128
+ " 643 (BC_2, N18, output3, X, 642, 1, PULL1)," & -- PAD128
+ " 642 (BC_2, *, controlr, 1)," &
+ " 641 (BC_2, M16, input, X)," & -- PAD129
+ " 640 (BC_2, M16, output3, X, 639, 1, PULL1)," & -- PAD129
+ " 639 (BC_2, *, controlr, 1)," &
+ " 638 (BC_2, M15, input, X)," & -- PAD130
+ " 637 (BC_2, M15, output3, X, 636, 1, PULL1)," & -- PAD130
+ " 636 (BC_2, *, controlr, 1)," &
+ " 635 (BC_2, IPAD131, input, X)," &
+ " 634 (BC_2, P18, input, X)," & -- PAD132
+ " 633 (BC_2, P18, output3, X, 632, 1, PULL1)," & -- PAD132
+ " 632 (BC_2, *, controlr, 1)," &
+ " 631 (BC_2, P17, input, X)," & -- PAD133
+ " 630 (BC_2, P17, output3, X, 629, 1, PULL1)," & -- PAD133
+ " 629 (BC_2, *, controlr, 1)," &
+ " 628 (BC_2, M13, input, X)," & -- PAD134
+ " 627 (BC_2, M13, output3, X, 626, 1, PULL1)," & -- PAD134
+ " 626 (BC_2, *, controlr, 1)," &
+ " 625 (BC_2, M14, input, X)," & -- PAD135
+ " 624 (BC_2, M14, output3, X, 623, 1, PULL1)," & -- PAD135
+ " 623 (BC_2, *, controlr, 1)," &
+ " 622 (BC_2, IPAD136, input, X)," &
+ " 621 (BC_2, *, internal, X)," & -- PAD137.I
+ " 620 (BC_2, *, internal, X)," & -- PAD137.O
+ " 619 (BC_2, *, internal, 1)," & -- PAD137.T
+ " 618 (BC_2, *, internal, X)," & -- PAD138.I
+ " 617 (BC_2, *, internal, X)," & -- PAD138.O
+ " 616 (BC_2, *, internal, 1)," & -- PAD138.T
+ " 615 (BC_2, N14, input, X)," & -- PAD139
+ " 614 (BC_2, N14, output3, X, 613, 1, PULL1)," & -- PAD139
+ " 613 (BC_2, *, controlr, 1)," &
+ " 612 (BC_2, N15, input, X)," & -- PAD140
+ " 611 (BC_2, N15, output3, X, 610, 1, PULL1)," & -- PAD140
+ " 610 (BC_2, *, controlr, 1)," &
+ " 609 (BC_2, IPAD141, input, X)," &
+ " 608 (BC_2, P16, input, X)," & -- PAD142
+ " 607 (BC_2, P16, output3, X, 606, 1, PULL1)," & -- PAD142
+ " 606 (BC_2, *, controlr, 1)," &
+ " 605 (BC_2, *, internal, X)," & -- PAD143.I
+ " 604 (BC_2, *, internal, X)," & -- PAD143.O
+ " 603 (BC_2, *, internal, 1)," & -- PAD143.T
+ " 602 (BC_2, *, internal, X)," & -- PAD144.I
+ " 601 (BC_2, *, internal, X)," & -- PAD144.O
+ " 600 (BC_2, *, internal, 1)," & -- PAD144.T
+ " 599 (BC_2, *, internal, X)," & -- PAD145.I
+ " 598 (BC_2, *, internal, X)," & -- PAD145.O
+ " 597 (BC_2, *, internal, 1)," & -- PAD145.T
+ " 596 (BC_2, R16, input, X)," & -- PAD146
+ " 595 (BC_2, R16, output3, X, 594, 1, PULL1)," & -- PAD146
+ " 594 (BC_2, *, controlr, 1)," &
+ " 593 (BC_2, R15, input, X)," & -- PAD147
+ " 592 (BC_2, R15, output3, X, 591, 1, PULL1)," & -- PAD147
+ " 591 (BC_2, *, controlr, 1)," &
+ " 590 (BC_2, IPAD148, input, X)," &
+ " 589 (BC_2, T18, input, X)," & -- PAD149
+ " 588 (BC_2, T18, output3, X, 587, 1, PULL1)," & -- PAD149
+ " 587 (BC_2, *, controlr, 1)," &
+ " 586 (BC_2, R18, input, X)," & -- PAD150
+ " 585 (BC_2, R18, output3, X, 584, 1, PULL1)," & -- PAD150
+ " 584 (BC_2, *, controlr, 1)," &
+ " 583 (BC_2, T17, input, X)," & -- PAD151
+ " 582 (BC_2, T17, output3, X, 581, 1, PULL1)," & -- PAD151
+ " 581 (BC_2, *, controlr, 1)," &
+ " 580 (BC_2, U18, input, X)," & -- PAD152
+ " 579 (BC_2, U18, output3, X, 578, 1, PULL1)," & -- PAD152
+ " 578 (BC_2, *, controlr, 1)," &
+ " 577 (BC_2, DONE, input, X)," &
+ " 576 (BC_2, DONE, output3, X, 575, 1, PULL1)," &
+ " 575 (BC_2, *, controlr, 1)," &
+ " 574 (BC_2, U16, input, X)," & -- PAD153
+ " 573 (BC_2, U16, output3, X, 572, 1, PULL1)," & -- PAD153
+ " 572 (BC_2, *, controlr, 1)," &
+ " 571 (BC_2, T16, input, X)," & -- PAD154
+ " 570 (BC_2, T16, output3, X, 569, 1, PULL1)," & -- PAD154
+ " 569 (BC_2, *, controlr, 1)," &
+ " 568 (BC_2, IPAD155, input, X)," &
+ " 567 (BC_2, U15, input, X)," & -- PAD156
+ " 566 (BC_2, U15, output3, X, 565, 1, PULL1)," & -- PAD156
+ " 565 (BC_2, *, controlr, 1)," &
+ " 564 (BC_2, V15, input, X)," & -- PAD157
+ " 563 (BC_2, V15, output3, X, 562, 1, PULL1)," & -- PAD157
+ " 562 (BC_2, *, controlr, 1)," &
+ " 561 (BC_2, T15, input, X)," & -- PAD158
+ " 560 (BC_2, T15, output3, X, 559, 1, PULL1)," & -- PAD158
+ " 559 (BC_2, *, controlr, 1)," &
+ " 558 (BC_2, R14, input, X)," & -- PAD159
+ " 557 (BC_2, R14, output3, X, 556, 1, PULL1)," & -- PAD159
+ " 556 (BC_2, *, controlr, 1)," &
+ " 555 (BC_2, T14, input, X)," & -- PAD160
+ " 554 (BC_2, T14, output3, X, 553, 1, PULL1)," & -- PAD160
+ " 553 (BC_2, *, controlr, 1)," &
+ " 552 (BC_2, IPAD161, input, X)," &
+ " 551 (BC_2, IPAD162, input, X)," &
+ " 550 (BC_2, *, internal, X)," & -- PAD163.I
+ " 549 (BC_2, *, internal, X)," & -- PAD163.O
+ " 548 (BC_2, *, internal, 1)," & -- PAD163.T
+ " 547 (BC_2, *, internal, X)," & -- PAD164.I
+ " 546 (BC_2, *, internal, X)," & -- PAD164.O
+ " 545 (BC_2, *, internal, 1)," & -- PAD164.T
+ " 544 (BC_2, *, internal, X)," & -- PAD165.I
+ " 543 (BC_2, *, internal, X)," & -- PAD165.O
+ " 542 (BC_2, *, internal, 1)," & -- PAD165.T
+ " 541 (BC_2, R13, input, X)," & -- PAD166
+ " 540 (BC_2, R13, output3, X, 539, 1, PULL1)," & -- PAD166
+ " 539 (BC_2, *, controlr, 1)," &
+ " 538 (BC_2, P13, input, X)," & -- PAD167
+ " 537 (BC_2, P13, output3, X, 536, 1, PULL1)," & -- PAD167
+ " 536 (BC_2, *, controlr, 1)," &
+ " 535 (BC_2, *, internal, X)," & -- IPAD168
+ " 534 (BC_2, *, internal, X)," & -- IPAD169
+ " 533 (BC_2, P12, input, X)," & -- PAD170
+ " 532 (BC_2, P12, output3, X, 531, 1, PULL1)," & -- PAD170
+ " 531 (BC_2, *, controlr, 1)," &
+ " 530 (BC_2, N12, input, X)," & -- PAD171
+ " 529 (BC_2, N12, output3, X, 528, 1, PULL1)," & -- PAD171
+ " 528 (BC_2, *, controlr, 1)," &
+ " 527 (BC_2, U13, input, X)," & -- PAD172
+ " 526 (BC_2, U13, output3, X, 525, 1, PULL1)," & -- PAD172
+ " 525 (BC_2, *, controlr, 1)," &
+ " 524 (BC_2, R12, input, X)," & -- PAD173
+ " 523 (BC_2, R12, output3, X, 522, 1, PULL1)," & -- PAD173
+ " 522 (BC_2, *, controlr, 1)," &
+ " 521 (BC_2, T12, input, X)," & -- PAD174
+ " 520 (BC_2, T12, output3, X, 519, 1, PULL1)," & -- PAD174
+ " 519 (BC_2, *, controlr, 1)," &
+ " 518 (BC_2, *, internal, X)," & -- IPAD175
+ " 517 (BC_2, *, internal, X)," & -- IPAD176
+ " 516 (BC_2, *, internal, X)," & -- PAD177.I
+ " 515 (BC_2, *, internal, X)," & -- PAD177.O
+ " 514 (BC_2, *, internal, 1)," & -- PAD177.T
+ " 513 (BC_2, V13, input, X)," & -- PAD178
+ " 512 (BC_2, V13, output3, X, 511, 1, PULL1)," & -- PAD178
+ " 511 (BC_2, *, controlr, 1)," &
+ " 510 (BC_2, V12, input, X)," & -- PAD179
+ " 509 (BC_2, V12, output3, X, 508, 1, PULL1)," & -- PAD179
+ " 508 (BC_2, *, controlr, 1)," &
+ " 507 (BC_2, R11, input, X)," & -- PAD180
+ " 506 (BC_2, R11, output3, X, 505, 1, PULL1)," & -- PAD180
+ " 505 (BC_2, *, controlr, 1)," &
+ " 504 (BC_2, N11, input, X)," & -- PAD181
+ " 503 (BC_2, N11, output3, X, 502, 1, PULL1)," & -- PAD181
+ " 502 (BC_2, *, controlr, 1)," &
+ " 501 (BC_2, P11, input, X)," & -- PAD182
+ " 500 (BC_2, P11, output3, X, 499, 1, PULL1)," & -- PAD182
+ " 499 (BC_2, *, controlr, 1)," &
+ " 498 (BC_2, IPAD183, input, X)," &
+ " 497 (BC_2, IPAD184, input, X)," &
+ " 496 (BC_2, N10, input, X)," & -- PAD185
+ " 495 (BC_2, N10, output3, X, 494, 1, PULL1)," & -- PAD185
+ " 494 (BC_2, *, controlr, 1)," &
+ " 493 (BC_2, M10, input, X)," & -- PAD186
+ " 492 (BC_2, M10, output3, X, 491, 1, PULL1)," & -- PAD186
+ " 491 (BC_2, *, controlr, 1)," &
+ " 490 (BC_2, V11, input, X)," & -- PAD187
+ " 489 (BC_2, V11, output3, X, 488, 1, PULL1)," & -- PAD187
+ " 488 (BC_2, *, controlr, 1)," &
+ " 487 (BC_2, P10, input, X)," & -- PAD188
+ " 486 (BC_2, P10, output3, X, 485, 1, PULL1)," & -- PAD188
+ " 485 (BC_2, *, controlr, 1)," &
+ " 484 (BC_2, R10, input, X)," & -- PAD189
+ " 483 (BC_2, R10, output3, X, 482, 1, PULL1)," & -- PAD189
+ " 482 (BC_2, *, controlr, 1)," &
+ " 481 (BC_2, IPAD190, input, X)," &
+ " 480 (BC_2, IPAD191, input, X)," &
+ " 479 (BC_2, V9, input, X)," & -- PAD192
+ " 478 (BC_2, V9, output3, X, 477, 1, PULL1)," & -- PAD192
+ " 477 (BC_2, *, controlr, 1)," &
+ " 476 (BC_2, U9, input, X)," & -- PAD193
+ " 475 (BC_2, U9, output3, X, 474, 1, PULL1)," & -- PAD193
+ " 474 (BC_2, *, controlr, 1)," &
+ " 473 (BC_2, R9, input, X)," & -- PAD194
+ " 472 (BC_2, R9, output3, X, 471, 1, PULL1)," & -- PAD194
+ " 471 (BC_2, *, controlr, 1)," &
+ " 470 (BC_2, M9, input, X)," & -- PAD195
+ " 469 (BC_2, M9, output3, X, 468, 1, PULL1)," & -- PAD195
+ " 468 (BC_2, *, controlr, 1)," &
+ " 467 (BC_2, N9, input, X)," & -- PAD196
+ " 466 (BC_2, N9, output3, X, 465, 1, PULL1)," & -- PAD196
+ " 465 (BC_2, *, controlr, 1)," &
+ " 464 (BC_2, IPAD197, input, X)," &
+ " 463 (BC_2, IPAD198, input, X)," &
+ " 462 (BC_2, T8, input, X)," & -- PAD199
+ " 461 (BC_2, T8, output3, X, 460, 1, PULL1)," & -- PAD199
+ " 460 (BC_2, *, controlr, 1)," &
+ " 459 (BC_2, R8, input, X)," & -- PAD200
+ " 458 (BC_2, R8, output3, X, 457, 1, PULL1)," & -- PAD200
+ " 457 (BC_2, *, controlr, 1)," &
+ " 456 (BC_2, P9, input, X)," & -- PAD201
+ " 455 (BC_2, P9, output3, X, 454, 1, PULL1)," & -- PAD201
+ " 454 (BC_2, *, controlr, 1)," &
+ " 453 (BC_2, N8, input, X)," & -- PAD202
+ " 452 (BC_2, N8, output3, X, 451, 1, PULL1)," & -- PAD202
+ " 451 (BC_2, *, controlr, 1)," &
+ " 450 (BC_2, P8, input, X)," & -- PAD203
+ " 449 (BC_2, P8, output3, X, 448, 1, PULL1)," & -- PAD203
+ " 448 (BC_2, *, controlr, 1)," &
+ " 447 (BC_2, IPAD204, input, X)," &
+ " 446 (BC_2, IPAD205, input, X)," &
+ " 445 (BC_2, V7, input, X)," & -- PAD206
+ " 444 (BC_2, V7, output3, X, 443, 1, PULL1)," & -- PAD206
+ " 443 (BC_2, *, controlr, 1)," &
+ " 442 (BC_2, P7, input, X)," & -- PAD207
+ " 441 (BC_2, P7, output3, X, 440, 1, PULL1)," & -- PAD207
+ " 440 (BC_2, *, controlr, 1)," &
+ " 439 (BC_2, N7, input, X)," & -- PAD208
+ " 438 (BC_2, N7, output3, X, 437, 1, PULL1)," & -- PAD208
+ " 437 (BC_2, *, controlr, 1)," &
+ " 436 (BC_2, U6, input, X)," & -- PAD209
+ " 435 (BC_2, U6, output3, X, 434, 1, PULL1)," & -- PAD209
+ " 434 (BC_2, *, controlr, 1)," &
+ " 433 (BC_2, V6, input, X)," & -- PAD210
+ " 432 (BC_2, V6, output3, X, 431, 1, PULL1)," & -- PAD210
+ " 431 (BC_2, *, controlr, 1)," &
+ " 430 (BC_2, V5, input, X)," & -- PAD211
+ " 429 (BC_2, V5, output3, X, 428, 1, PULL1)," & -- PAD211
+ " 428 (BC_2, *, controlr, 1)," &
+ " 427 (BC_2, *, internal, X)," & -- IPAD212
+ " 426 (BC_2, *, internal, X)," & -- IPAD213
+ " 425 (BC_2, P6, input, X)," & -- PAD214
+ " 424 (BC_2, P6, output3, X, 423, 1, PULL1)," & -- PAD214
+ " 423 (BC_2, *, controlr, 1)," &
+ " 422 (BC_2, R6, input, X)," & -- PAD215
+ " 421 (BC_2, R6, output3, X, 420, 1, PULL1)," & -- PAD215
+ " 420 (BC_2, *, controlr, 1)," &
+ " 419 (BC_2, *, internal, X)," & -- PAD216.I
+ " 418 (BC_2, *, internal, X)," & -- PAD216.O
+ " 417 (BC_2, *, internal, 1)," & -- PAD216.T
+ " 416 (BC_2, *, internal, X)," & -- PAD217.I
+ " 415 (BC_2, *, internal, X)," & -- PAD217.O
+ " 414 (BC_2, *, internal, 1)," & -- PAD217.T
+ " 413 (BC_2, *, internal, X)," & -- PAD218.I
+ " 412 (BC_2, *, internal, X)," & -- PAD218.O
+ " 411 (BC_2, *, internal, 1)," & -- PAD218.T
+ " 410 (BC_2, *, internal, X)," & -- IPAD219
+ " 409 (BC_2, *, internal, X)," & -- IPAD220
+ " 408 (BC_2, T5, input, X)," & -- PAD221
+ " 407 (BC_2, T5, output3, X, 406, 1, PULL1)," & -- PAD221
+ " 406 (BC_2, *, controlr, 1)," &
+ " 405 (BC_2, R5, input, X)," & -- PAD222
+ " 404 (BC_2, R5, output3, X, 403, 1, PULL1)," & -- PAD222
+ " 403 (BC_2, *, controlr, 1)," &
+ " 402 (BC_2, U5, input, X)," & -- PAD223
+ " 401 (BC_2, U5, output3, X, 400, 1, PULL1)," & -- PAD223
+ " 400 (BC_2, *, controlr, 1)," &
+ " 399 (BC_2, T4, input, X)," & -- PAD224
+ " 398 (BC_2, T4, output3, X, 397, 1, PULL1)," & -- PAD224
+ " 397 (BC_2, *, controlr, 1)," &
+ " 396 (BC_2, U4, input, X)," & -- PAD225
+ " 395 (BC_2, U4, output3, X, 394, 1, PULL1)," & -- PAD225
+ " 394 (BC_2, *, controlr, 1)," &
+ " 393 (BC_2, IPAD226, input, X)," &
+ " 392 (BC_2, IPAD227, input, X)," &
+ " 391 (BC_2, T3, input, X)," & -- PAD228
+ " 390 (BC_2, T3, output3, X, 389, 1, PULL1)," & -- PAD228
+ " 389 (BC_2, *, controlr, 1)," &
+ " 388 (BC_2, U3, input, X)," & -- PAD229
+ " 387 (BC_2, U3, output3, X, 386, 1, PULL1)," & -- PAD229
+ " 386 (BC_2, *, controlr, 1)," &
+ " 385 (BC_2, IPAD230, input, X)," &
+ " 384 (BC_2, IPAD231, input, X)," &
+ " 383 (BC_2, T1, input, X)," & -- PAD232
+ " 382 (BC_2, T1, output3, X, 381, 1, PULL1)," & -- PAD232
+ " 381 (BC_2, *, controlr, 1)," &
+ " 380 (BC_2, T2, input, X)," & -- PAD233
+ " 379 (BC_2, T2, output3, X, 378, 1, PULL1)," & -- PAD233
+ " 378 (BC_2, *, controlr, 1)," &
+ " 377 (BC_2, R2, input, X)," & -- PAD234
+ " 376 (BC_2, R2, output3, X, 375, 1, PULL1)," & -- PAD234
+ " 375 (BC_2, *, controlr, 1)," &
+ " 374 (BC_2, R3, input, X)," & -- PAD235
+ " 373 (BC_2, R3, output3, X, 372, 1, PULL1)," & -- PAD235
+ " 372 (BC_2, *, controlr, 1)," &
+ " 371 (BC_2, *, internal, X)," & -- PAD236.I
+ " 370 (BC_2, *, internal, X)," & -- PAD236.O
+ " 369 (BC_2, *, internal, 1)," & -- PAD236.T
+ " 368 (BC_2, *, internal, X)," & -- PAD237.I
+ " 367 (BC_2, *, internal, X)," & -- PAD237.O
+ " 366 (BC_2, *, internal, 1)," & -- PAD237.T
+ " 365 (BC_2, IPAD238, input, X)," &
+ " 364 (BC_2, *, internal, X)," & -- PAD239.I
+ " 363 (BC_2, *, internal, X)," & -- PAD239.O
+ " 362 (BC_2, *, internal, 1)," & -- PAD239.T
+ " 361 (BC_2, *, internal, X)," & -- PAD240.I
+ " 360 (BC_2, *, internal, X)," & -- PAD240.O
+ " 359 (BC_2, *, internal, 1)," & -- PAD240.T
+ " 358 (BC_2, P4, input, X)," & -- PAD241
+ " 357 (BC_2, P4, output3, X, 356, 1, PULL1)," & -- PAD241
+ " 356 (BC_2, *, controlr, 1)," &
+ " 355 (BC_2, P3, input, X)," & -- PAD242
+ " 354 (BC_2, P3, output3, X, 353, 1, PULL1)," & -- PAD242
+ " 353 (BC_2, *, controlr, 1)," &
+ " 352 (BC_2, IPAD243, input, X)," &
+ " 351 (BC_2, P1, input, X)," & -- PAD244
+ " 350 (BC_2, P1, output3, X, 349, 1, PULL1)," & -- PAD244
+ " 349 (BC_2, *, controlr, 1)," &
+ " 348 (BC_2, P2, input, X)," & -- PAD245
+ " 347 (BC_2, P2, output3, X, 346, 1, PULL1)," & -- PAD245
+ " 346 (BC_2, *, controlr, 1)," &
+ " 345 (BC_2, *, internal, X)," & -- PAD246.I
+ " 344 (BC_2, *, internal, X)," & -- PAD246.O
+ " 343 (BC_2, *, internal, 1)," & -- PAD246.T
+ " 342 (BC_2, *, internal, X)," & -- PAD247.I
+ " 341 (BC_2, *, internal, X)," & -- PAD247.O
+ " 340 (BC_2, *, internal, 1)," & -- PAD247.T
+ " 339 (BC_2, IPAD248, input, X)," &
+ " 338 (BC_2, N5, input, X)," & -- PAD249
+ " 337 (BC_2, N5, output3, X, 336, 1, PULL1)," & -- PAD249
+ " 336 (BC_2, *, controlr, 1)," &
+ " 335 (BC_2, N4, input, X)," & -- PAD250
+ " 334 (BC_2, N4, output3, X, 333, 1, PULL1)," & -- PAD250
+ " 333 (BC_2, *, controlr, 1)," &
+ " 332 (BC_2, M6, input, X)," & -- PAD251
+ " 331 (BC_2, M6, output3, X, 330, 1, PULL1)," & -- PAD251
+ " 330 (BC_2, *, controlr, 1)," &
+ " 329 (BC_2, M5, input, X)," & -- PAD252
+ " 328 (BC_2, M5, output3, X, 327, 1, PULL1)," & -- PAD252
+ " 327 (BC_2, *, controlr, 1)," &
+ " 326 (BC_2, IPAD253, input, X)," &
+ " 325 (BC_2, M3, input, X)," & -- PAD254
+ " 324 (BC_2, M3, output3, X, 323, 1, PULL1)," & -- PAD254
+ " 323 (BC_2, *, controlr, 1)," &
+ " 322 (BC_2, M4, input, X)," & -- PAD255
+ " 321 (BC_2, M4, output3, X, 320, 1, PULL1)," & -- PAD255
+ " 320 (BC_2, *, controlr, 1)," &
+ " 319 (BC_2, L5, input, X)," & -- PAD256
+ " 318 (BC_2, L5, output3, X, 317, 1, PULL1)," & -- PAD256
+ " 317 (BC_2, *, controlr, 1)," &
+ " 316 (BC_2, L6, input, X)," & -- PAD257
+ " 315 (BC_2, L6, output3, X, 314, 1, PULL1)," & -- PAD257
+ " 314 (BC_2, *, controlr, 1)," &
+ " 313 (BC_2, IPAD258, input, X)," &
+ " 312 (BC_2, L4, input, X)," & -- PAD259
+ " 311 (BC_2, L4, output3, X, 310, 1, PULL1)," & -- PAD259
+ " 310 (BC_2, *, controlr, 1)," &
+ " 309 (BC_2, L3, input, X)," & -- PAD260
+ " 308 (BC_2, L3, output3, X, 307, 1, PULL1)," & -- PAD260
+ " 307 (BC_2, *, controlr, 1)," &
+ " 306 (BC_2, L2, input, X)," & -- PAD261
+ " 305 (BC_2, L2, output3, X, 304, 1, PULL1)," & -- PAD261
+ " 304 (BC_2, *, controlr, 1)," &
+ " 303 (BC_2, L1, input, X)," & -- PAD262
+ " 302 (BC_2, L1, output3, X, 301, 1, PULL1)," & -- PAD262
+ " 301 (BC_2, *, controlr, 1)," &
+ " 300 (BC_2, IPAD263, input, X)," &
+ " 299 (BC_2, K5, input, X)," & -- PAD264
+ " 298 (BC_2, K5, output3, X, 297, 1, PULL1)," & -- PAD264
+ " 297 (BC_2, *, controlr, 1)," &
+ " 296 (BC_2, K6, input, X)," & -- PAD265
+ " 295 (BC_2, K6, output3, X, 294, 1, PULL1)," & -- PAD265
+ " 294 (BC_2, *, controlr, 1)," &
+ " 293 (BC_2, K4, input, X)," & -- PAD266
+ " 292 (BC_2, K4, output3, X, 291, 1, PULL1)," & -- PAD266
+ " 291 (BC_2, *, controlr, 1)," &
+ " 290 (BC_2, K3, input, X)," & -- PAD267
+ " 289 (BC_2, K3, output3, X, 288, 1, PULL1)," & -- PAD267
+ " 288 (BC_2, *, controlr, 1)," &
+ " 287 (BC_2, IPAD268, input, X)," &
+ " 286 (BC_2, J2, input, X)," & -- PAD269
+ " 285 (BC_2, J2, output3, X, 284, 1, PULL1)," & -- PAD269
+ " 284 (BC_2, *, controlr, 1)," &
+ " 283 (BC_2, J1, input, X)," & -- PAD270
+ " 282 (BC_2, J1, output3, X, 281, 1, PULL1)," & -- PAD270
+ " 281 (BC_2, *, controlr, 1)," &
+ " 280 (BC_2, J4, input, X)," & -- PAD271
+ " 279 (BC_2, J4, output3, X, 278, 1, PULL1)," & -- PAD271
+ " 278 (BC_2, *, controlr, 1)," &
+ " 277 (BC_2, J5, input, X)," & -- PAD272
+ " 276 (BC_2, J5, output3, X, 275, 1, PULL1)," & -- PAD272
+ " 275 (BC_2, *, controlr, 1)," &
+ " 274 (BC_2, IPAD273, input, X)," &
+ " 273 (BC_2, H1, input, X)," & -- PAD274
+ " 272 (BC_2, H1, output3, X, 271, 1, PULL1)," & -- PAD274
+ " 271 (BC_2, *, controlr, 1)," &
+ " 270 (BC_2, H2, input, X)," & -- PAD275
+ " 269 (BC_2, H2, output3, X, 268, 1, PULL1)," & -- PAD275
+ " 268 (BC_2, *, controlr, 1)," &
+ " 267 (BC_2, H3, input, X)," & -- PAD276
+ " 266 (BC_2, H3, output3, X, 265, 1, PULL1)," & -- PAD276
+ " 265 (BC_2, *, controlr, 1)," &
+ " 264 (BC_2, H4, input, X)," & -- PAD277
+ " 263 (BC_2, H4, output3, X, 262, 1, PULL1)," & -- PAD277
+ " 262 (BC_2, *, controlr, 1)," &
+ " 261 (BC_2, IPAD278, input, X)," &
+ " 260 (BC_2, H5, input, X)," & -- PAD279
+ " 259 (BC_2, H5, output3, X, 258, 1, PULL1)," & -- PAD279
+ " 258 (BC_2, *, controlr, 1)," &
+ " 257 (BC_2, H6, input, X)," & -- PAD280
+ " 256 (BC_2, H6, output3, X, 255, 1, PULL1)," & -- PAD280
+ " 255 (BC_2, *, controlr, 1)," &
+ " 254 (BC_2, G5, input, X)," & -- PAD281
+ " 253 (BC_2, G5, output3, X, 252, 1, PULL1)," & -- PAD281
+ " 252 (BC_2, *, controlr, 1)," &
+ " 251 (BC_2, G6, input, X)," & -- PAD282
+ " 250 (BC_2, G6, output3, X, 249, 1, PULL1)," & -- PAD282
+ " 249 (BC_2, *, controlr, 1)," &
+ " 248 (BC_2, IPAD283, input, X)," &
+ " 247 (BC_2, G4, input, X)," & -- PAD284
+ " 246 (BC_2, G4, output3, X, 245, 1, PULL1)," & -- PAD284
+ " 245 (BC_2, *, controlr, 1)," &
+ " 244 (BC_2, G3, input, X)," & -- PAD285
+ " 243 (BC_2, G3, output3, X, 242, 1, PULL1)," & -- PAD285
+ " 242 (BC_2, *, controlr, 1)," &
+ " 241 (BC_2, F2, input, X)," & -- PAD286
+ " 240 (BC_2, F2, output3, X, 239, 1, PULL1)," & -- PAD286
+ " 239 (BC_2, *, controlr, 1)," &
+ " 238 (BC_2, F1, input, X)," & -- PAD287
+ " 237 (BC_2, F1, output3, X, 236, 1, PULL1)," & -- PAD287
+ " 236 (BC_2, *, controlr, 1)," &
+ " 235 (BC_2, IPAD288, input, X)," &
+ " 234 (BC_2, *, internal, X)," & -- PAD289.I
+ " 233 (BC_2, *, internal, X)," & -- PAD289.O
+ " 232 (BC_2, *, internal, 1)," & -- PAD289.T
+ " 231 (BC_2, *, internal, X)," & -- PAD290.I
+ " 230 (BC_2, *, internal, X)," & -- PAD290.O
+ " 229 (BC_2, *, internal, 1)," & -- PAD290.T
+ " 228 (BC_2, E3, input, X)," & -- PAD291
+ " 227 (BC_2, E3, output3, X, 226, 1, PULL1)," & -- PAD291
+ " 226 (BC_2, *, controlr, 1)," &
+ " 225 (BC_2, E4, input, X)," & -- PAD292
+ " 224 (BC_2, E4, output3, X, 223, 1, PULL1)," & -- PAD292
+ " 223 (BC_2, *, controlr, 1)," &
+ " 222 (BC_2, IPAD293, input, X)," &
+ " 221 (BC_2, *, internal, X)," & -- PAD294.I
+ " 220 (BC_2, *, internal, X)," & -- PAD294.O
+ " 219 (BC_2, *, internal, 1)," & -- PAD294.T
+ " 218 (BC_2, *, internal, X)," & -- PAD295.I
+ " 217 (BC_2, *, internal, X)," & -- PAD295.O
+ " 216 (BC_2, *, internal, 1)," & -- PAD295.T
+ " 215 (BC_2, E1, input, X)," & -- PAD296
+ " 214 (BC_2, E1, output3, X, 213, 1, PULL1)," & -- PAD296
+ " 213 (BC_2, *, controlr, 1)," &
+ " 212 (BC_2, E2, input, X)," & -- PAD297
+ " 211 (BC_2, E2, output3, X, 210, 1, PULL1)," & -- PAD297
+ " 210 (BC_2, *, controlr, 1)," &
+ " 209 (BC_2, D4, input, X)," & -- PAD298
+ " 208 (BC_2, D4, output3, X, 207, 1, PULL1)," & -- PAD298
+ " 207 (BC_2, *, controlr, 1)," &
+ " 206 (BC_2, *, internal, X)," & -- PAD299.I
+ " 205 (BC_2, *, internal, X)," & -- PAD299.O
+ " 204 (BC_2, *, internal, 1)," & -- PAD299.T
+ " 203 (BC_2, IPAD300, input, X)," &
+ " 202 (BC_2, D2, input, X)," & -- PAD301
+ " 201 (BC_2, D2, output3, X, 200, 1, PULL1)," & -- PAD301
+ " 200 (BC_2, *, controlr, 1)," &
+ " 199 (BC_2, D1, input, X)," & -- PAD302
+ " 198 (BC_2, D1, output3, X, 197, 1, PULL1)," & -- PAD302
+ " 197 (BC_2, *, controlr, 1)," &
+ " 196 (BC_2, C2, input, X)," & -- PAD303
+ " 195 (BC_2, C2, output3, X, 194, 1, PULL1)," & -- PAD303
+ " 194 (BC_2, *, controlr, 1)," &
+ " 193 (BC_2, C1, input, X)," & -- PAD304
+ " 192 (BC_2, C1, output3, X, 191, 1, PULL1)," & -- PAD304
+ " 191 (BC_2, *, controlr, 1)," &
+ " 190 (BC_2, *, internal, 1)," & -- PROG_B
+ " 189 (BC_2, *, internal, 1)," & -- PUDC_B
+ " 188 (BC_2, *, internal, 1)," & -- PUDC_B
+ " 187 (BC_2, *, internal, 1)," & -- PUDC_B
+ " 186 (BC_2, C3, input, X)," & -- PAD2
+ " 185 (BC_2, C3, output3, X, 184, 1, PULL1)," & -- PAD2
+ " 184 (BC_2, *, controlr, 1)," &
+ " 183 (BC_2, IPAD3, input, X)," &
+ " 182 (BC_2, B4, input, X)," & -- PAD4
+ " 181 (BC_2, B4, output3, X, 180, 1, PULL1)," & -- PAD4
+ " 180 (BC_2, *, controlr, 1)," &
+ " 179 (BC_2, A4, input, X)," & -- PAD5
+ " 178 (BC_2, A4, output3, X, 177, 1, PULL1)," & -- PAD5
+ " 177 (BC_2, *, controlr, 1)," &
+ " 176 (BC_2, C4, input, X)," & -- PAD6
+ " 175 (BC_2, C4, output3, X, 174, 1, PULL1)," & -- PAD6
+ " 174 (BC_2, *, controlr, 1)," &
+ " 173 (BC_2, D5, input, X)," & -- PAD7
+ " 172 (BC_2, D5, output3, X, 171, 1, PULL1)," & -- PAD7
+ " 171 (BC_2, *, controlr, 1)," &
+ " 170 (BC_2, C5, input, X)," & -- PAD8
+ " 169 (BC_2, C5, output3, X, 168, 1, PULL1)," & -- PAD8
+ " 168 (BC_2, *, controlr, 1)," &
+ " 167 (BC_2, IPAD9, input, X)," &
+ " 166 (BC_2, IPAD10, input, X)," &
+ " 165 (BC_2, E6, input, X)," & -- PAD11
+ " 164 (BC_2, E6, output3, X, 163, 1, PULL1)," & -- PAD11
+ " 163 (BC_2, *, controlr, 1)," &
+ " 162 (BC_2, D6, input, X)," & -- PAD12
+ " 161 (BC_2, D6, output3, X, 160, 1, PULL1)," & -- PAD12
+ " 160 (BC_2, *, controlr, 1)," &
+ " 159 (BC_2, *, internal, X)," & -- PAD13.I
+ " 158 (BC_2, *, internal, X)," & -- PAD13.O
+ " 157 (BC_2, *, internal, 1)," & -- PAD13.T
+ " 156 (BC_2, A6, input, X)," & -- PAD14
+ " 155 (BC_2, A6, output3, X, 154, 1, PULL1)," & -- PAD14
+ " 154 (BC_2, *, controlr, 1)," &
+ " 153 (BC_2, B6, input, X)," & -- PAD15
+ " 152 (BC_2, B6, output3, X, 151, 1, PULL1)," & -- PAD15
+ " 151 (BC_2, *, controlr, 1)," &
+ " 150 (BC_2, *, internal, X)," & -- IPAD16
+ " 149 (BC_2, *, internal, X)," & -- IPAD17
+ " 148 (BC_2, *, internal, X)," & -- PAD18.I
+ " 147 (BC_2, *, internal, X)," & -- PAD18.O
+ " 146 (BC_2, *, internal, 1)," & -- PAD18.T
+ " 145 (BC_2, *, internal, X)," & -- PAD19.I
+ " 144 (BC_2, *, internal, X)," & -- PAD19.O
+ " 143 (BC_2, *, internal, 1)," & -- PAD19.T
+ " 142 (BC_2, A7, input, X)," & -- PAD20
+ " 141 (BC_2, A7, output3, X, 140, 1, PULL1)," & -- PAD20
+ " 140 (BC_2, *, controlr, 1)," &
+ " 139 (BC_2, E7, input, X)," & -- PAD21
+ " 138 (BC_2, E7, output3, X, 137, 1, PULL1)," & -- PAD21
+ " 137 (BC_2, *, controlr, 1)," &
+ " 136 (BC_2, F7, input, X)," & -- PAD22
+ " 135 (BC_2, F7, output3, X, 134, 1, PULL1)," & -- PAD22
+ " 134 (BC_2, *, controlr, 1)," &
+ " 133 (BC_2, *, internal, X)," & -- IPAD23
+ " 132 (BC_2, *, internal, X)," & -- IPAD24
+ " 131 (BC_2, *, internal, X)," & -- PAD25.I
+ " 130 (BC_2, *, internal, X)," & -- PAD25.O
+ " 129 (BC_2, *, internal, 1)," & -- PAD25.T
+ " 128 (BC_2, D7, input, X)," & -- PAD26
+ " 127 (BC_2, D7, output3, X, 126, 1, PULL1)," & -- PAD26
+ " 126 (BC_2, *, controlr, 1)," &
+ " 125 (BC_2, C7, input, X)," & -- PAD27
+ " 124 (BC_2, C7, output3, X, 123, 1, PULL1)," & -- PAD27
+ " 123 (BC_2, *, controlr, 1)," &
+ " 122 (BC_2, A8, input, X)," & -- PAD28
+ " 121 (BC_2, A8, output3, X, 120, 1, PULL1)," & -- PAD28
+ " 120 (BC_2, *, controlr, 1)," &
+ " 119 (BC_2, F8, input, X)," & -- PAD29
+ " 118 (BC_2, F8, output3, X, 117, 1, PULL1)," & -- PAD29
+ " 117 (BC_2, *, controlr, 1)," &
+ " 116 (BC_2, E8, input, X)," & -- PAD30
+ " 115 (BC_2, E8, output3, X, 114, 1, PULL1)," & -- PAD30
+ " 114 (BC_2, *, controlr, 1)," &
+ " 113 (BC_2, IPAD31, input, X)," &
+ " 112 (BC_2, IPAD32, input, X)," &
+ " 111 (BC_2, F9, input, X)," & -- PAD33
+ " 110 (BC_2, F9, output3, X, 109, 1, PULL1)," & -- PAD33
+ " 109 (BC_2, *, controlr, 1)," &
+ " 108 (BC_2, E9, input, X)," & -- PAD34
+ " 107 (BC_2, E9, output3, X, 106, 1, PULL1)," & -- PAD34
+ " 106 (BC_2, *, controlr, 1)," &
+ " 105 (BC_2, G9, input, X)," & -- PAD35
+ " 104 (BC_2, G9, output3, X, 103, 1, PULL1)," & -- PAD35
+ " 103 (BC_2, *, controlr, 1)," &
+ " 102 (BC_2, D9, input, X)," & -- PAD36
+ " 101 (BC_2, D9, output3, X, 100, 1, PULL1)," & -- PAD36
+ " 100 (BC_2, *, controlr, 1)," &
+ " 99 (BC_2, C9, input, X)," & -- PAD37
+ " 98 (BC_2, C9, output3, X, 97, 1, PULL1)," & -- PAD37
+ " 97 (BC_2, *, controlr, 1)," &
+ " 96 (BC_2, IPAD38, input, X)," &
+ " 95 (BC_2, IPAD39, input, X)," &
+ " 94 (BC_2, A10, input, X)," & -- PAD40
+ " 93 (BC_2, A10, output3, X, 92, 1, PULL1)," & -- PAD40
+ " 92 (BC_2, *, controlr, 1)," &
+ " 91 (BC_2, B10, input, X)," & -- PAD41
+ " 90 (BC_2, B10, output3, X, 89, 1, PULL1)," & -- PAD41
+ " 89 (BC_2, *, controlr, 1)," &
+ " 88 (BC_2, B11, input, X)," & -- PAD42
+ " 87 (BC_2, B11, output3, X, 86, 1, PULL1)," & -- PAD42
+ " 86 (BC_2, *, controlr, 1)," &
+ " 85 (BC_2, E10, input, X)," & -- PAD43
+ " 84 (BC_2, E10, output3, X, 83, 1, PULL1)," & -- PAD43
+ " 83 (BC_2, *, controlr, 1)," &
+ " 82 (BC_2, D10, input, X)," & -- PAD44
+ " 81 (BC_2, D10, output3, X, 80, 1, PULL1)," & -- PAD44
+ " 80 (BC_2, *, controlr, 1)," &
+ " 79 (BC_2, IPAD45, input, X)," &
+ " 78 (BC_2, IPAD46, input, X)," &
+ " 77 (BC_2, D11, input, X)," & -- PAD47
+ " 76 (BC_2, D11, output3, X, 75, 1, PULL1)," & -- PAD47
+ " 75 (BC_2, *, controlr, 1)," &
+ " 74 (BC_2, C11, input, X)," & -- PAD48
+ " 73 (BC_2, C11, output3, X, 72, 1, PULL1)," & -- PAD48
+ " 72 (BC_2, *, controlr, 1)," &
+ " 71 (BC_2, A11, input, X)," & -- PAD49
+ " 70 (BC_2, A11, output3, X, 69, 1, PULL1)," & -- PAD49
+ " 69 (BC_2, *, controlr, 1)," &
+ " 68 (BC_2, F11, input, X)," & -- PAD50
+ " 67 (BC_2, F11, output3, X, 66, 1, PULL1)," & -- PAD50
+ " 66 (BC_2, *, controlr, 1)," &
+ " 65 (BC_2, E11, input, X)," & -- PAD51
+ " 64 (BC_2, E11, output3, X, 63, 1, PULL1)," & -- PAD51
+ " 63 (BC_2, *, controlr, 1)," &
+ " 62 (BC_2, IPAD52, input, X)," &
+ " 61 (BC_2, IPAD53, input, X)," &
+ " 60 (BC_2, A12, input, X)," & -- PAD54
+ " 59 (BC_2, A12, output3, X, 58, 1, PULL1)," & -- PAD54
+ " 58 (BC_2, *, controlr, 1)," &
+ " 57 (BC_2, E12, input, X)," & -- PAD55
+ " 56 (BC_2, E12, output3, X, 55, 1, PULL1)," & -- PAD55
+ " 55 (BC_2, *, controlr, 1)," &
+ " 54 (BC_2, F12, input, X)," & -- PAD56
+ " 53 (BC_2, F12, output3, X, 52, 1, PULL1)," & -- PAD56
+ " 52 (BC_2, *, controlr, 1)," &
+ " 51 (BC_2, D13, input, X)," & -- PAD57
+ " 50 (BC_2, D13, output3, X, 49, 1, PULL1)," & -- PAD57
+ " 49 (BC_2, *, controlr, 1)," &
+ " 48 (BC_2, B13, input, X)," & -- PAD58
+ " 47 (BC_2, B13, output3, X, 46, 1, PULL1)," & -- PAD58
+ " 46 (BC_2, *, controlr, 1)," &
+ " 45 (BC_2, A13, input, X)," & -- PAD59
+ " 44 (BC_2, A13, output3, X, 43, 1, PULL1)," & -- PAD59
+ " 43 (BC_2, *, controlr, 1)," &
+ " 42 (BC_2, *, internal, X)," & -- IPAD60
+ " 41 (BC_2, *, internal, X)," & -- IPAD61
+ " 40 (BC_2, A14, input, X)," & -- PAD62
+ " 39 (BC_2, A14, output3, X, 38, 1, PULL1)," & -- PAD62
+ " 38 (BC_2, *, controlr, 1)," &
+ " 37 (BC_2, B14, input, X)," & -- PAD63
+ " 36 (BC_2, B14, output3, X, 35, 1, PULL1)," & -- PAD63
+ " 35 (BC_2, *, controlr, 1)," &
+ " 34 (BC_2, *, internal, X)," & -- PAD64.I
+ " 33 (BC_2, *, internal, X)," & -- PAD64.O
+ " 32 (BC_2, *, internal, 1)," & -- PAD64.T
+ " 31 (BC_2, *, internal, X)," & -- PAD65.I
+ " 30 (BC_2, *, internal, X)," & -- PAD65.O
+ " 29 (BC_2, *, internal, 1)," & -- PAD65.T
+ " 28 (BC_2, *, internal, X)," & -- PAD66.I
+ " 27 (BC_2, *, internal, X)," & -- PAD66.O
+ " 26 (BC_2, *, internal, 1)," & -- PAD66.T
+ " 25 (BC_2, *, internal, X)," & -- IPAD67
+ " 24 (BC_2, *, internal, X)," & -- IPAD68
+ " 23 (BC_2, *, internal, X)," & -- PAD69.I
+ " 22 (BC_2, *, internal, X)," & -- PAD69.O
+ " 21 (BC_2, *, internal, 1)," & -- PAD69.T
+ " 20 (BC_2, *, internal, X)," & -- PAD70.I
+ " 19 (BC_2, *, internal, X)," & -- PAD70.O
+ " 18 (BC_2, *, internal, 1)," & -- PAD70.T
+ " 17 (BC_2, E13, input, X)," & -- PAD71
+ " 16 (BC_2, E13, output3, X, 15, 1, PULL1)," & -- PAD71
+ " 15 (BC_2, *, controlr, 1)," &
+ " 14 (BC_2, C14, input, X)," & -- PAD72
+ " 13 (BC_2, C14, output3, X, 12, 1, PULL1)," & -- PAD72
+ " 12 (BC_2, *, controlr, 1)," &
+ " 11 (BC_2, D14, input, X)," & -- PAD73
+ " 10 (BC_2, D14, output3, X, 9, 1, PULL1)," & -- PAD73
+ " 9 (BC_2, *, controlr, 1)," &
+ " 8 (BC_2, IPAD74, input, X)," &
+ " 7 (BC_2, IPAD75, input, X)," &
+ " 6 (BC_2, A16, input, X)," & -- PAD76
+ " 5 (BC_2, A16, output3, X, 4, 1, PULL1)," & -- PAD76
+ " 4 (BC_2, *, controlr, 1)," &
+ " 3 (BC_2, B16, input, X)," & -- PAD77
+ " 2 (BC_2, B16, output3, X, 1, 1, PULL1)," & -- PAD77
+ " 1 (BC_2, *, controlr, 1)," &
+ " 0 (BC_2, IPAD78, input, X)";
+
+
+attribute ISC_PIN_BEHAVIOR of XC3S1200E_FG320 : entity is
+ "HIGHZ" ; -- clamp behavior
+ -- no status
+
+attribute ISC_STATUS of XC3S1200E_FG320 : entity is
+ "NOT IMPLEMENTED" ;
+
+attribute ISC_BLANK_USERCODE of XC3S1200E_FG320 : entity is
+ "00000000000000000000000000000000";
+
+attribute ISC_FLOW of XC3S1200E_FG320 : entity is
+ -- Enable program
+ "flow_enable " &
+ "initialize " &
+ " (ISC_ENABLE 5:00 wait TCK 16)," &
+
+ "flow_disable " &
+ "initialize " &
+ " (ISC_DISABLE wait TCK 16)" &
+ " (BYPASS 1:0 wait TCK 1)," &
+
+ "flow_program(array) " &
+ "Repeat 239922 " &
+ " (ISC_PROGRAM 16:? wait TCK 1 )," &
+
+ "flow_program(legacy) " &
+ "Initialize " &
+ " (JSHUTDOWN wait TCK 16)" &
+ " (CFG_IN 3838752:? wait TCK 1)" &
+ " (JSTART wait TCK 32)" &
+ " (BYPASS 1:0 wait TCK 1)," &
+
+ "flow_verify(idcode) " &
+ "initialize " &
+ " (IDCODE wait TCK 1 32:01C2E093*0FFFFFFF)," &
+
+ "flow_read(usercode) " &
+ "initialize " &
+ " (USERCODE wait TCK 1 32:!)," &
+
+ "flow_read(idcode) " &
+ "initialize " &
+ " (IDCODE wait TCK 1 32:!)," &
+
+ "flow_program_done " &
+ "initialize " &
+ " (BYPASS wait TCK 1)," &
+
+ "flow_error_exit " &
+ "initialize " &
+ " (BYPASS wait TCK 1)";
+
+attribute ISC_PROCEDURE of XC3S1200E_FG320 : entity is
+ "proc_enable = (flow_enable)," &
+ "proc_disable = (flow_disable)," &
+ "proc_program = (flow_program(array))," &
+ "proc_program(legacy) = (flow_program(legacy))," &
+ "proc_verify(idcode) = (flow_verify(idcode))," &
+ "proc_read(idcode) = (flow_read(idcode))," &
+ "proc_read(usercode) = (flow_read(usercode))," &
+ "proc_program_done = (flow_program_done)," &
+ "proc_error_exit = (flow_error_exit)";
+
+attribute ISC_ACTION of XC3S1200E_FG320 : entity is
+ "program = (proc_verify(idcode) recommended," &
+ " proc_enable, proc_program," &
+ " proc_disable)," &
+ "program(lgcy) = (proc_verify(idcode) recommended," &
+ " proc_enable, proc_program(legacy)," &
+ " proc_disable)," &
+ "verify(idcode) = (proc_verify(idcode))," &
+ "read(idcode) = (proc_read(idcode))," &
+ "read(usercode) = (proc_read(usercode))";
+
+-- Design Warning Section
+
+attribute DESIGN_WARNING of XC3S1200E_FG320 : entity is
+ "This is a preliminary BSDL file which has not been verified." &
+ "This BSDL file must be modified by the FPGA designer in order to" &
+ "reflect post-configuration behavior (if any)." &
+ "To avoid losing the current configuration, the PROG_B should be" &
+ "kept high. If the PROG_B pin goes low by any means," &
+ "the configuration will be cleared." &
+ "PROG_B can only be captured, not updated." &
+ "The value at the pin is always used by the device." &
+ "PUDC_B can be captured and updated." &
+ "The value at the pin is always used by the device" &
+ "before configuration is done." &
+ "During pre-configuration, the disable result of a 3-stated" &
+ "I/O in this file corresponds to PUDC_B being low" &
+ "or during EXTEST instruction." &
+ "When PUDC_B is high AND during SAMPLE instruction, change" &
+ "all PULL1s to PULL0s." &
+ "After configuration, the disable result only depends on" &
+ "the individual IO configuration setting." &
+ "In EXTEST, output and tristate values are not captured in the" &
+ "Capture-DR state - those register cells are unchanged." &
+ "In INTEST, the pin input values are not captured in the" &
+ "Capture-DR state - those register cells are unchanged." &
+ "The output and tristate capture values are not valid until after" &
+ "the device is configured." &
+ "The tristate control value is not captured properly when" &
+ "GTS is activated.";
+
+end XC3S1200E_FG320;
+
trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/bsdl/xc3s1200e_fg320_1532.bsd
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/debug/impact_bat
===================================================================
--- trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/debug/impact_bat (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/debug/impact_bat (revision 44)
@@ -0,0 +1,6 @@
+setMode -bs
+setCable -port svf -file ../debug/bitstream.svf
+addDevice -p 1 -file Board_Design_jtag.bit
+program -p 1
+closeCable
+quit
trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/debug/impact_bat
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/debug/fpga_load
===================================================================
--- trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/debug/fpga_load (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/debug/fpga_load (revision 44)
@@ -0,0 +1,6 @@
+bsdl path ../bsdl;../target/bsdl;
+cable usbblaster
+detect
+part 1
+svf bitstream.svf
+
trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/debug/fpga_load
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/filelist
===================================================================
--- trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/filelist (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/filelist (revision 44)
@@ -0,0 +1,29 @@
+verilog work ./target/Pad_Ring.v
+
+
+verilog work ../../../../../ip/T6502/rtl/gen/syn/T6502.v
+verilog work ../../../../../children/logic/ip/disp_io/rtl/gen/syn/disp_io.v
+verilog work ../../../../../children/logic/ip/io_module/rtl/gen/syn/io_module.v
+
+
+verilog work ../../../../../children/logic/ip/vga_char_ctrl/rtl/gen/syn/vga_char_ctrl.v
+verilog work ../../../../../children/logic/ip/ps2_interface/rtl/gen/syn/ps2_interface.v
+verilog work ../../../../../children/logic/ip/uart/rtl/gen/syn/uart.v
+verilog work ../../../../../children/logic/ip/serial_rcvr/rtl/gen/syn/serial_rcvr.v
+verilog work ../../../../../children/logic/ip/flash_memcontrl/rtl/gen/syn/flash_memcontrl.v
+
+
+verilog work ./target/lib/syn/cde_pads/cde_pad_se_dig.v
+verilog work ./target/lib/syn/cde_clock_sys/cde_clock_sys.v
+verilog work ./target/lib/syn/cde_jtag/cde_jtag.v
+verilog work ./target/lib/syn/cde_jtag/cde_jtag_rpc_reg.v
+verilog work ./target/lib/syn/cde_sram/cde_sram.v
+verilog work ./target/lib/syn/cde_fifo/cde_fifo.v
+verilog work ./target/lib/syn/cde_lifo/cde_lifo.v
+verilog work ./target/lib/syn/cde_synchronizers/cde_sync_with_hysteresis.v
+verilog work ./target/lib/syn/cde_divider/cde_divider.v
+verilog work ./target/lib/syn/cde_serial_rcvr/cde_serial_rcvr.v
+verilog work ./target/lib/syn/cde_serial_xmit/cde_serial_xmit.v
+
+
+
trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/filelist
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/core.v
===================================================================
--- trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/core.v (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/core.v (revision 44)
@@ -0,0 +1,112 @@
+
+ // Declare I/O Port connections
+
+
+wire clk = ck25MHz;
+wire [15:0] add_mon;
+wire [7:0] gpio_0_out;
+wire [7:0] gpio_1_out;
+
+
+assign rs_tx_pad_out = rs_rx_pad_in;
+
+assign jtag_user1_cap = jtag_user1_upd;
+assign jtag_user2_cap = add_mon;
+
+assign PosD = {gpio_0_out,gpio_1_out};
+assign PosL = 8'h12;
+
+assign ja_1_pad_out = 1'b0;
+assign ja_2_pad_out = reset;
+assign ja_3_pad_out = 1'b0;
+assign ja_4_pad_out = 1'b0 ;
+
+assign ja_7_pad_out = 1'b0;
+assign ja_8_pad_out = 1'b0;
+assign ja_9_pad_out = 1'b0;
+assign ja_10_pad_out = 1'b0;
+
+assign jb_1_pad_out = 1'b0;
+assign jb_2_pad_out = 1'b0;
+assign jb_3_pad_out = 1'b0;
+assign jb_4_pad_out = 1'b0;
+
+assign jb_7_pad_out = 1'b0;
+assign jb_8_pad_out = 1'b0;
+assign jb_9_pad_out = 1'b0;
+assign jb_10_pad_out = 1'b0;
+
+assign jc_1_pad_out = 1'b1;
+assign jc_2_pad_out = 1'b0;
+assign jc_3_pad_out = 1'b1;
+assign jc_4_pad_out = 1'b0;
+
+assign jc_7_pad_out = 1'b1;
+assign jc_8_pad_out = 1'b0;
+assign jc_9_pad_out = 1'b1;
+assign jc_10_pad_out = 1'b0;
+
+assign add_mon[15:0] = 16'h0000 ;
+
+
+
+T6502 #(
+ .ROM_WORDS (`ROM_WORDS),
+ .ROM_ADD (`ROM_ADD),
+ .ROM_FILE (`ROM_FILE),
+ .PROG_ROM_WORDS (`PROG_ROM_WORDS),
+ .PROG_ROM_ADD (`PROG_ROM_ADD),
+ .PROG_ROM_FILE (`PROG_ROM_FILE),
+ .RAM_WORDS (4096),
+ .STARTUP (`STARTUP),
+ .FONT (`FONT)
+ )
+ cpu (
+ .clk ( ck25MHz ),
+ .reset ( reset ),
+
+ .alu_status ( ),
+
+ .ext_add ( micro_addr ),
+ .ext_wdata ( micro_wdata ),
+ .ext_rdata ( micro_rdata ),
+ .ext_ub ( micro_ub ),
+ .ext_lb ( micro_lb ),
+ .ext_rd ( micro_rd ),
+ .ext_wr ( micro_wr ),
+ .ext_cs ( micro_cs ),
+
+ .ext_irq_in ( 4'h0 ),
+
+ .gpio_0_out ( gpio_0_out ),
+ .gpio_0_in ( 8'h00 ),
+ .gpio_0_oe ( ),
+ .gpio_0_lat ( ),
+
+ .gpio_1_out ( gpio_1_out ),
+ .gpio_1_in ( 8'h00 ),
+ .gpio_1_oe ( ),
+ .gpio_1_lat ( ),
+
+ .ps2_data_oe ( ps2_data_pad_oe ),
+ .ps2_data_in ( ps2_data_pad_in ),
+ .ps2_clk_oe ( ps2_clk_pad_oe ),
+ .ps2_clk_in ( ps2_clk_pad_in ),
+
+ .txd_pad_out ( txd_pad_out ),
+ .rxd_pad_in ( rxd_pad_in ),
+ .cts_pad_in ( cts_pad_in ),
+ .rts_pad_out ( rts_pad_out ),
+
+ .vgared_pad_out ( vgared_pad_out[2:0] ),
+ .vgagreen_pad_out ( vgagreen_pad_out[2:0] ),
+ .vgablue_pad_out ( vgablue_pad_out[1:0] ),
+
+ .hsync_n_pad_out ( hsync_pad_out ),
+ .vsync_n_pad_out ( vsync_pad_out )
+
+
+);
+
+
+
\ No newline at end of file
trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/core.v
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/Makefile
===================================================================
--- trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/Makefile (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/Makefile (revision 44)
@@ -0,0 +1,4 @@
+include ../../../../bin/Makefile.root
+include ./target/Makefile.brd
+Design=X6502_irq_2_test
+
trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/Makefile
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/def_file
===================================================================
--- trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/def_file (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/def_file (revision 44)
@@ -0,0 +1,23 @@
+`define SYNTHESIS
+`define ROM_FILE "NONE"
+`define ROM_WORDS 128
+`define ROM_ADD 7
+
+`define PROG_ROM_FILE "../../../../../../../projects/Mos6502/sw/irq_2_test/irq_2_test.abs16"
+`define PROG_ROM_WORDS 2048
+`define PROG_ROM_ADD 11
+
+
+
+`define MODULE_NAME Nexys2_X6502_irq_2_test
+
+`define STARTUP "../../../../../sw/vga_startup_screen/vga_startup_screen.abs"
+`define FONT "../../../../../sw/vga_font/vga_font.abs"
+
+
+`define JTAG_USER1_WIDTH 8
+`define JTAG_USER1_RESET 8'h12
+`define JTAG_USER1_UPDR 1'b1
+`define JTAG_USER2_WIDTH 16
+`define JTAG_USER2_RESET 16'h0000
+`define JTAG_USER2_UPDR 1'b0
trunk/projects/Mos6502/ip/T6502/syn/Nexys2_irq_2_test/def_file
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/bsdl/xc3s1200e_fg320_1532.bsd
===================================================================
--- trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/bsdl/xc3s1200e_fg320_1532.bsd (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/bsdl/xc3s1200e_fg320_1532.bsd (revision 44)
@@ -0,0 +1,1591 @@
+--$ XILINX$RCSfile: xc3s1200e_fg320_1532.bsd,v $
+--$ XILINX$Revision: 1.2.124.1 $
+
+--###################################################################
+-- WARNING !!!! .. This is a 1532 PROTOTYPE BDSL file.
+--###################################################################
+--
+-- It should not be be used in place of, or along side of 1149.1 bsdl files.
+--
+-- This file conforms to the unapproved IEEE Standard 1532 BSDL draft
+-- Standard. It may not function as expected with IEEE 1149.1 BSDL
+-- and is subject to change pending the ratification of the 1532 Standard
+-- by the IEEE. When denoted as FINAL, it has been verified
+-- syntactically, and against hardware.
+--
+-- Prototype 1532 BSDL file for device XC3S1200E, package FG320
+-- Xilinx, Inc. $State: Exp $ $Date: 2008/07/07 22:23:21 $
+--
+-- Generated by BSDLnet bsdlnet Version 1.40
+------------------------------------------------------------------------
+-- Modification History
+-- | Generated on 05/28/08
+-- | CR # 471899
+-- | Details - Initial Release using BSDLnet.
+-- | Added 'attribute COMPLIANCE_PATTERNS' & changed boundary
+-- | register attribute to internal for PROG_B & PUDC_B.
+------------------------------------------------------------------------
+--
+-- createBSDL template $RCSfile: xc3s1200e_fg320_1532.bsd,v $ $Revision: 1.2.124.1 $ $Date: 2008/07/07 22:23:21 $
+--
+--###################################################################
+--
+--
+-- For technical support, contact Xilinx on the web at:
+--
+-- http://support.xilinx.com
+--
+-- Technical support can also take place via email or phone at:
+--
+-- North America 1-800-255-7778 hotline@xilinx.com
+-- United Kingdom (44) 1932 820821 ukhelp@xilinx.com
+-- France (33) 1 3463 0100 frhelp@xilinx.com
+-- Germany (49) 89 991 54930 dlhelp@xilinx.com
+-- Japan (81) 3-3297-9163 jhotline@xilinx.com
+--
+--
+-- This BSDL file reflects the pre-configuration JTAG behavior. To reflect
+-- the post-configuration JTAG behavior (if any), edit this file as described
+-- below. Many of these changes are demonstrated by commented-out template
+-- lines preceeding the lines they would replace:
+--
+-- 1. Set disable result of all pads as configured.
+-- 2. Set safe state of boundary cells as necessary.
+-- 3. Rename entity if necessary to avoid name collisions.
+-- 4. Modify USERCODE value in USERCODE_REGISTER declaration.
+--
+--###################################################################--
+
+----------------------------------
+
+-- BSDL File for 1532 Standard.
+
+----------------------------------
+
+entity XC3S1200E_FG320 is
+
+-- Generic Parameter
+
+generic (PHYSICAL_PIN_MAP : string := "FG320" );
+
+-- Logical Port Description
+
+port (
+ A10: inout bit; -- PAD40
+ A11: inout bit; -- PAD49
+ A12: inout bit; -- PAD54
+ A13: inout bit; -- PAD59
+ A14: inout bit; -- PAD62
+ A16: inout bit; -- PAD76
+ A4: inout bit; -- PAD5
+ A6: inout bit; -- PAD14
+ A7: inout bit; -- PAD20
+ A8: inout bit; -- PAD28
+ B10: inout bit; -- PAD41
+ B11: inout bit; -- PAD42
+ B13: inout bit; -- PAD58
+ B14: inout bit; -- PAD63
+ B16: inout bit; -- PAD77
+ B4: inout bit; -- PAD4
+ B6: inout bit; -- PAD15
+ C1: inout bit; -- PAD304
+ C11: inout bit; -- PAD48
+ C14: inout bit; -- PAD72
+ C17: inout bit; -- PAD80
+ C18: inout bit; -- PAD81
+ C2: inout bit; -- PAD303
+ C3: inout bit; -- PAD2
+ C4: inout bit; -- PAD6
+ C5: inout bit; -- PAD8
+ C7: inout bit; -- PAD27
+ C9: inout bit; -- PAD37
+ D1: inout bit; -- PAD302
+ D10: inout bit; -- PAD44
+ D11: inout bit; -- PAD47
+ D13: inout bit; -- PAD57
+ D14: inout bit; -- PAD73
+ D16: inout bit; -- PAD82
+ D17: inout bit; -- PAD83
+ D2: inout bit; -- PAD301
+ D4: inout bit; -- PAD298
+ D5: inout bit; -- PAD7
+ D6: inout bit; -- PAD12
+ D7: inout bit; -- PAD26
+ D9: inout bit; -- PAD36
+ DONE: inout bit;
+ E1: inout bit; -- PAD296
+ E10: inout bit; -- PAD43
+ E11: inout bit; -- PAD51
+ E12: inout bit; -- PAD55
+ E13: inout bit; -- PAD71
+ E15: inout bit; -- PAD85
+ E16: inout bit; -- PAD84
+ E2: inout bit; -- PAD297
+ E3: inout bit; -- PAD291
+ E4: inout bit; -- PAD292
+ E6: inout bit; -- PAD11
+ E7: inout bit; -- PAD21
+ E8: inout bit; -- PAD30
+ E9: inout bit; -- PAD34
+ F1: inout bit; -- PAD287
+ F11: inout bit; -- PAD50
+ F12: inout bit; -- PAD56
+ F14: inout bit; -- PAD92
+ F15: inout bit; -- PAD93
+ F17: inout bit; -- PAD99
+ F18: inout bit; -- PAD100
+ F2: inout bit; -- PAD286
+ F7: inout bit; -- PAD22
+ F8: inout bit; -- PAD29
+ F9: inout bit; -- PAD33
+ G13: inout bit; -- PAD97
+ G14: inout bit; -- PAD98
+ G15: inout bit; -- PAD103
+ G16: inout bit; -- PAD102
+ G3: inout bit; -- PAD285
+ G4: inout bit; -- PAD284
+ G5: inout bit; -- PAD281
+ G6: inout bit; -- PAD282
+ G9: inout bit; -- PAD35
+ GND: linkage bit_vector (1 to 28);
+ H1: inout bit; -- PAD274
+ H14: inout bit; -- PAD105
+ H15: inout bit; -- PAD104
+ H16: inout bit; -- PAD108
+ H17: inout bit; -- PAD107
+ H2: inout bit; -- PAD275
+ H3: inout bit; -- PAD276
+ H4: inout bit; -- PAD277
+ H5: inout bit; -- PAD279
+ H6: inout bit; -- PAD280
+ IPAD10: in bit;
+ IPAD101: in bit;
+ IPAD106: in bit;
+ IPAD111: in bit;
+ IPAD116: in bit;
+ IPAD121: in bit;
+ IPAD126: in bit;
+ IPAD131: in bit;
+ IPAD136: in bit;
+ IPAD141: in bit;
+ IPAD148: in bit;
+ IPAD155: in bit;
+ IPAD161: in bit;
+ IPAD162: in bit;
+ IPAD183: in bit;
+ IPAD184: in bit;
+ IPAD190: in bit;
+ IPAD191: in bit;
+ IPAD197: in bit;
+ IPAD198: in bit;
+ IPAD204: in bit;
+ IPAD205: in bit;
+ IPAD226: in bit;
+ IPAD227: in bit;
+ IPAD230: in bit;
+ IPAD231: in bit;
+ IPAD238: in bit;
+ IPAD243: in bit;
+ IPAD248: in bit;
+ IPAD253: in bit;
+ IPAD258: in bit;
+ IPAD263: in bit;
+ IPAD268: in bit;
+ IPAD273: in bit;
+ IPAD278: in bit;
+ IPAD283: in bit;
+ IPAD288: in bit;
+ IPAD293: in bit;
+ IPAD3: in bit;
+ IPAD300: in bit;
+ IPAD31: in bit;
+ IPAD32: in bit;
+ IPAD38: in bit;
+ IPAD39: in bit;
+ IPAD45: in bit;
+ IPAD46: in bit;
+ IPAD52: in bit;
+ IPAD53: in bit;
+ IPAD74: in bit;
+ IPAD75: in bit;
+ IPAD78: in bit;
+ IPAD79: in bit;
+ IPAD86: in bit;
+ IPAD9: in bit;
+ IPAD91: in bit;
+ IPAD96: in bit;
+ J1: inout bit; -- PAD270
+ J12: inout bit; -- PAD110
+ J13: inout bit; -- PAD109
+ J14: inout bit; -- PAD112
+ J15: inout bit; -- PAD113
+ J16: inout bit; -- PAD114
+ J17: inout bit; -- PAD115
+ J2: inout bit; -- PAD269
+ J4: inout bit; -- PAD271
+ J5: inout bit; -- PAD272
+ K12: inout bit; -- PAD119
+ K13: inout bit; -- PAD120
+ K14: inout bit; -- PAD117
+ K15: inout bit; -- PAD118
+ K3: inout bit; -- PAD267
+ K4: inout bit; -- PAD266
+ K5: inout bit; -- PAD264
+ K6: inout bit; -- PAD265
+ L1: inout bit; -- PAD262
+ L15: inout bit; -- PAD124
+ L16: inout bit; -- PAD125
+ L17: inout bit; -- PAD122
+ L18: inout bit; -- PAD123
+ L2: inout bit; -- PAD261
+ L3: inout bit; -- PAD260
+ L4: inout bit; -- PAD259
+ L5: inout bit; -- PAD256
+ L6: inout bit; -- PAD257
+ M10: inout bit; -- PAD186
+ M13: inout bit; -- PAD134
+ M14: inout bit; -- PAD135
+ M15: inout bit; -- PAD130
+ M16: inout bit; -- PAD129
+ M18: inout bit; -- PAD127
+ M3: inout bit; -- PAD254
+ M4: inout bit; -- PAD255
+ M5: inout bit; -- PAD252
+ M6: inout bit; -- PAD251
+ M9: inout bit; -- PAD195
+ N10: inout bit; -- PAD185
+ N11: inout bit; -- PAD181
+ N12: inout bit; -- PAD171
+ N14: inout bit; -- PAD139
+ N15: inout bit; -- PAD140
+ N18: inout bit; -- PAD128
+ N4: inout bit; -- PAD250
+ N5: inout bit; -- PAD249
+ N7: inout bit; -- PAD208
+ N8: inout bit; -- PAD202
+ N9: inout bit; -- PAD196
+ P1: inout bit; -- PAD244
+ P10: inout bit; -- PAD188
+ P11: inout bit; -- PAD182
+ P12: inout bit; -- PAD170
+ P13: inout bit; -- PAD167
+ P16: inout bit; -- PAD142
+ P17: inout bit; -- PAD133
+ P18: inout bit; -- PAD132
+ P2: inout bit; -- PAD245
+ P3: inout bit; -- PAD242
+ P4: inout bit; -- PAD241
+ P6: inout bit; -- PAD214
+ P7: inout bit; -- PAD207
+ P8: inout bit; -- PAD203
+ P9: inout bit; -- PAD201
+ PROG_B: in bit;
+ PUDC_B: in bit; -- PAD1
+ R10: inout bit; -- PAD189
+ R11: inout bit; -- PAD180
+ R12: inout bit; -- PAD173
+ R13: inout bit; -- PAD166
+ R14: inout bit; -- PAD159
+ R15: inout bit; -- PAD147
+ R16: inout bit; -- PAD146
+ R18: inout bit; -- PAD150
+ R2: inout bit; -- PAD234
+ R3: inout bit; -- PAD235
+ R5: inout bit; -- PAD222
+ R6: inout bit; -- PAD215
+ R8: inout bit; -- PAD200
+ R9: inout bit; -- PAD194
+ T1: inout bit; -- PAD232
+ T12: inout bit; -- PAD174
+ T14: inout bit; -- PAD160
+ T15: inout bit; -- PAD158
+ T16: inout bit; -- PAD154
+ T17: inout bit; -- PAD151
+ T18: inout bit; -- PAD149
+ T2: inout bit; -- PAD233
+ T3: inout bit; -- PAD228
+ T4: inout bit; -- PAD224
+ T5: inout bit; -- PAD221
+ T8: inout bit; -- PAD199
+ TCK: in bit;
+ TDI: in bit;
+ TDO: out bit;
+ TMS: in bit;
+ U13: inout bit; -- PAD172
+ U15: inout bit; -- PAD156
+ U16: inout bit; -- PAD153
+ U18: inout bit; -- PAD152
+ U3: inout bit; -- PAD229
+ U4: inout bit; -- PAD225
+ U5: inout bit; -- PAD223
+ U6: inout bit; -- PAD209
+ U9: inout bit; -- PAD193
+ V11: inout bit; -- PAD187
+ V12: inout bit; -- PAD179
+ V13: inout bit; -- PAD178
+ V15: inout bit; -- PAD157
+ V5: inout bit; -- PAD211
+ V6: inout bit; -- PAD210
+ V7: inout bit; -- PAD206
+ V9: inout bit; -- PAD192
+ VCCAUX: linkage bit_vector (1 to 8);
+ VCCINT: linkage bit_vector (1 to 8);
+ VCCO_0: linkage bit_vector (1 to 5);
+ VCCO_1: linkage bit_vector (1 to 5);
+ VCCO_2: linkage bit_vector (1 to 5);
+ VCCO_3: linkage bit_vector (1 to 5)
+); --end port list
+
+-- Use Statements
+
+use STD_1149_1_2001.all;
+use STD_1532_2002.all;
+
+-- Component Conformance Statement(s)
+
+attribute COMPONENT_CONFORMANCE of XC3S1200E_FG320 : entity is
+ "STD_1149_1_2001";
+
+-- Device Package Pin Mappings
+
+attribute PIN_MAP of XC3S1200E_FG320 : entity is PHYSICAL_PIN_MAP;
+
+constant FG320: PIN_MAP_STRING:=
+ "A10:A10," &
+ "A11:A11," &
+ "A12:A12," &
+ "A13:A13," &
+ "A14:A14," &
+ "A16:A16," &
+ "A4:A4," &
+ "A6:A6," &
+ "A7:A7," &
+ "A8:A8," &
+ "B10:B10," &
+ "B11:B11," &
+ "B13:B13," &
+ "B14:B14," &
+ "B16:B16," &
+ "B4:B4," &
+ "B6:B6," &
+ "C1:C1," &
+ "C11:C11," &
+ "C14:C14," &
+ "C17:C17," &
+ "C18:C18," &
+ "C2:C2," &
+ "C3:C3," &
+ "C4:C4," &
+ "C5:C5," &
+ "C7:C7," &
+ "C9:C9," &
+ "D1:D1," &
+ "D10:D10," &
+ "D11:D11," &
+ "D13:D13," &
+ "D14:D14," &
+ "D16:D16," &
+ "D17:D17," &
+ "D2:D2," &
+ "D4:D4," &
+ "D5:D5," &
+ "D6:D6," &
+ "D7:D7," &
+ "D9:D9," &
+ "DONE:V17," &
+ "E1:E1," &
+ "E10:E10," &
+ "E11:E11," &
+ "E12:E12," &
+ "E13:E13," &
+ "E15:E15," &
+ "E16:E16," &
+ "E2:E2," &
+ "E3:E3," &
+ "E4:E4," &
+ "E6:E6," &
+ "E7:E7," &
+ "E8:E8," &
+ "E9:E9," &
+ "F1:F1," &
+ "F11:F11," &
+ "F12:F12," &
+ "F14:F14," &
+ "F15:F15," &
+ "F17:F17," &
+ "F18:F18," &
+ "F2:F2," &
+ "F7:F7," &
+ "F8:F8," &
+ "F9:F9," &
+ "G13:G13," &
+ "G14:G14," &
+ "G15:G15," &
+ "G16:G16," &
+ "G3:G3," &
+ "G4:G4," &
+ "G5:G5," &
+ "G6:G6," &
+ "G9:G9," &
+ "GND:(A1,A18,B2,B17,C10,G7,G12,H8,H9,H10," &
+ "H11,J3,J8,J11,K8,K11,K16,L8,L9,L10," &
+ "L11,M7,M12,T9,U2,U17,V1,V18)," &
+ "H1:H1," &
+ "H14:H14," &
+ "H15:H15," &
+ "H16:H16," &
+ "H17:H17," &
+ "H2:H2," &
+ "H3:H3," &
+ "H4:H4," &
+ "H5:H5," &
+ "H6:H6," &
+ "IPAD10:A5," &
+ "IPAD101:H13," &
+ "IPAD106:G18," &
+ "IPAD111:H18," &
+ "IPAD116:K18," &
+ "IPAD121:K17," &
+ "IPAD126:L13," &
+ "IPAD131:L14," &
+ "IPAD136:N17," &
+ "IPAD141:P15," &
+ "IPAD148:R17," &
+ "IPAD155:V16," &
+ "IPAD161:U14," &
+ "IPAD162:V14," &
+ "IPAD183:U11," &
+ "IPAD184:T11," &
+ "IPAD190:T10," &
+ "IPAD191:U10," &
+ "IPAD197:V8," &
+ "IPAD198:U8," &
+ "IPAD204:R7," &
+ "IPAD205:T7," &
+ "IPAD226:V3," &
+ "IPAD227:V4," &
+ "IPAD230:V2," &
+ "IPAD231:U1," &
+ "IPAD238:R1," &
+ "IPAD243:R4," &
+ "IPAD248:N2," &
+ "IPAD253:N1," &
+ "IPAD258:M1," &
+ "IPAD263:K7," &
+ "IPAD268:K2," &
+ "IPAD273:J6," &
+ "IPAD278:J7," &
+ "IPAD283:G1," &
+ "IPAD288:F5," &
+ "IPAD293:F4," &
+ "IPAD3:A3," &
+ "IPAD300:D3," &
+ "IPAD31:D8," &
+ "IPAD32:C8," &
+ "IPAD38:B9," &
+ "IPAD39:B8," &
+ "IPAD45:G10," &
+ "IPAD46:F10," &
+ "IPAD52:D12," &
+ "IPAD53:C12," &
+ "IPAD74:A15," &
+ "IPAD75:B15," &
+ "IPAD78:C15," &
+ "IPAD79:B18," &
+ "IPAD86:D18," &
+ "IPAD9:B5," &
+ "IPAD91:E17," &
+ "IPAD96:E18," &
+ "J1:J1," &
+ "J12:J12," &
+ "J13:J13," &
+ "J14:J14," &
+ "J15:J15," &
+ "J16:J16," &
+ "J17:J17," &
+ "J2:J2," &
+ "J4:J4," &
+ "J5:J5," &
+ "K12:K12," &
+ "K13:K13," &
+ "K14:K14," &
+ "K15:K15," &
+ "K3:K3," &
+ "K4:K4," &
+ "K5:K5," &
+ "K6:K6," &
+ "L1:L1," &
+ "L15:L15," &
+ "L16:L16," &
+ "L17:L17," &
+ "L18:L18," &
+ "L2:L2," &
+ "L3:L3," &
+ "L4:L4," &
+ "L5:L5," &
+ "L6:L6," &
+ "M10:M10," &
+ "M13:M13," &
+ "M14:M14," &
+ "M15:M15," &
+ "M16:M16," &
+ "M18:M18," &
+ "M3:M3," &
+ "M4:M4," &
+ "M5:M5," &
+ "M6:M6," &
+ "M9:M9," &
+ "N10:N10," &
+ "N11:N11," &
+ "N12:N12," &
+ "N14:N14," &
+ "N15:N15," &
+ "N18:N18," &
+ "N4:N4," &
+ "N5:N5," &
+ "N7:N7," &
+ "N8:N8," &
+ "N9:N9," &
+ "P1:P1," &
+ "P10:P10," &
+ "P11:P11," &
+ "P12:P12," &
+ "P13:P13," &
+ "P16:P16," &
+ "P17:P17," &
+ "P18:P18," &
+ "P2:P2," &
+ "P3:P3," &
+ "P4:P4," &
+ "P6:P6," &
+ "P7:P7," &
+ "P8:P8," &
+ "P9:P9," &
+ "PROG_B:B1," &
+ "PUDC_B:B3," &
+ "R10:R10," &
+ "R11:R11," &
+ "R12:R12," &
+ "R13:R13," &
+ "R14:R14," &
+ "R15:R15," &
+ "R16:R16," &
+ "R18:R18," &
+ "R2:R2," &
+ "R3:R3," &
+ "R5:R5," &
+ "R6:R6," &
+ "R8:R8," &
+ "R9:R9," &
+ "T1:T1," &
+ "T12:T12," &
+ "T14:T14," &
+ "T15:T15," &
+ "T16:T16," &
+ "T17:T17," &
+ "T18:T18," &
+ "T2:T2," &
+ "T3:T3," &
+ "T4:T4," &
+ "T5:T5," &
+ "T8:T8," &
+ "TCK:A17," &
+ "TDI:A2," &
+ "TDO:C16," &
+ "TMS:D15," &
+ "U13:U13," &
+ "U15:U15," &
+ "U16:U16," &
+ "U18:U18," &
+ "U3:U3," &
+ "U4:U4," &
+ "U5:U5," &
+ "U6:U6," &
+ "U9:U9," &
+ "V11:V11," &
+ "V12:V12," &
+ "V13:V13," &
+ "V15:V15," &
+ "V5:V5," &
+ "V6:V6," &
+ "V7:V7," &
+ "V9:V9," &
+ "VCCAUX:(B7,B12,G2,G17,M2,M17,U7,U12)," &
+ "VCCINT:(E5,E14,F6,F13,N6,N13,P5,P14)," &
+ "VCCO_0:(A9,C6,C13,G8,G11)," &
+ "VCCO_1:(F16,H12,J18,L12,N16)," &
+ "VCCO_2:(M8,M11,T6,T13,V10)," &
+ "VCCO_3:(F3,H7,K1,L7,N3)";
+
+
+-- Scan Port Identification
+
+attribute TAP_SCAN_OUT of TDO : signal is true;
+attribute TAP_SCAN_IN of TDI : signal is true;
+attribute TAP_SCAN_CLOCK of TCK : signal is (10.0e6, both);
+attribute TAP_SCAN_MODE of TMS : signal is true;
+
+-- Compliance-Enable Description
+
+attribute COMPLIANCE_PATTERNS of XC3S1200E_FG320 : entity is
+ "(PROG_B, PUDC_B) (10)";
+
+-- Instruction Register Description
+
+attribute INSTRUCTION_LENGTH of XC3S1200E_FG320 : entity is 6;
+
+attribute INSTRUCTION_OPCODE of XC3S1200E_FG320 : entity is
+
+ "EXTEST (001111)," &
+ "SAMPLE (000001)," &
+ "PRELOAD (000001)," & -- Same as SAMPLE
+ "USER1 (000010)," & -- Not available until after configuration
+ "USER2 (000011)," & -- Not available until after configuration
+ "CFG_OUT (000100)," & -- Not available during configuration with another mode.
+ "CFG_IN (000101)," & -- Not available during configuration with another mode.
+ "INTEST (000111)," &
+ "USERCODE (001000)," &
+ "IDCODE (001001)," &
+ "HIGHZ (001010)," &
+ "JPROGRAM (001011)," & -- Not available during configuration with another mode.
+ "JSTART (001100)," & -- Not available during configuration with another mode.
+ "JSHUTDOWN (001101)," & -- Not available during configuration with another mode.
+ "BYPASS (111111)," &
+ "ISC_ENABLE (010000)," &
+ "ISC_PROGRAM (010001)," &
+ "ISC_NOOP (010100)," &
+ "ISC_READ (010101)," &
+ "ISC_DISABLE (010110)";
+
+attribute INSTRUCTION_CAPTURE of XC3S1200E_FG320 : entity is
+-- Bit 5 is 1 when DONE is released (part of startup sequence)
+-- Bit 4 is 1 if house-cleaning is complete
+-- Bit 3 is ISC_Enabled
+-- Bit 2 is ISC_Done
+ "XXXX01" ;
+
+attribute INSTRUCTION_PRIVATE of XC3S1200E_FG320 : entity is
+ "USER1," &
+ "USER2," &
+ "CFG_OUT," &
+ "CFG_IN," &
+ "JPROGRAM," &
+ "JSTART," &
+ "JSHUTDOWN," &
+ "ISC_ENABLE," &
+ "ISC_PROGRAM," &
+ "ISC_NOOP," &
+ "ISC_READ," &
+ "ISC_DISABLE";
+
+-- Optional Register Description
+
+attribute IDCODE_REGISTER of XC3S1200E_FG320 : entity is "XXXX" & -- version
+ "0001110" & -- family
+ "000101110" & -- array size
+ "00001001001" & -- manufacturer
+ "1"; -- required by 1149.1
+
+
+attribute USERCODE_REGISTER of XC3S1200E_FG320 : entity is "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX";
+
+-- Register Access Description
+
+attribute REGISTER_ACCESS of XC3S1200E_FG320 : entity is
+ "TEST1[8] (USER1)," &
+ "TEST2[16] (USER2)," &
+ "DEVICE_ID (USERCODE,IDCODE)," &
+ "BYPASS (BYPASS,HIGHZ,JPROGRAM,JSTART,JSHUTDOWN)," &
+ "CFG_DATA[3838752] (CFG_IN)," &
+ "ISC_PDATA[16] (ISC_PROGRAM),"&
+ "ISC_RDATA[16] (ISC_READ),"&
+ "ISC_DEFAULT[5] (ISC_NOOP)," &
+ "ISC_CONFIG[5] (ISC_ENABLE,ISC_DISABLE)," &
+ "BOUNDARY (EXTEST, SAMPLE, PRELOAD, INTEST)";
+
+-- Boundary-Scan Register Description
+
+attribute BOUNDARY_LENGTH of XC3S1200E_FG320 : entity is 772;
+
+attribute BOUNDARY_REGISTER of XC3S1200E_FG320 : entity is
+-- cellnum (type, port, function, safe[, ccell, disval, disrslt])
+ " 771 (BC_2, IPAD79, input, X)," &
+ " 770 (BC_2, C17, input, X)," & -- PAD80
+ " 769 (BC_2, C17, output3, X, 768, 1, PULL1)," & -- PAD80
+ " 768 (BC_2, *, controlr, 1)," &
+ " 767 (BC_2, C18, input, X)," & -- PAD81
+ " 766 (BC_2, C18, output3, X, 765, 1, PULL1)," & -- PAD81
+ " 765 (BC_2, *, controlr, 1)," &
+ " 764 (BC_2, D16, input, X)," & -- PAD82
+ " 763 (BC_2, D16, output3, X, 762, 1, PULL1)," & -- PAD82
+ " 762 (BC_2, *, controlr, 1)," &
+ " 761 (BC_2, D17, input, X)," & -- PAD83
+ " 760 (BC_2, D17, output3, X, 759, 1, PULL1)," & -- PAD83
+ " 759 (BC_2, *, controlr, 1)," &
+ " 758 (BC_2, E16, input, X)," & -- PAD84
+ " 757 (BC_2, E16, output3, X, 756, 1, PULL1)," & -- PAD84
+ " 756 (BC_2, *, controlr, 1)," &
+ " 755 (BC_2, E15, input, X)," & -- PAD85
+ " 754 (BC_2, E15, output3, X, 753, 1, PULL1)," & -- PAD85
+ " 753 (BC_2, *, controlr, 1)," &
+ " 752 (BC_2, IPAD86, input, X)," &
+ " 751 (BC_2, *, internal, X)," & -- PAD87.I
+ " 750 (BC_2, *, internal, X)," & -- PAD87.O
+ " 749 (BC_2, *, internal, 1)," & -- PAD87.T
+ " 748 (BC_2, *, internal, X)," & -- PAD88.I
+ " 747 (BC_2, *, internal, X)," & -- PAD88.O
+ " 746 (BC_2, *, internal, 1)," & -- PAD88.T
+ " 745 (BC_2, *, internal, X)," & -- PAD89.I
+ " 744 (BC_2, *, internal, X)," & -- PAD89.O
+ " 743 (BC_2, *, internal, 1)," & -- PAD89.T
+ " 742 (BC_2, *, internal, X)," & -- PAD90.I
+ " 741 (BC_2, *, internal, X)," & -- PAD90.O
+ " 740 (BC_2, *, internal, 1)," & -- PAD90.T
+ " 739 (BC_2, IPAD91, input, X)," &
+ " 738 (BC_2, F14, input, X)," & -- PAD92
+ " 737 (BC_2, F14, output3, X, 736, 1, PULL1)," & -- PAD92
+ " 736 (BC_2, *, controlr, 1)," &
+ " 735 (BC_2, F15, input, X)," & -- PAD93
+ " 734 (BC_2, F15, output3, X, 733, 1, PULL1)," & -- PAD93
+ " 733 (BC_2, *, controlr, 1)," &
+ " 732 (BC_2, *, internal, X)," & -- PAD94.I
+ " 731 (BC_2, *, internal, X)," & -- PAD94.O
+ " 730 (BC_2, *, internal, 1)," & -- PAD94.T
+ " 729 (BC_2, *, internal, X)," & -- PAD95.I
+ " 728 (BC_2, *, internal, X)," & -- PAD95.O
+ " 727 (BC_2, *, internal, 1)," & -- PAD95.T
+ " 726 (BC_2, IPAD96, input, X)," &
+ " 725 (BC_2, G13, input, X)," & -- PAD97
+ " 724 (BC_2, G13, output3, X, 723, 1, PULL1)," & -- PAD97
+ " 723 (BC_2, *, controlr, 1)," &
+ " 722 (BC_2, G14, input, X)," & -- PAD98
+ " 721 (BC_2, G14, output3, X, 720, 1, PULL1)," & -- PAD98
+ " 720 (BC_2, *, controlr, 1)," &
+ " 719 (BC_2, F17, input, X)," & -- PAD99
+ " 718 (BC_2, F17, output3, X, 717, 1, PULL1)," & -- PAD99
+ " 717 (BC_2, *, controlr, 1)," &
+ " 716 (BC_2, F18, input, X)," & -- PAD100
+ " 715 (BC_2, F18, output3, X, 714, 1, PULL1)," & -- PAD100
+ " 714 (BC_2, *, controlr, 1)," &
+ " 713 (BC_2, IPAD101, input, X)," &
+ " 712 (BC_2, G16, input, X)," & -- PAD102
+ " 711 (BC_2, G16, output3, X, 710, 1, PULL1)," & -- PAD102
+ " 710 (BC_2, *, controlr, 1)," &
+ " 709 (BC_2, G15, input, X)," & -- PAD103
+ " 708 (BC_2, G15, output3, X, 707, 1, PULL1)," & -- PAD103
+ " 707 (BC_2, *, controlr, 1)," &
+ " 706 (BC_2, H15, input, X)," & -- PAD104
+ " 705 (BC_2, H15, output3, X, 704, 1, PULL1)," & -- PAD104
+ " 704 (BC_2, *, controlr, 1)," &
+ " 703 (BC_2, H14, input, X)," & -- PAD105
+ " 702 (BC_2, H14, output3, X, 701, 1, PULL1)," & -- PAD105
+ " 701 (BC_2, *, controlr, 1)," &
+ " 700 (BC_2, IPAD106, input, X)," &
+ " 699 (BC_2, H17, input, X)," & -- PAD107
+ " 698 (BC_2, H17, output3, X, 697, 1, PULL1)," & -- PAD107
+ " 697 (BC_2, *, controlr, 1)," &
+ " 696 (BC_2, H16, input, X)," & -- PAD108
+ " 695 (BC_2, H16, output3, X, 694, 1, PULL1)," & -- PAD108
+ " 694 (BC_2, *, controlr, 1)," &
+ " 693 (BC_2, J13, input, X)," & -- PAD109
+ " 692 (BC_2, J13, output3, X, 691, 1, PULL1)," & -- PAD109
+ " 691 (BC_2, *, controlr, 1)," &
+ " 690 (BC_2, J12, input, X)," & -- PAD110
+ " 689 (BC_2, J12, output3, X, 688, 1, PULL1)," & -- PAD110
+ " 688 (BC_2, *, controlr, 1)," &
+ " 687 (BC_2, IPAD111, input, X)," &
+ " 686 (BC_2, J14, input, X)," & -- PAD112
+ " 685 (BC_2, J14, output3, X, 684, 1, PULL1)," & -- PAD112
+ " 684 (BC_2, *, controlr, 1)," &
+ " 683 (BC_2, J15, input, X)," & -- PAD113
+ " 682 (BC_2, J15, output3, X, 681, 1, PULL1)," & -- PAD113
+ " 681 (BC_2, *, controlr, 1)," &
+ " 680 (BC_2, J16, input, X)," & -- PAD114
+ " 679 (BC_2, J16, output3, X, 678, 1, PULL1)," & -- PAD114
+ " 678 (BC_2, *, controlr, 1)," &
+ " 677 (BC_2, J17, input, X)," & -- PAD115
+ " 676 (BC_2, J17, output3, X, 675, 1, PULL1)," & -- PAD115
+ " 675 (BC_2, *, controlr, 1)," &
+ " 674 (BC_2, IPAD116, input, X)," &
+ " 673 (BC_2, K14, input, X)," & -- PAD117
+ " 672 (BC_2, K14, output3, X, 671, 1, PULL1)," & -- PAD117
+ " 671 (BC_2, *, controlr, 1)," &
+ " 670 (BC_2, K15, input, X)," & -- PAD118
+ " 669 (BC_2, K15, output3, X, 668, 1, PULL1)," & -- PAD118
+ " 668 (BC_2, *, controlr, 1)," &
+ " 667 (BC_2, K12, input, X)," & -- PAD119
+ " 666 (BC_2, K12, output3, X, 665, 1, PULL1)," & -- PAD119
+ " 665 (BC_2, *, controlr, 1)," &
+ " 664 (BC_2, K13, input, X)," & -- PAD120
+ " 663 (BC_2, K13, output3, X, 662, 1, PULL1)," & -- PAD120
+ " 662 (BC_2, *, controlr, 1)," &
+ " 661 (BC_2, IPAD121, input, X)," &
+ " 660 (BC_2, L17, input, X)," & -- PAD122
+ " 659 (BC_2, L17, output3, X, 658, 1, PULL1)," & -- PAD122
+ " 658 (BC_2, *, controlr, 1)," &
+ " 657 (BC_2, L18, input, X)," & -- PAD123
+ " 656 (BC_2, L18, output3, X, 655, 1, PULL1)," & -- PAD123
+ " 655 (BC_2, *, controlr, 1)," &
+ " 654 (BC_2, L15, input, X)," & -- PAD124
+ " 653 (BC_2, L15, output3, X, 652, 1, PULL1)," & -- PAD124
+ " 652 (BC_2, *, controlr, 1)," &
+ " 651 (BC_2, L16, input, X)," & -- PAD125
+ " 650 (BC_2, L16, output3, X, 649, 1, PULL1)," & -- PAD125
+ " 649 (BC_2, *, controlr, 1)," &
+ " 648 (BC_2, IPAD126, input, X)," &
+ " 647 (BC_2, M18, input, X)," & -- PAD127
+ " 646 (BC_2, M18, output3, X, 645, 1, PULL1)," & -- PAD127
+ " 645 (BC_2, *, controlr, 1)," &
+ " 644 (BC_2, N18, input, X)," & -- PAD128
+ " 643 (BC_2, N18, output3, X, 642, 1, PULL1)," & -- PAD128
+ " 642 (BC_2, *, controlr, 1)," &
+ " 641 (BC_2, M16, input, X)," & -- PAD129
+ " 640 (BC_2, M16, output3, X, 639, 1, PULL1)," & -- PAD129
+ " 639 (BC_2, *, controlr, 1)," &
+ " 638 (BC_2, M15, input, X)," & -- PAD130
+ " 637 (BC_2, M15, output3, X, 636, 1, PULL1)," & -- PAD130
+ " 636 (BC_2, *, controlr, 1)," &
+ " 635 (BC_2, IPAD131, input, X)," &
+ " 634 (BC_2, P18, input, X)," & -- PAD132
+ " 633 (BC_2, P18, output3, X, 632, 1, PULL1)," & -- PAD132
+ " 632 (BC_2, *, controlr, 1)," &
+ " 631 (BC_2, P17, input, X)," & -- PAD133
+ " 630 (BC_2, P17, output3, X, 629, 1, PULL1)," & -- PAD133
+ " 629 (BC_2, *, controlr, 1)," &
+ " 628 (BC_2, M13, input, X)," & -- PAD134
+ " 627 (BC_2, M13, output3, X, 626, 1, PULL1)," & -- PAD134
+ " 626 (BC_2, *, controlr, 1)," &
+ " 625 (BC_2, M14, input, X)," & -- PAD135
+ " 624 (BC_2, M14, output3, X, 623, 1, PULL1)," & -- PAD135
+ " 623 (BC_2, *, controlr, 1)," &
+ " 622 (BC_2, IPAD136, input, X)," &
+ " 621 (BC_2, *, internal, X)," & -- PAD137.I
+ " 620 (BC_2, *, internal, X)," & -- PAD137.O
+ " 619 (BC_2, *, internal, 1)," & -- PAD137.T
+ " 618 (BC_2, *, internal, X)," & -- PAD138.I
+ " 617 (BC_2, *, internal, X)," & -- PAD138.O
+ " 616 (BC_2, *, internal, 1)," & -- PAD138.T
+ " 615 (BC_2, N14, input, X)," & -- PAD139
+ " 614 (BC_2, N14, output3, X, 613, 1, PULL1)," & -- PAD139
+ " 613 (BC_2, *, controlr, 1)," &
+ " 612 (BC_2, N15, input, X)," & -- PAD140
+ " 611 (BC_2, N15, output3, X, 610, 1, PULL1)," & -- PAD140
+ " 610 (BC_2, *, controlr, 1)," &
+ " 609 (BC_2, IPAD141, input, X)," &
+ " 608 (BC_2, P16, input, X)," & -- PAD142
+ " 607 (BC_2, P16, output3, X, 606, 1, PULL1)," & -- PAD142
+ " 606 (BC_2, *, controlr, 1)," &
+ " 605 (BC_2, *, internal, X)," & -- PAD143.I
+ " 604 (BC_2, *, internal, X)," & -- PAD143.O
+ " 603 (BC_2, *, internal, 1)," & -- PAD143.T
+ " 602 (BC_2, *, internal, X)," & -- PAD144.I
+ " 601 (BC_2, *, internal, X)," & -- PAD144.O
+ " 600 (BC_2, *, internal, 1)," & -- PAD144.T
+ " 599 (BC_2, *, internal, X)," & -- PAD145.I
+ " 598 (BC_2, *, internal, X)," & -- PAD145.O
+ " 597 (BC_2, *, internal, 1)," & -- PAD145.T
+ " 596 (BC_2, R16, input, X)," & -- PAD146
+ " 595 (BC_2, R16, output3, X, 594, 1, PULL1)," & -- PAD146
+ " 594 (BC_2, *, controlr, 1)," &
+ " 593 (BC_2, R15, input, X)," & -- PAD147
+ " 592 (BC_2, R15, output3, X, 591, 1, PULL1)," & -- PAD147
+ " 591 (BC_2, *, controlr, 1)," &
+ " 590 (BC_2, IPAD148, input, X)," &
+ " 589 (BC_2, T18, input, X)," & -- PAD149
+ " 588 (BC_2, T18, output3, X, 587, 1, PULL1)," & -- PAD149
+ " 587 (BC_2, *, controlr, 1)," &
+ " 586 (BC_2, R18, input, X)," & -- PAD150
+ " 585 (BC_2, R18, output3, X, 584, 1, PULL1)," & -- PAD150
+ " 584 (BC_2, *, controlr, 1)," &
+ " 583 (BC_2, T17, input, X)," & -- PAD151
+ " 582 (BC_2, T17, output3, X, 581, 1, PULL1)," & -- PAD151
+ " 581 (BC_2, *, controlr, 1)," &
+ " 580 (BC_2, U18, input, X)," & -- PAD152
+ " 579 (BC_2, U18, output3, X, 578, 1, PULL1)," & -- PAD152
+ " 578 (BC_2, *, controlr, 1)," &
+ " 577 (BC_2, DONE, input, X)," &
+ " 576 (BC_2, DONE, output3, X, 575, 1, PULL1)," &
+ " 575 (BC_2, *, controlr, 1)," &
+ " 574 (BC_2, U16, input, X)," & -- PAD153
+ " 573 (BC_2, U16, output3, X, 572, 1, PULL1)," & -- PAD153
+ " 572 (BC_2, *, controlr, 1)," &
+ " 571 (BC_2, T16, input, X)," & -- PAD154
+ " 570 (BC_2, T16, output3, X, 569, 1, PULL1)," & -- PAD154
+ " 569 (BC_2, *, controlr, 1)," &
+ " 568 (BC_2, IPAD155, input, X)," &
+ " 567 (BC_2, U15, input, X)," & -- PAD156
+ " 566 (BC_2, U15, output3, X, 565, 1, PULL1)," & -- PAD156
+ " 565 (BC_2, *, controlr, 1)," &
+ " 564 (BC_2, V15, input, X)," & -- PAD157
+ " 563 (BC_2, V15, output3, X, 562, 1, PULL1)," & -- PAD157
+ " 562 (BC_2, *, controlr, 1)," &
+ " 561 (BC_2, T15, input, X)," & -- PAD158
+ " 560 (BC_2, T15, output3, X, 559, 1, PULL1)," & -- PAD158
+ " 559 (BC_2, *, controlr, 1)," &
+ " 558 (BC_2, R14, input, X)," & -- PAD159
+ " 557 (BC_2, R14, output3, X, 556, 1, PULL1)," & -- PAD159
+ " 556 (BC_2, *, controlr, 1)," &
+ " 555 (BC_2, T14, input, X)," & -- PAD160
+ " 554 (BC_2, T14, output3, X, 553, 1, PULL1)," & -- PAD160
+ " 553 (BC_2, *, controlr, 1)," &
+ " 552 (BC_2, IPAD161, input, X)," &
+ " 551 (BC_2, IPAD162, input, X)," &
+ " 550 (BC_2, *, internal, X)," & -- PAD163.I
+ " 549 (BC_2, *, internal, X)," & -- PAD163.O
+ " 548 (BC_2, *, internal, 1)," & -- PAD163.T
+ " 547 (BC_2, *, internal, X)," & -- PAD164.I
+ " 546 (BC_2, *, internal, X)," & -- PAD164.O
+ " 545 (BC_2, *, internal, 1)," & -- PAD164.T
+ " 544 (BC_2, *, internal, X)," & -- PAD165.I
+ " 543 (BC_2, *, internal, X)," & -- PAD165.O
+ " 542 (BC_2, *, internal, 1)," & -- PAD165.T
+ " 541 (BC_2, R13, input, X)," & -- PAD166
+ " 540 (BC_2, R13, output3, X, 539, 1, PULL1)," & -- PAD166
+ " 539 (BC_2, *, controlr, 1)," &
+ " 538 (BC_2, P13, input, X)," & -- PAD167
+ " 537 (BC_2, P13, output3, X, 536, 1, PULL1)," & -- PAD167
+ " 536 (BC_2, *, controlr, 1)," &
+ " 535 (BC_2, *, internal, X)," & -- IPAD168
+ " 534 (BC_2, *, internal, X)," & -- IPAD169
+ " 533 (BC_2, P12, input, X)," & -- PAD170
+ " 532 (BC_2, P12, output3, X, 531, 1, PULL1)," & -- PAD170
+ " 531 (BC_2, *, controlr, 1)," &
+ " 530 (BC_2, N12, input, X)," & -- PAD171
+ " 529 (BC_2, N12, output3, X, 528, 1, PULL1)," & -- PAD171
+ " 528 (BC_2, *, controlr, 1)," &
+ " 527 (BC_2, U13, input, X)," & -- PAD172
+ " 526 (BC_2, U13, output3, X, 525, 1, PULL1)," & -- PAD172
+ " 525 (BC_2, *, controlr, 1)," &
+ " 524 (BC_2, R12, input, X)," & -- PAD173
+ " 523 (BC_2, R12, output3, X, 522, 1, PULL1)," & -- PAD173
+ " 522 (BC_2, *, controlr, 1)," &
+ " 521 (BC_2, T12, input, X)," & -- PAD174
+ " 520 (BC_2, T12, output3, X, 519, 1, PULL1)," & -- PAD174
+ " 519 (BC_2, *, controlr, 1)," &
+ " 518 (BC_2, *, internal, X)," & -- IPAD175
+ " 517 (BC_2, *, internal, X)," & -- IPAD176
+ " 516 (BC_2, *, internal, X)," & -- PAD177.I
+ " 515 (BC_2, *, internal, X)," & -- PAD177.O
+ " 514 (BC_2, *, internal, 1)," & -- PAD177.T
+ " 513 (BC_2, V13, input, X)," & -- PAD178
+ " 512 (BC_2, V13, output3, X, 511, 1, PULL1)," & -- PAD178
+ " 511 (BC_2, *, controlr, 1)," &
+ " 510 (BC_2, V12, input, X)," & -- PAD179
+ " 509 (BC_2, V12, output3, X, 508, 1, PULL1)," & -- PAD179
+ " 508 (BC_2, *, controlr, 1)," &
+ " 507 (BC_2, R11, input, X)," & -- PAD180
+ " 506 (BC_2, R11, output3, X, 505, 1, PULL1)," & -- PAD180
+ " 505 (BC_2, *, controlr, 1)," &
+ " 504 (BC_2, N11, input, X)," & -- PAD181
+ " 503 (BC_2, N11, output3, X, 502, 1, PULL1)," & -- PAD181
+ " 502 (BC_2, *, controlr, 1)," &
+ " 501 (BC_2, P11, input, X)," & -- PAD182
+ " 500 (BC_2, P11, output3, X, 499, 1, PULL1)," & -- PAD182
+ " 499 (BC_2, *, controlr, 1)," &
+ " 498 (BC_2, IPAD183, input, X)," &
+ " 497 (BC_2, IPAD184, input, X)," &
+ " 496 (BC_2, N10, input, X)," & -- PAD185
+ " 495 (BC_2, N10, output3, X, 494, 1, PULL1)," & -- PAD185
+ " 494 (BC_2, *, controlr, 1)," &
+ " 493 (BC_2, M10, input, X)," & -- PAD186
+ " 492 (BC_2, M10, output3, X, 491, 1, PULL1)," & -- PAD186
+ " 491 (BC_2, *, controlr, 1)," &
+ " 490 (BC_2, V11, input, X)," & -- PAD187
+ " 489 (BC_2, V11, output3, X, 488, 1, PULL1)," & -- PAD187
+ " 488 (BC_2, *, controlr, 1)," &
+ " 487 (BC_2, P10, input, X)," & -- PAD188
+ " 486 (BC_2, P10, output3, X, 485, 1, PULL1)," & -- PAD188
+ " 485 (BC_2, *, controlr, 1)," &
+ " 484 (BC_2, R10, input, X)," & -- PAD189
+ " 483 (BC_2, R10, output3, X, 482, 1, PULL1)," & -- PAD189
+ " 482 (BC_2, *, controlr, 1)," &
+ " 481 (BC_2, IPAD190, input, X)," &
+ " 480 (BC_2, IPAD191, input, X)," &
+ " 479 (BC_2, V9, input, X)," & -- PAD192
+ " 478 (BC_2, V9, output3, X, 477, 1, PULL1)," & -- PAD192
+ " 477 (BC_2, *, controlr, 1)," &
+ " 476 (BC_2, U9, input, X)," & -- PAD193
+ " 475 (BC_2, U9, output3, X, 474, 1, PULL1)," & -- PAD193
+ " 474 (BC_2, *, controlr, 1)," &
+ " 473 (BC_2, R9, input, X)," & -- PAD194
+ " 472 (BC_2, R9, output3, X, 471, 1, PULL1)," & -- PAD194
+ " 471 (BC_2, *, controlr, 1)," &
+ " 470 (BC_2, M9, input, X)," & -- PAD195
+ " 469 (BC_2, M9, output3, X, 468, 1, PULL1)," & -- PAD195
+ " 468 (BC_2, *, controlr, 1)," &
+ " 467 (BC_2, N9, input, X)," & -- PAD196
+ " 466 (BC_2, N9, output3, X, 465, 1, PULL1)," & -- PAD196
+ " 465 (BC_2, *, controlr, 1)," &
+ " 464 (BC_2, IPAD197, input, X)," &
+ " 463 (BC_2, IPAD198, input, X)," &
+ " 462 (BC_2, T8, input, X)," & -- PAD199
+ " 461 (BC_2, T8, output3, X, 460, 1, PULL1)," & -- PAD199
+ " 460 (BC_2, *, controlr, 1)," &
+ " 459 (BC_2, R8, input, X)," & -- PAD200
+ " 458 (BC_2, R8, output3, X, 457, 1, PULL1)," & -- PAD200
+ " 457 (BC_2, *, controlr, 1)," &
+ " 456 (BC_2, P9, input, X)," & -- PAD201
+ " 455 (BC_2, P9, output3, X, 454, 1, PULL1)," & -- PAD201
+ " 454 (BC_2, *, controlr, 1)," &
+ " 453 (BC_2, N8, input, X)," & -- PAD202
+ " 452 (BC_2, N8, output3, X, 451, 1, PULL1)," & -- PAD202
+ " 451 (BC_2, *, controlr, 1)," &
+ " 450 (BC_2, P8, input, X)," & -- PAD203
+ " 449 (BC_2, P8, output3, X, 448, 1, PULL1)," & -- PAD203
+ " 448 (BC_2, *, controlr, 1)," &
+ " 447 (BC_2, IPAD204, input, X)," &
+ " 446 (BC_2, IPAD205, input, X)," &
+ " 445 (BC_2, V7, input, X)," & -- PAD206
+ " 444 (BC_2, V7, output3, X, 443, 1, PULL1)," & -- PAD206
+ " 443 (BC_2, *, controlr, 1)," &
+ " 442 (BC_2, P7, input, X)," & -- PAD207
+ " 441 (BC_2, P7, output3, X, 440, 1, PULL1)," & -- PAD207
+ " 440 (BC_2, *, controlr, 1)," &
+ " 439 (BC_2, N7, input, X)," & -- PAD208
+ " 438 (BC_2, N7, output3, X, 437, 1, PULL1)," & -- PAD208
+ " 437 (BC_2, *, controlr, 1)," &
+ " 436 (BC_2, U6, input, X)," & -- PAD209
+ " 435 (BC_2, U6, output3, X, 434, 1, PULL1)," & -- PAD209
+ " 434 (BC_2, *, controlr, 1)," &
+ " 433 (BC_2, V6, input, X)," & -- PAD210
+ " 432 (BC_2, V6, output3, X, 431, 1, PULL1)," & -- PAD210
+ " 431 (BC_2, *, controlr, 1)," &
+ " 430 (BC_2, V5, input, X)," & -- PAD211
+ " 429 (BC_2, V5, output3, X, 428, 1, PULL1)," & -- PAD211
+ " 428 (BC_2, *, controlr, 1)," &
+ " 427 (BC_2, *, internal, X)," & -- IPAD212
+ " 426 (BC_2, *, internal, X)," & -- IPAD213
+ " 425 (BC_2, P6, input, X)," & -- PAD214
+ " 424 (BC_2, P6, output3, X, 423, 1, PULL1)," & -- PAD214
+ " 423 (BC_2, *, controlr, 1)," &
+ " 422 (BC_2, R6, input, X)," & -- PAD215
+ " 421 (BC_2, R6, output3, X, 420, 1, PULL1)," & -- PAD215
+ " 420 (BC_2, *, controlr, 1)," &
+ " 419 (BC_2, *, internal, X)," & -- PAD216.I
+ " 418 (BC_2, *, internal, X)," & -- PAD216.O
+ " 417 (BC_2, *, internal, 1)," & -- PAD216.T
+ " 416 (BC_2, *, internal, X)," & -- PAD217.I
+ " 415 (BC_2, *, internal, X)," & -- PAD217.O
+ " 414 (BC_2, *, internal, 1)," & -- PAD217.T
+ " 413 (BC_2, *, internal, X)," & -- PAD218.I
+ " 412 (BC_2, *, internal, X)," & -- PAD218.O
+ " 411 (BC_2, *, internal, 1)," & -- PAD218.T
+ " 410 (BC_2, *, internal, X)," & -- IPAD219
+ " 409 (BC_2, *, internal, X)," & -- IPAD220
+ " 408 (BC_2, T5, input, X)," & -- PAD221
+ " 407 (BC_2, T5, output3, X, 406, 1, PULL1)," & -- PAD221
+ " 406 (BC_2, *, controlr, 1)," &
+ " 405 (BC_2, R5, input, X)," & -- PAD222
+ " 404 (BC_2, R5, output3, X, 403, 1, PULL1)," & -- PAD222
+ " 403 (BC_2, *, controlr, 1)," &
+ " 402 (BC_2, U5, input, X)," & -- PAD223
+ " 401 (BC_2, U5, output3, X, 400, 1, PULL1)," & -- PAD223
+ " 400 (BC_2, *, controlr, 1)," &
+ " 399 (BC_2, T4, input, X)," & -- PAD224
+ " 398 (BC_2, T4, output3, X, 397, 1, PULL1)," & -- PAD224
+ " 397 (BC_2, *, controlr, 1)," &
+ " 396 (BC_2, U4, input, X)," & -- PAD225
+ " 395 (BC_2, U4, output3, X, 394, 1, PULL1)," & -- PAD225
+ " 394 (BC_2, *, controlr, 1)," &
+ " 393 (BC_2, IPAD226, input, X)," &
+ " 392 (BC_2, IPAD227, input, X)," &
+ " 391 (BC_2, T3, input, X)," & -- PAD228
+ " 390 (BC_2, T3, output3, X, 389, 1, PULL1)," & -- PAD228
+ " 389 (BC_2, *, controlr, 1)," &
+ " 388 (BC_2, U3, input, X)," & -- PAD229
+ " 387 (BC_2, U3, output3, X, 386, 1, PULL1)," & -- PAD229
+ " 386 (BC_2, *, controlr, 1)," &
+ " 385 (BC_2, IPAD230, input, X)," &
+ " 384 (BC_2, IPAD231, input, X)," &
+ " 383 (BC_2, T1, input, X)," & -- PAD232
+ " 382 (BC_2, T1, output3, X, 381, 1, PULL1)," & -- PAD232
+ " 381 (BC_2, *, controlr, 1)," &
+ " 380 (BC_2, T2, input, X)," & -- PAD233
+ " 379 (BC_2, T2, output3, X, 378, 1, PULL1)," & -- PAD233
+ " 378 (BC_2, *, controlr, 1)," &
+ " 377 (BC_2, R2, input, X)," & -- PAD234
+ " 376 (BC_2, R2, output3, X, 375, 1, PULL1)," & -- PAD234
+ " 375 (BC_2, *, controlr, 1)," &
+ " 374 (BC_2, R3, input, X)," & -- PAD235
+ " 373 (BC_2, R3, output3, X, 372, 1, PULL1)," & -- PAD235
+ " 372 (BC_2, *, controlr, 1)," &
+ " 371 (BC_2, *, internal, X)," & -- PAD236.I
+ " 370 (BC_2, *, internal, X)," & -- PAD236.O
+ " 369 (BC_2, *, internal, 1)," & -- PAD236.T
+ " 368 (BC_2, *, internal, X)," & -- PAD237.I
+ " 367 (BC_2, *, internal, X)," & -- PAD237.O
+ " 366 (BC_2, *, internal, 1)," & -- PAD237.T
+ " 365 (BC_2, IPAD238, input, X)," &
+ " 364 (BC_2, *, internal, X)," & -- PAD239.I
+ " 363 (BC_2, *, internal, X)," & -- PAD239.O
+ " 362 (BC_2, *, internal, 1)," & -- PAD239.T
+ " 361 (BC_2, *, internal, X)," & -- PAD240.I
+ " 360 (BC_2, *, internal, X)," & -- PAD240.O
+ " 359 (BC_2, *, internal, 1)," & -- PAD240.T
+ " 358 (BC_2, P4, input, X)," & -- PAD241
+ " 357 (BC_2, P4, output3, X, 356, 1, PULL1)," & -- PAD241
+ " 356 (BC_2, *, controlr, 1)," &
+ " 355 (BC_2, P3, input, X)," & -- PAD242
+ " 354 (BC_2, P3, output3, X, 353, 1, PULL1)," & -- PAD242
+ " 353 (BC_2, *, controlr, 1)," &
+ " 352 (BC_2, IPAD243, input, X)," &
+ " 351 (BC_2, P1, input, X)," & -- PAD244
+ " 350 (BC_2, P1, output3, X, 349, 1, PULL1)," & -- PAD244
+ " 349 (BC_2, *, controlr, 1)," &
+ " 348 (BC_2, P2, input, X)," & -- PAD245
+ " 347 (BC_2, P2, output3, X, 346, 1, PULL1)," & -- PAD245
+ " 346 (BC_2, *, controlr, 1)," &
+ " 345 (BC_2, *, internal, X)," & -- PAD246.I
+ " 344 (BC_2, *, internal, X)," & -- PAD246.O
+ " 343 (BC_2, *, internal, 1)," & -- PAD246.T
+ " 342 (BC_2, *, internal, X)," & -- PAD247.I
+ " 341 (BC_2, *, internal, X)," & -- PAD247.O
+ " 340 (BC_2, *, internal, 1)," & -- PAD247.T
+ " 339 (BC_2, IPAD248, input, X)," &
+ " 338 (BC_2, N5, input, X)," & -- PAD249
+ " 337 (BC_2, N5, output3, X, 336, 1, PULL1)," & -- PAD249
+ " 336 (BC_2, *, controlr, 1)," &
+ " 335 (BC_2, N4, input, X)," & -- PAD250
+ " 334 (BC_2, N4, output3, X, 333, 1, PULL1)," & -- PAD250
+ " 333 (BC_2, *, controlr, 1)," &
+ " 332 (BC_2, M6, input, X)," & -- PAD251
+ " 331 (BC_2, M6, output3, X, 330, 1, PULL1)," & -- PAD251
+ " 330 (BC_2, *, controlr, 1)," &
+ " 329 (BC_2, M5, input, X)," & -- PAD252
+ " 328 (BC_2, M5, output3, X, 327, 1, PULL1)," & -- PAD252
+ " 327 (BC_2, *, controlr, 1)," &
+ " 326 (BC_2, IPAD253, input, X)," &
+ " 325 (BC_2, M3, input, X)," & -- PAD254
+ " 324 (BC_2, M3, output3, X, 323, 1, PULL1)," & -- PAD254
+ " 323 (BC_2, *, controlr, 1)," &
+ " 322 (BC_2, M4, input, X)," & -- PAD255
+ " 321 (BC_2, M4, output3, X, 320, 1, PULL1)," & -- PAD255
+ " 320 (BC_2, *, controlr, 1)," &
+ " 319 (BC_2, L5, input, X)," & -- PAD256
+ " 318 (BC_2, L5, output3, X, 317, 1, PULL1)," & -- PAD256
+ " 317 (BC_2, *, controlr, 1)," &
+ " 316 (BC_2, L6, input, X)," & -- PAD257
+ " 315 (BC_2, L6, output3, X, 314, 1, PULL1)," & -- PAD257
+ " 314 (BC_2, *, controlr, 1)," &
+ " 313 (BC_2, IPAD258, input, X)," &
+ " 312 (BC_2, L4, input, X)," & -- PAD259
+ " 311 (BC_2, L4, output3, X, 310, 1, PULL1)," & -- PAD259
+ " 310 (BC_2, *, controlr, 1)," &
+ " 309 (BC_2, L3, input, X)," & -- PAD260
+ " 308 (BC_2, L3, output3, X, 307, 1, PULL1)," & -- PAD260
+ " 307 (BC_2, *, controlr, 1)," &
+ " 306 (BC_2, L2, input, X)," & -- PAD261
+ " 305 (BC_2, L2, output3, X, 304, 1, PULL1)," & -- PAD261
+ " 304 (BC_2, *, controlr, 1)," &
+ " 303 (BC_2, L1, input, X)," & -- PAD262
+ " 302 (BC_2, L1, output3, X, 301, 1, PULL1)," & -- PAD262
+ " 301 (BC_2, *, controlr, 1)," &
+ " 300 (BC_2, IPAD263, input, X)," &
+ " 299 (BC_2, K5, input, X)," & -- PAD264
+ " 298 (BC_2, K5, output3, X, 297, 1, PULL1)," & -- PAD264
+ " 297 (BC_2, *, controlr, 1)," &
+ " 296 (BC_2, K6, input, X)," & -- PAD265
+ " 295 (BC_2, K6, output3, X, 294, 1, PULL1)," & -- PAD265
+ " 294 (BC_2, *, controlr, 1)," &
+ " 293 (BC_2, K4, input, X)," & -- PAD266
+ " 292 (BC_2, K4, output3, X, 291, 1, PULL1)," & -- PAD266
+ " 291 (BC_2, *, controlr, 1)," &
+ " 290 (BC_2, K3, input, X)," & -- PAD267
+ " 289 (BC_2, K3, output3, X, 288, 1, PULL1)," & -- PAD267
+ " 288 (BC_2, *, controlr, 1)," &
+ " 287 (BC_2, IPAD268, input, X)," &
+ " 286 (BC_2, J2, input, X)," & -- PAD269
+ " 285 (BC_2, J2, output3, X, 284, 1, PULL1)," & -- PAD269
+ " 284 (BC_2, *, controlr, 1)," &
+ " 283 (BC_2, J1, input, X)," & -- PAD270
+ " 282 (BC_2, J1, output3, X, 281, 1, PULL1)," & -- PAD270
+ " 281 (BC_2, *, controlr, 1)," &
+ " 280 (BC_2, J4, input, X)," & -- PAD271
+ " 279 (BC_2, J4, output3, X, 278, 1, PULL1)," & -- PAD271
+ " 278 (BC_2, *, controlr, 1)," &
+ " 277 (BC_2, J5, input, X)," & -- PAD272
+ " 276 (BC_2, J5, output3, X, 275, 1, PULL1)," & -- PAD272
+ " 275 (BC_2, *, controlr, 1)," &
+ " 274 (BC_2, IPAD273, input, X)," &
+ " 273 (BC_2, H1, input, X)," & -- PAD274
+ " 272 (BC_2, H1, output3, X, 271, 1, PULL1)," & -- PAD274
+ " 271 (BC_2, *, controlr, 1)," &
+ " 270 (BC_2, H2, input, X)," & -- PAD275
+ " 269 (BC_2, H2, output3, X, 268, 1, PULL1)," & -- PAD275
+ " 268 (BC_2, *, controlr, 1)," &
+ " 267 (BC_2, H3, input, X)," & -- PAD276
+ " 266 (BC_2, H3, output3, X, 265, 1, PULL1)," & -- PAD276
+ " 265 (BC_2, *, controlr, 1)," &
+ " 264 (BC_2, H4, input, X)," & -- PAD277
+ " 263 (BC_2, H4, output3, X, 262, 1, PULL1)," & -- PAD277
+ " 262 (BC_2, *, controlr, 1)," &
+ " 261 (BC_2, IPAD278, input, X)," &
+ " 260 (BC_2, H5, input, X)," & -- PAD279
+ " 259 (BC_2, H5, output3, X, 258, 1, PULL1)," & -- PAD279
+ " 258 (BC_2, *, controlr, 1)," &
+ " 257 (BC_2, H6, input, X)," & -- PAD280
+ " 256 (BC_2, H6, output3, X, 255, 1, PULL1)," & -- PAD280
+ " 255 (BC_2, *, controlr, 1)," &
+ " 254 (BC_2, G5, input, X)," & -- PAD281
+ " 253 (BC_2, G5, output3, X, 252, 1, PULL1)," & -- PAD281
+ " 252 (BC_2, *, controlr, 1)," &
+ " 251 (BC_2, G6, input, X)," & -- PAD282
+ " 250 (BC_2, G6, output3, X, 249, 1, PULL1)," & -- PAD282
+ " 249 (BC_2, *, controlr, 1)," &
+ " 248 (BC_2, IPAD283, input, X)," &
+ " 247 (BC_2, G4, input, X)," & -- PAD284
+ " 246 (BC_2, G4, output3, X, 245, 1, PULL1)," & -- PAD284
+ " 245 (BC_2, *, controlr, 1)," &
+ " 244 (BC_2, G3, input, X)," & -- PAD285
+ " 243 (BC_2, G3, output3, X, 242, 1, PULL1)," & -- PAD285
+ " 242 (BC_2, *, controlr, 1)," &
+ " 241 (BC_2, F2, input, X)," & -- PAD286
+ " 240 (BC_2, F2, output3, X, 239, 1, PULL1)," & -- PAD286
+ " 239 (BC_2, *, controlr, 1)," &
+ " 238 (BC_2, F1, input, X)," & -- PAD287
+ " 237 (BC_2, F1, output3, X, 236, 1, PULL1)," & -- PAD287
+ " 236 (BC_2, *, controlr, 1)," &
+ " 235 (BC_2, IPAD288, input, X)," &
+ " 234 (BC_2, *, internal, X)," & -- PAD289.I
+ " 233 (BC_2, *, internal, X)," & -- PAD289.O
+ " 232 (BC_2, *, internal, 1)," & -- PAD289.T
+ " 231 (BC_2, *, internal, X)," & -- PAD290.I
+ " 230 (BC_2, *, internal, X)," & -- PAD290.O
+ " 229 (BC_2, *, internal, 1)," & -- PAD290.T
+ " 228 (BC_2, E3, input, X)," & -- PAD291
+ " 227 (BC_2, E3, output3, X, 226, 1, PULL1)," & -- PAD291
+ " 226 (BC_2, *, controlr, 1)," &
+ " 225 (BC_2, E4, input, X)," & -- PAD292
+ " 224 (BC_2, E4, output3, X, 223, 1, PULL1)," & -- PAD292
+ " 223 (BC_2, *, controlr, 1)," &
+ " 222 (BC_2, IPAD293, input, X)," &
+ " 221 (BC_2, *, internal, X)," & -- PAD294.I
+ " 220 (BC_2, *, internal, X)," & -- PAD294.O
+ " 219 (BC_2, *, internal, 1)," & -- PAD294.T
+ " 218 (BC_2, *, internal, X)," & -- PAD295.I
+ " 217 (BC_2, *, internal, X)," & -- PAD295.O
+ " 216 (BC_2, *, internal, 1)," & -- PAD295.T
+ " 215 (BC_2, E1, input, X)," & -- PAD296
+ " 214 (BC_2, E1, output3, X, 213, 1, PULL1)," & -- PAD296
+ " 213 (BC_2, *, controlr, 1)," &
+ " 212 (BC_2, E2, input, X)," & -- PAD297
+ " 211 (BC_2, E2, output3, X, 210, 1, PULL1)," & -- PAD297
+ " 210 (BC_2, *, controlr, 1)," &
+ " 209 (BC_2, D4, input, X)," & -- PAD298
+ " 208 (BC_2, D4, output3, X, 207, 1, PULL1)," & -- PAD298
+ " 207 (BC_2, *, controlr, 1)," &
+ " 206 (BC_2, *, internal, X)," & -- PAD299.I
+ " 205 (BC_2, *, internal, X)," & -- PAD299.O
+ " 204 (BC_2, *, internal, 1)," & -- PAD299.T
+ " 203 (BC_2, IPAD300, input, X)," &
+ " 202 (BC_2, D2, input, X)," & -- PAD301
+ " 201 (BC_2, D2, output3, X, 200, 1, PULL1)," & -- PAD301
+ " 200 (BC_2, *, controlr, 1)," &
+ " 199 (BC_2, D1, input, X)," & -- PAD302
+ " 198 (BC_2, D1, output3, X, 197, 1, PULL1)," & -- PAD302
+ " 197 (BC_2, *, controlr, 1)," &
+ " 196 (BC_2, C2, input, X)," & -- PAD303
+ " 195 (BC_2, C2, output3, X, 194, 1, PULL1)," & -- PAD303
+ " 194 (BC_2, *, controlr, 1)," &
+ " 193 (BC_2, C1, input, X)," & -- PAD304
+ " 192 (BC_2, C1, output3, X, 191, 1, PULL1)," & -- PAD304
+ " 191 (BC_2, *, controlr, 1)," &
+ " 190 (BC_2, *, internal, 1)," & -- PROG_B
+ " 189 (BC_2, *, internal, 1)," & -- PUDC_B
+ " 188 (BC_2, *, internal, 1)," & -- PUDC_B
+ " 187 (BC_2, *, internal, 1)," & -- PUDC_B
+ " 186 (BC_2, C3, input, X)," & -- PAD2
+ " 185 (BC_2, C3, output3, X, 184, 1, PULL1)," & -- PAD2
+ " 184 (BC_2, *, controlr, 1)," &
+ " 183 (BC_2, IPAD3, input, X)," &
+ " 182 (BC_2, B4, input, X)," & -- PAD4
+ " 181 (BC_2, B4, output3, X, 180, 1, PULL1)," & -- PAD4
+ " 180 (BC_2, *, controlr, 1)," &
+ " 179 (BC_2, A4, input, X)," & -- PAD5
+ " 178 (BC_2, A4, output3, X, 177, 1, PULL1)," & -- PAD5
+ " 177 (BC_2, *, controlr, 1)," &
+ " 176 (BC_2, C4, input, X)," & -- PAD6
+ " 175 (BC_2, C4, output3, X, 174, 1, PULL1)," & -- PAD6
+ " 174 (BC_2, *, controlr, 1)," &
+ " 173 (BC_2, D5, input, X)," & -- PAD7
+ " 172 (BC_2, D5, output3, X, 171, 1, PULL1)," & -- PAD7
+ " 171 (BC_2, *, controlr, 1)," &
+ " 170 (BC_2, C5, input, X)," & -- PAD8
+ " 169 (BC_2, C5, output3, X, 168, 1, PULL1)," & -- PAD8
+ " 168 (BC_2, *, controlr, 1)," &
+ " 167 (BC_2, IPAD9, input, X)," &
+ " 166 (BC_2, IPAD10, input, X)," &
+ " 165 (BC_2, E6, input, X)," & -- PAD11
+ " 164 (BC_2, E6, output3, X, 163, 1, PULL1)," & -- PAD11
+ " 163 (BC_2, *, controlr, 1)," &
+ " 162 (BC_2, D6, input, X)," & -- PAD12
+ " 161 (BC_2, D6, output3, X, 160, 1, PULL1)," & -- PAD12
+ " 160 (BC_2, *, controlr, 1)," &
+ " 159 (BC_2, *, internal, X)," & -- PAD13.I
+ " 158 (BC_2, *, internal, X)," & -- PAD13.O
+ " 157 (BC_2, *, internal, 1)," & -- PAD13.T
+ " 156 (BC_2, A6, input, X)," & -- PAD14
+ " 155 (BC_2, A6, output3, X, 154, 1, PULL1)," & -- PAD14
+ " 154 (BC_2, *, controlr, 1)," &
+ " 153 (BC_2, B6, input, X)," & -- PAD15
+ " 152 (BC_2, B6, output3, X, 151, 1, PULL1)," & -- PAD15
+ " 151 (BC_2, *, controlr, 1)," &
+ " 150 (BC_2, *, internal, X)," & -- IPAD16
+ " 149 (BC_2, *, internal, X)," & -- IPAD17
+ " 148 (BC_2, *, internal, X)," & -- PAD18.I
+ " 147 (BC_2, *, internal, X)," & -- PAD18.O
+ " 146 (BC_2, *, internal, 1)," & -- PAD18.T
+ " 145 (BC_2, *, internal, X)," & -- PAD19.I
+ " 144 (BC_2, *, internal, X)," & -- PAD19.O
+ " 143 (BC_2, *, internal, 1)," & -- PAD19.T
+ " 142 (BC_2, A7, input, X)," & -- PAD20
+ " 141 (BC_2, A7, output3, X, 140, 1, PULL1)," & -- PAD20
+ " 140 (BC_2, *, controlr, 1)," &
+ " 139 (BC_2, E7, input, X)," & -- PAD21
+ " 138 (BC_2, E7, output3, X, 137, 1, PULL1)," & -- PAD21
+ " 137 (BC_2, *, controlr, 1)," &
+ " 136 (BC_2, F7, input, X)," & -- PAD22
+ " 135 (BC_2, F7, output3, X, 134, 1, PULL1)," & -- PAD22
+ " 134 (BC_2, *, controlr, 1)," &
+ " 133 (BC_2, *, internal, X)," & -- IPAD23
+ " 132 (BC_2, *, internal, X)," & -- IPAD24
+ " 131 (BC_2, *, internal, X)," & -- PAD25.I
+ " 130 (BC_2, *, internal, X)," & -- PAD25.O
+ " 129 (BC_2, *, internal, 1)," & -- PAD25.T
+ " 128 (BC_2, D7, input, X)," & -- PAD26
+ " 127 (BC_2, D7, output3, X, 126, 1, PULL1)," & -- PAD26
+ " 126 (BC_2, *, controlr, 1)," &
+ " 125 (BC_2, C7, input, X)," & -- PAD27
+ " 124 (BC_2, C7, output3, X, 123, 1, PULL1)," & -- PAD27
+ " 123 (BC_2, *, controlr, 1)," &
+ " 122 (BC_2, A8, input, X)," & -- PAD28
+ " 121 (BC_2, A8, output3, X, 120, 1, PULL1)," & -- PAD28
+ " 120 (BC_2, *, controlr, 1)," &
+ " 119 (BC_2, F8, input, X)," & -- PAD29
+ " 118 (BC_2, F8, output3, X, 117, 1, PULL1)," & -- PAD29
+ " 117 (BC_2, *, controlr, 1)," &
+ " 116 (BC_2, E8, input, X)," & -- PAD30
+ " 115 (BC_2, E8, output3, X, 114, 1, PULL1)," & -- PAD30
+ " 114 (BC_2, *, controlr, 1)," &
+ " 113 (BC_2, IPAD31, input, X)," &
+ " 112 (BC_2, IPAD32, input, X)," &
+ " 111 (BC_2, F9, input, X)," & -- PAD33
+ " 110 (BC_2, F9, output3, X, 109, 1, PULL1)," & -- PAD33
+ " 109 (BC_2, *, controlr, 1)," &
+ " 108 (BC_2, E9, input, X)," & -- PAD34
+ " 107 (BC_2, E9, output3, X, 106, 1, PULL1)," & -- PAD34
+ " 106 (BC_2, *, controlr, 1)," &
+ " 105 (BC_2, G9, input, X)," & -- PAD35
+ " 104 (BC_2, G9, output3, X, 103, 1, PULL1)," & -- PAD35
+ " 103 (BC_2, *, controlr, 1)," &
+ " 102 (BC_2, D9, input, X)," & -- PAD36
+ " 101 (BC_2, D9, output3, X, 100, 1, PULL1)," & -- PAD36
+ " 100 (BC_2, *, controlr, 1)," &
+ " 99 (BC_2, C9, input, X)," & -- PAD37
+ " 98 (BC_2, C9, output3, X, 97, 1, PULL1)," & -- PAD37
+ " 97 (BC_2, *, controlr, 1)," &
+ " 96 (BC_2, IPAD38, input, X)," &
+ " 95 (BC_2, IPAD39, input, X)," &
+ " 94 (BC_2, A10, input, X)," & -- PAD40
+ " 93 (BC_2, A10, output3, X, 92, 1, PULL1)," & -- PAD40
+ " 92 (BC_2, *, controlr, 1)," &
+ " 91 (BC_2, B10, input, X)," & -- PAD41
+ " 90 (BC_2, B10, output3, X, 89, 1, PULL1)," & -- PAD41
+ " 89 (BC_2, *, controlr, 1)," &
+ " 88 (BC_2, B11, input, X)," & -- PAD42
+ " 87 (BC_2, B11, output3, X, 86, 1, PULL1)," & -- PAD42
+ " 86 (BC_2, *, controlr, 1)," &
+ " 85 (BC_2, E10, input, X)," & -- PAD43
+ " 84 (BC_2, E10, output3, X, 83, 1, PULL1)," & -- PAD43
+ " 83 (BC_2, *, controlr, 1)," &
+ " 82 (BC_2, D10, input, X)," & -- PAD44
+ " 81 (BC_2, D10, output3, X, 80, 1, PULL1)," & -- PAD44
+ " 80 (BC_2, *, controlr, 1)," &
+ " 79 (BC_2, IPAD45, input, X)," &
+ " 78 (BC_2, IPAD46, input, X)," &
+ " 77 (BC_2, D11, input, X)," & -- PAD47
+ " 76 (BC_2, D11, output3, X, 75, 1, PULL1)," & -- PAD47
+ " 75 (BC_2, *, controlr, 1)," &
+ " 74 (BC_2, C11, input, X)," & -- PAD48
+ " 73 (BC_2, C11, output3, X, 72, 1, PULL1)," & -- PAD48
+ " 72 (BC_2, *, controlr, 1)," &
+ " 71 (BC_2, A11, input, X)," & -- PAD49
+ " 70 (BC_2, A11, output3, X, 69, 1, PULL1)," & -- PAD49
+ " 69 (BC_2, *, controlr, 1)," &
+ " 68 (BC_2, F11, input, X)," & -- PAD50
+ " 67 (BC_2, F11, output3, X, 66, 1, PULL1)," & -- PAD50
+ " 66 (BC_2, *, controlr, 1)," &
+ " 65 (BC_2, E11, input, X)," & -- PAD51
+ " 64 (BC_2, E11, output3, X, 63, 1, PULL1)," & -- PAD51
+ " 63 (BC_2, *, controlr, 1)," &
+ " 62 (BC_2, IPAD52, input, X)," &
+ " 61 (BC_2, IPAD53, input, X)," &
+ " 60 (BC_2, A12, input, X)," & -- PAD54
+ " 59 (BC_2, A12, output3, X, 58, 1, PULL1)," & -- PAD54
+ " 58 (BC_2, *, controlr, 1)," &
+ " 57 (BC_2, E12, input, X)," & -- PAD55
+ " 56 (BC_2, E12, output3, X, 55, 1, PULL1)," & -- PAD55
+ " 55 (BC_2, *, controlr, 1)," &
+ " 54 (BC_2, F12, input, X)," & -- PAD56
+ " 53 (BC_2, F12, output3, X, 52, 1, PULL1)," & -- PAD56
+ " 52 (BC_2, *, controlr, 1)," &
+ " 51 (BC_2, D13, input, X)," & -- PAD57
+ " 50 (BC_2, D13, output3, X, 49, 1, PULL1)," & -- PAD57
+ " 49 (BC_2, *, controlr, 1)," &
+ " 48 (BC_2, B13, input, X)," & -- PAD58
+ " 47 (BC_2, B13, output3, X, 46, 1, PULL1)," & -- PAD58
+ " 46 (BC_2, *, controlr, 1)," &
+ " 45 (BC_2, A13, input, X)," & -- PAD59
+ " 44 (BC_2, A13, output3, X, 43, 1, PULL1)," & -- PAD59
+ " 43 (BC_2, *, controlr, 1)," &
+ " 42 (BC_2, *, internal, X)," & -- IPAD60
+ " 41 (BC_2, *, internal, X)," & -- IPAD61
+ " 40 (BC_2, A14, input, X)," & -- PAD62
+ " 39 (BC_2, A14, output3, X, 38, 1, PULL1)," & -- PAD62
+ " 38 (BC_2, *, controlr, 1)," &
+ " 37 (BC_2, B14, input, X)," & -- PAD63
+ " 36 (BC_2, B14, output3, X, 35, 1, PULL1)," & -- PAD63
+ " 35 (BC_2, *, controlr, 1)," &
+ " 34 (BC_2, *, internal, X)," & -- PAD64.I
+ " 33 (BC_2, *, internal, X)," & -- PAD64.O
+ " 32 (BC_2, *, internal, 1)," & -- PAD64.T
+ " 31 (BC_2, *, internal, X)," & -- PAD65.I
+ " 30 (BC_2, *, internal, X)," & -- PAD65.O
+ " 29 (BC_2, *, internal, 1)," & -- PAD65.T
+ " 28 (BC_2, *, internal, X)," & -- PAD66.I
+ " 27 (BC_2, *, internal, X)," & -- PAD66.O
+ " 26 (BC_2, *, internal, 1)," & -- PAD66.T
+ " 25 (BC_2, *, internal, X)," & -- IPAD67
+ " 24 (BC_2, *, internal, X)," & -- IPAD68
+ " 23 (BC_2, *, internal, X)," & -- PAD69.I
+ " 22 (BC_2, *, internal, X)," & -- PAD69.O
+ " 21 (BC_2, *, internal, 1)," & -- PAD69.T
+ " 20 (BC_2, *, internal, X)," & -- PAD70.I
+ " 19 (BC_2, *, internal, X)," & -- PAD70.O
+ " 18 (BC_2, *, internal, 1)," & -- PAD70.T
+ " 17 (BC_2, E13, input, X)," & -- PAD71
+ " 16 (BC_2, E13, output3, X, 15, 1, PULL1)," & -- PAD71
+ " 15 (BC_2, *, controlr, 1)," &
+ " 14 (BC_2, C14, input, X)," & -- PAD72
+ " 13 (BC_2, C14, output3, X, 12, 1, PULL1)," & -- PAD72
+ " 12 (BC_2, *, controlr, 1)," &
+ " 11 (BC_2, D14, input, X)," & -- PAD73
+ " 10 (BC_2, D14, output3, X, 9, 1, PULL1)," & -- PAD73
+ " 9 (BC_2, *, controlr, 1)," &
+ " 8 (BC_2, IPAD74, input, X)," &
+ " 7 (BC_2, IPAD75, input, X)," &
+ " 6 (BC_2, A16, input, X)," & -- PAD76
+ " 5 (BC_2, A16, output3, X, 4, 1, PULL1)," & -- PAD76
+ " 4 (BC_2, *, controlr, 1)," &
+ " 3 (BC_2, B16, input, X)," & -- PAD77
+ " 2 (BC_2, B16, output3, X, 1, 1, PULL1)," & -- PAD77
+ " 1 (BC_2, *, controlr, 1)," &
+ " 0 (BC_2, IPAD78, input, X)";
+
+
+attribute ISC_PIN_BEHAVIOR of XC3S1200E_FG320 : entity is
+ "HIGHZ" ; -- clamp behavior
+ -- no status
+
+attribute ISC_STATUS of XC3S1200E_FG320 : entity is
+ "NOT IMPLEMENTED" ;
+
+attribute ISC_BLANK_USERCODE of XC3S1200E_FG320 : entity is
+ "00000000000000000000000000000000";
+
+attribute ISC_FLOW of XC3S1200E_FG320 : entity is
+ -- Enable program
+ "flow_enable " &
+ "initialize " &
+ " (ISC_ENABLE 5:00 wait TCK 16)," &
+
+ "flow_disable " &
+ "initialize " &
+ " (ISC_DISABLE wait TCK 16)" &
+ " (BYPASS 1:0 wait TCK 1)," &
+
+ "flow_program(array) " &
+ "Repeat 239922 " &
+ " (ISC_PROGRAM 16:? wait TCK 1 )," &
+
+ "flow_program(legacy) " &
+ "Initialize " &
+ " (JSHUTDOWN wait TCK 16)" &
+ " (CFG_IN 3838752:? wait TCK 1)" &
+ " (JSTART wait TCK 32)" &
+ " (BYPASS 1:0 wait TCK 1)," &
+
+ "flow_verify(idcode) " &
+ "initialize " &
+ " (IDCODE wait TCK 1 32:01C2E093*0FFFFFFF)," &
+
+ "flow_read(usercode) " &
+ "initialize " &
+ " (USERCODE wait TCK 1 32:!)," &
+
+ "flow_read(idcode) " &
+ "initialize " &
+ " (IDCODE wait TCK 1 32:!)," &
+
+ "flow_program_done " &
+ "initialize " &
+ " (BYPASS wait TCK 1)," &
+
+ "flow_error_exit " &
+ "initialize " &
+ " (BYPASS wait TCK 1)";
+
+attribute ISC_PROCEDURE of XC3S1200E_FG320 : entity is
+ "proc_enable = (flow_enable)," &
+ "proc_disable = (flow_disable)," &
+ "proc_program = (flow_program(array))," &
+ "proc_program(legacy) = (flow_program(legacy))," &
+ "proc_verify(idcode) = (flow_verify(idcode))," &
+ "proc_read(idcode) = (flow_read(idcode))," &
+ "proc_read(usercode) = (flow_read(usercode))," &
+ "proc_program_done = (flow_program_done)," &
+ "proc_error_exit = (flow_error_exit)";
+
+attribute ISC_ACTION of XC3S1200E_FG320 : entity is
+ "program = (proc_verify(idcode) recommended," &
+ " proc_enable, proc_program," &
+ " proc_disable)," &
+ "program(lgcy) = (proc_verify(idcode) recommended," &
+ " proc_enable, proc_program(legacy)," &
+ " proc_disable)," &
+ "verify(idcode) = (proc_verify(idcode))," &
+ "read(idcode) = (proc_read(idcode))," &
+ "read(usercode) = (proc_read(usercode))";
+
+-- Design Warning Section
+
+attribute DESIGN_WARNING of XC3S1200E_FG320 : entity is
+ "This is a preliminary BSDL file which has not been verified." &
+ "This BSDL file must be modified by the FPGA designer in order to" &
+ "reflect post-configuration behavior (if any)." &
+ "To avoid losing the current configuration, the PROG_B should be" &
+ "kept high. If the PROG_B pin goes low by any means," &
+ "the configuration will be cleared." &
+ "PROG_B can only be captured, not updated." &
+ "The value at the pin is always used by the device." &
+ "PUDC_B can be captured and updated." &
+ "The value at the pin is always used by the device" &
+ "before configuration is done." &
+ "During pre-configuration, the disable result of a 3-stated" &
+ "I/O in this file corresponds to PUDC_B being low" &
+ "or during EXTEST instruction." &
+ "When PUDC_B is high AND during SAMPLE instruction, change" &
+ "all PULL1s to PULL0s." &
+ "After configuration, the disable result only depends on" &
+ "the individual IO configuration setting." &
+ "In EXTEST, output and tristate values are not captured in the" &
+ "Capture-DR state - those register cells are unchanged." &
+ "In INTEST, the pin input values are not captured in the" &
+ "Capture-DR state - those register cells are unchanged." &
+ "The output and tristate capture values are not valid until after" &
+ "the device is configured." &
+ "The tristate control value is not captured properly when" &
+ "GTS is activated.";
+
+end XC3S1200E_FG320;
+
trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/bsdl/xc3s1200e_fg320_1532.bsd
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/debug/impact_bat
===================================================================
--- trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/debug/impact_bat (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/debug/impact_bat (revision 44)
@@ -0,0 +1,6 @@
+setMode -bs
+setCable -port svf -file ../debug/bitstream.svf
+addDevice -p 1 -file Board_Design_jtag.bit
+program -p 1
+closeCable
+quit
trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/debug/impact_bat
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/debug/fpga_load
===================================================================
--- trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/debug/fpga_load (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/debug/fpga_load (revision 44)
@@ -0,0 +1,6 @@
+bsdl path ../bsdl;../target/bsdl;
+cable usbblaster
+detect
+part 1
+svf bitstream.svf
+
trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/debug/fpga_load
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/filelist
===================================================================
--- trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/filelist (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/filelist (revision 44)
@@ -0,0 +1,29 @@
+verilog work ./target/Pad_Ring.v
+
+
+verilog work ../../../../../ip/T6502/rtl/gen/syn/T6502.v
+verilog work ../../../../../children/logic/ip/disp_io/rtl/gen/syn/disp_io.v
+verilog work ../../../../../children/logic/ip/io_module/rtl/gen/syn/io_module.v
+
+
+verilog work ../../../../../children/logic/ip/vga_char_ctrl/rtl/gen/syn/vga_char_ctrl.v
+verilog work ../../../../../children/logic/ip/ps2_interface/rtl/gen/syn/ps2_interface.v
+verilog work ../../../../../children/logic/ip/uart/rtl/gen/syn/uart.v
+verilog work ../../../../../children/logic/ip/serial_rcvr/rtl/gen/syn/serial_rcvr.v
+verilog work ../../../../../children/logic/ip/flash_memcontrl/rtl/gen/syn/flash_memcontrl.v
+
+
+verilog work ./target/lib/syn/cde_pads/cde_pad_se_dig.v
+verilog work ./target/lib/syn/cde_clock_sys/cde_clock_sys.v
+verilog work ./target/lib/syn/cde_jtag/cde_jtag.v
+verilog work ./target/lib/syn/cde_jtag/cde_jtag_rpc_reg.v
+verilog work ./target/lib/syn/cde_sram/cde_sram.v
+verilog work ./target/lib/syn/cde_fifo/cde_fifo.v
+verilog work ./target/lib/syn/cde_lifo/cde_lifo.v
+verilog work ./target/lib/syn/cde_synchronizers/cde_sync_with_hysteresis.v
+verilog work ./target/lib/syn/cde_divider/cde_divider.v
+verilog work ./target/lib/syn/cde_serial_rcvr/cde_serial_rcvr.v
+verilog work ./target/lib/syn/cde_serial_xmit/cde_serial_xmit.v
+
+
+
trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/filelist
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/core.v
===================================================================
--- trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/core.v (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/core.v (revision 44)
@@ -0,0 +1,149 @@
+
+
+
+
+
+
+ // Declare I/O Port connections
+
+
+wire clk = ck25MHz;
+
+
+
+
+
+
+
+
+
+wire [15:0] add_mon;
+wire [7:0] gpio_0_out;
+wire [7:0] gpio_1_out;
+
+
+assign rs_tx_pad_out = rs_rx_pad_in;
+
+
+
+
+assign jtag_user1_cap = jtag_user1_upd;
+assign jtag_user2_cap = add_mon;
+
+assign PosD = {gpio_0_out,gpio_1_out};
+assign PosL = 8'h12;
+
+
+
+assign ja_1_pad_out = 1'b0;
+assign ja_2_pad_out = reset;
+assign ja_3_pad_out = 1'b0;
+assign ja_4_pad_out = 1'b0 ;
+
+assign ja_7_pad_out = 1'b0;
+assign ja_8_pad_out = 1'b0;
+assign ja_9_pad_out = 1'b0;
+assign ja_10_pad_out = 1'b0;
+
+
+
+assign jb_1_pad_out = 1'b0;
+assign jb_2_pad_out = 1'b0;
+assign jb_3_pad_out = 1'b0;
+assign jb_4_pad_out = 1'b0;
+
+
+assign jb_7_pad_out = 1'b0;
+assign jb_8_pad_out = 1'b0;
+assign jb_9_pad_out = 1'b0;
+assign jb_10_pad_out = 1'b0;
+
+
+assign jc_1_pad_out = 1'b1;
+assign jc_2_pad_out = 1'b0;
+assign jc_3_pad_out = 1'b1;
+assign jc_4_pad_out = 1'b0;
+
+assign jc_7_pad_out = 1'b1;
+assign jc_8_pad_out = 1'b0;
+assign jc_9_pad_out = 1'b1;
+assign jc_10_pad_out = 1'b0;
+
+
+
+
+
+
+wire [9:0] xpos;
+
+
+assign add_mon[15:0] = 16'h0000 ;
+
+
+
+T6502 #(
+ .ROM_WORDS (`ROM_WORDS),
+ .ROM_ADD (`ROM_ADD),
+ .ROM_FILE (`ROM_FILE),
+ .PROG_ROM_WORDS (`PROG_ROM_WORDS),
+ .PROG_ROM_ADD (`PROG_ROM_ADD),
+ .PROG_ROM_FILE (`PROG_ROM_FILE),
+ .RAM_WORDS (4096),
+ .STARTUP (`STARTUP),
+ .FONT (`FONT)
+ )
+ cpu (
+ .clk ( ck25MHz ),
+ .reset ( reset ),
+
+
+
+
+ .alu_status ( ),
+
+ .ext_add ( micro_addr ),
+ .ext_wdata ( micro_wdata ),
+ .ext_rdata ( micro_rdata ),
+ .ext_ub ( micro_ub ),
+ .ext_lb ( micro_lb ),
+ .ext_rd ( micro_rd ),
+ .ext_wr ( micro_wr ),
+ .ext_cs ( micro_cs ),
+
+
+
+
+ .ext_irq_in ( 4'h0 ),
+
+ .gpio_0_out ( gpio_0_out ),
+ .gpio_0_in ( 8'h00 ),
+ .gpio_0_oe ( ),
+ .gpio_0_lat ( ),
+
+ .gpio_1_out ( gpio_1_out ),
+ .gpio_1_in ( 8'h00 ),
+ .gpio_1_oe ( ),
+ .gpio_1_lat ( ),
+
+ .ps2_data_oe ( ps2_data_pad_oe ),
+ .ps2_data_in ( ps2_data_pad_in ),
+ .ps2_clk_oe ( ps2_clk_pad_oe ),
+ .ps2_clk_in ( ps2_clk_pad_in ),
+
+ .txd_pad_out ( txd_pad_out ),
+ .rxd_pad_in ( rxd_pad_in ),
+ .cts_pad_in ( cts_pad_in ),
+ .rts_pad_out ( rts_pad_out ),
+
+ .vgared_pad_out (vgared_pad_out[2:0] ),
+ .vgagreen_pad_out(vgagreen_pad_out[2:0] ),
+ .vgablue_pad_out ( vgablue_pad_out[1:0] ),
+
+ .hsync_n_pad_out ( hsync_pad_out ),
+ .vsync_n_pad_out ( vsync_pad_out )
+
+
+);
+
+
+
\ No newline at end of file
trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/core.v
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/Makefile
===================================================================
--- trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/Makefile (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/Makefile (revision 44)
@@ -0,0 +1,4 @@
+include ../../../../bin/Makefile.root
+include ./target/Makefile.brd
+Design=X6502_kim_2
+
trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/Makefile
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/def_file
===================================================================
--- trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/def_file (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/def_file (revision 44)
@@ -0,0 +1,23 @@
+`define SYNTHESIS
+`define ROM_FILE "../../../../../../../projects/Mos6502/sw/table_tim1/table_tim1.abs16"
+`define ROM_WORDS 128
+`define ROM_ADD 7
+
+`define PROG_ROM_FILE "../../../../../../../projects/Mos6502/sw/kim_2/kim_2.abs16"
+`define PROG_ROM_WORDS 2048
+`define PROG_ROM_ADD 11
+
+
+
+`define MODULE_NAME Nexys2_X6502_kim_2
+
+`define STARTUP "../../../../../sw/vga_startup_screen/vga_startup_screen.abs"
+`define FONT "../../../../../sw/vga_font/vga_font.abs"
+
+
+`define JTAG_USER1_WIDTH 8
+`define JTAG_USER1_RESET 8'h12
+`define JTAG_USER1_UPDR 1'b1
+`define JTAG_USER2_WIDTH 16
+`define JTAG_USER2_RESET 16'h0000
+`define JTAG_USER2_UPDR 1'b0
trunk/projects/Mos6502/ip/T6502/syn/Nexys2_kim_2/def_file
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/bsdl/xc3s1200e_fg320_1532.bsd
===================================================================
--- trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/bsdl/xc3s1200e_fg320_1532.bsd (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/bsdl/xc3s1200e_fg320_1532.bsd (revision 44)
@@ -0,0 +1,1591 @@
+--$ XILINX$RCSfile: xc3s1200e_fg320_1532.bsd,v $
+--$ XILINX$Revision: 1.2.124.1 $
+
+--###################################################################
+-- WARNING !!!! .. This is a 1532 PROTOTYPE BDSL file.
+--###################################################################
+--
+-- It should not be be used in place of, or along side of 1149.1 bsdl files.
+--
+-- This file conforms to the unapproved IEEE Standard 1532 BSDL draft
+-- Standard. It may not function as expected with IEEE 1149.1 BSDL
+-- and is subject to change pending the ratification of the 1532 Standard
+-- by the IEEE. When denoted as FINAL, it has been verified
+-- syntactically, and against hardware.
+--
+-- Prototype 1532 BSDL file for device XC3S1200E, package FG320
+-- Xilinx, Inc. $State: Exp $ $Date: 2008/07/07 22:23:21 $
+--
+-- Generated by BSDLnet bsdlnet Version 1.40
+------------------------------------------------------------------------
+-- Modification History
+-- | Generated on 05/28/08
+-- | CR # 471899
+-- | Details - Initial Release using BSDLnet.
+-- | Added 'attribute COMPLIANCE_PATTERNS' & changed boundary
+-- | register attribute to internal for PROG_B & PUDC_B.
+------------------------------------------------------------------------
+--
+-- createBSDL template $RCSfile: xc3s1200e_fg320_1532.bsd,v $ $Revision: 1.2.124.1 $ $Date: 2008/07/07 22:23:21 $
+--
+--###################################################################
+--
+--
+-- For technical support, contact Xilinx on the web at:
+--
+-- http://support.xilinx.com
+--
+-- Technical support can also take place via email or phone at:
+--
+-- North America 1-800-255-7778 hotline@xilinx.com
+-- United Kingdom (44) 1932 820821 ukhelp@xilinx.com
+-- France (33) 1 3463 0100 frhelp@xilinx.com
+-- Germany (49) 89 991 54930 dlhelp@xilinx.com
+-- Japan (81) 3-3297-9163 jhotline@xilinx.com
+--
+--
+-- This BSDL file reflects the pre-configuration JTAG behavior. To reflect
+-- the post-configuration JTAG behavior (if any), edit this file as described
+-- below. Many of these changes are demonstrated by commented-out template
+-- lines preceeding the lines they would replace:
+--
+-- 1. Set disable result of all pads as configured.
+-- 2. Set safe state of boundary cells as necessary.
+-- 3. Rename entity if necessary to avoid name collisions.
+-- 4. Modify USERCODE value in USERCODE_REGISTER declaration.
+--
+--###################################################################--
+
+----------------------------------
+
+-- BSDL File for 1532 Standard.
+
+----------------------------------
+
+entity XC3S1200E_FG320 is
+
+-- Generic Parameter
+
+generic (PHYSICAL_PIN_MAP : string := "FG320" );
+
+-- Logical Port Description
+
+port (
+ A10: inout bit; -- PAD40
+ A11: inout bit; -- PAD49
+ A12: inout bit; -- PAD54
+ A13: inout bit; -- PAD59
+ A14: inout bit; -- PAD62
+ A16: inout bit; -- PAD76
+ A4: inout bit; -- PAD5
+ A6: inout bit; -- PAD14
+ A7: inout bit; -- PAD20
+ A8: inout bit; -- PAD28
+ B10: inout bit; -- PAD41
+ B11: inout bit; -- PAD42
+ B13: inout bit; -- PAD58
+ B14: inout bit; -- PAD63
+ B16: inout bit; -- PAD77
+ B4: inout bit; -- PAD4
+ B6: inout bit; -- PAD15
+ C1: inout bit; -- PAD304
+ C11: inout bit; -- PAD48
+ C14: inout bit; -- PAD72
+ C17: inout bit; -- PAD80
+ C18: inout bit; -- PAD81
+ C2: inout bit; -- PAD303
+ C3: inout bit; -- PAD2
+ C4: inout bit; -- PAD6
+ C5: inout bit; -- PAD8
+ C7: inout bit; -- PAD27
+ C9: inout bit; -- PAD37
+ D1: inout bit; -- PAD302
+ D10: inout bit; -- PAD44
+ D11: inout bit; -- PAD47
+ D13: inout bit; -- PAD57
+ D14: inout bit; -- PAD73
+ D16: inout bit; -- PAD82
+ D17: inout bit; -- PAD83
+ D2: inout bit; -- PAD301
+ D4: inout bit; -- PAD298
+ D5: inout bit; -- PAD7
+ D6: inout bit; -- PAD12
+ D7: inout bit; -- PAD26
+ D9: inout bit; -- PAD36
+ DONE: inout bit;
+ E1: inout bit; -- PAD296
+ E10: inout bit; -- PAD43
+ E11: inout bit; -- PAD51
+ E12: inout bit; -- PAD55
+ E13: inout bit; -- PAD71
+ E15: inout bit; -- PAD85
+ E16: inout bit; -- PAD84
+ E2: inout bit; -- PAD297
+ E3: inout bit; -- PAD291
+ E4: inout bit; -- PAD292
+ E6: inout bit; -- PAD11
+ E7: inout bit; -- PAD21
+ E8: inout bit; -- PAD30
+ E9: inout bit; -- PAD34
+ F1: inout bit; -- PAD287
+ F11: inout bit; -- PAD50
+ F12: inout bit; -- PAD56
+ F14: inout bit; -- PAD92
+ F15: inout bit; -- PAD93
+ F17: inout bit; -- PAD99
+ F18: inout bit; -- PAD100
+ F2: inout bit; -- PAD286
+ F7: inout bit; -- PAD22
+ F8: inout bit; -- PAD29
+ F9: inout bit; -- PAD33
+ G13: inout bit; -- PAD97
+ G14: inout bit; -- PAD98
+ G15: inout bit; -- PAD103
+ G16: inout bit; -- PAD102
+ G3: inout bit; -- PAD285
+ G4: inout bit; -- PAD284
+ G5: inout bit; -- PAD281
+ G6: inout bit; -- PAD282
+ G9: inout bit; -- PAD35
+ GND: linkage bit_vector (1 to 28);
+ H1: inout bit; -- PAD274
+ H14: inout bit; -- PAD105
+ H15: inout bit; -- PAD104
+ H16: inout bit; -- PAD108
+ H17: inout bit; -- PAD107
+ H2: inout bit; -- PAD275
+ H3: inout bit; -- PAD276
+ H4: inout bit; -- PAD277
+ H5: inout bit; -- PAD279
+ H6: inout bit; -- PAD280
+ IPAD10: in bit;
+ IPAD101: in bit;
+ IPAD106: in bit;
+ IPAD111: in bit;
+ IPAD116: in bit;
+ IPAD121: in bit;
+ IPAD126: in bit;
+ IPAD131: in bit;
+ IPAD136: in bit;
+ IPAD141: in bit;
+ IPAD148: in bit;
+ IPAD155: in bit;
+ IPAD161: in bit;
+ IPAD162: in bit;
+ IPAD183: in bit;
+ IPAD184: in bit;
+ IPAD190: in bit;
+ IPAD191: in bit;
+ IPAD197: in bit;
+ IPAD198: in bit;
+ IPAD204: in bit;
+ IPAD205: in bit;
+ IPAD226: in bit;
+ IPAD227: in bit;
+ IPAD230: in bit;
+ IPAD231: in bit;
+ IPAD238: in bit;
+ IPAD243: in bit;
+ IPAD248: in bit;
+ IPAD253: in bit;
+ IPAD258: in bit;
+ IPAD263: in bit;
+ IPAD268: in bit;
+ IPAD273: in bit;
+ IPAD278: in bit;
+ IPAD283: in bit;
+ IPAD288: in bit;
+ IPAD293: in bit;
+ IPAD3: in bit;
+ IPAD300: in bit;
+ IPAD31: in bit;
+ IPAD32: in bit;
+ IPAD38: in bit;
+ IPAD39: in bit;
+ IPAD45: in bit;
+ IPAD46: in bit;
+ IPAD52: in bit;
+ IPAD53: in bit;
+ IPAD74: in bit;
+ IPAD75: in bit;
+ IPAD78: in bit;
+ IPAD79: in bit;
+ IPAD86: in bit;
+ IPAD9: in bit;
+ IPAD91: in bit;
+ IPAD96: in bit;
+ J1: inout bit; -- PAD270
+ J12: inout bit; -- PAD110
+ J13: inout bit; -- PAD109
+ J14: inout bit; -- PAD112
+ J15: inout bit; -- PAD113
+ J16: inout bit; -- PAD114
+ J17: inout bit; -- PAD115
+ J2: inout bit; -- PAD269
+ J4: inout bit; -- PAD271
+ J5: inout bit; -- PAD272
+ K12: inout bit; -- PAD119
+ K13: inout bit; -- PAD120
+ K14: inout bit; -- PAD117
+ K15: inout bit; -- PAD118
+ K3: inout bit; -- PAD267
+ K4: inout bit; -- PAD266
+ K5: inout bit; -- PAD264
+ K6: inout bit; -- PAD265
+ L1: inout bit; -- PAD262
+ L15: inout bit; -- PAD124
+ L16: inout bit; -- PAD125
+ L17: inout bit; -- PAD122
+ L18: inout bit; -- PAD123
+ L2: inout bit; -- PAD261
+ L3: inout bit; -- PAD260
+ L4: inout bit; -- PAD259
+ L5: inout bit; -- PAD256
+ L6: inout bit; -- PAD257
+ M10: inout bit; -- PAD186
+ M13: inout bit; -- PAD134
+ M14: inout bit; -- PAD135
+ M15: inout bit; -- PAD130
+ M16: inout bit; -- PAD129
+ M18: inout bit; -- PAD127
+ M3: inout bit; -- PAD254
+ M4: inout bit; -- PAD255
+ M5: inout bit; -- PAD252
+ M6: inout bit; -- PAD251
+ M9: inout bit; -- PAD195
+ N10: inout bit; -- PAD185
+ N11: inout bit; -- PAD181
+ N12: inout bit; -- PAD171
+ N14: inout bit; -- PAD139
+ N15: inout bit; -- PAD140
+ N18: inout bit; -- PAD128
+ N4: inout bit; -- PAD250
+ N5: inout bit; -- PAD249
+ N7: inout bit; -- PAD208
+ N8: inout bit; -- PAD202
+ N9: inout bit; -- PAD196
+ P1: inout bit; -- PAD244
+ P10: inout bit; -- PAD188
+ P11: inout bit; -- PAD182
+ P12: inout bit; -- PAD170
+ P13: inout bit; -- PAD167
+ P16: inout bit; -- PAD142
+ P17: inout bit; -- PAD133
+ P18: inout bit; -- PAD132
+ P2: inout bit; -- PAD245
+ P3: inout bit; -- PAD242
+ P4: inout bit; -- PAD241
+ P6: inout bit; -- PAD214
+ P7: inout bit; -- PAD207
+ P8: inout bit; -- PAD203
+ P9: inout bit; -- PAD201
+ PROG_B: in bit;
+ PUDC_B: in bit; -- PAD1
+ R10: inout bit; -- PAD189
+ R11: inout bit; -- PAD180
+ R12: inout bit; -- PAD173
+ R13: inout bit; -- PAD166
+ R14: inout bit; -- PAD159
+ R15: inout bit; -- PAD147
+ R16: inout bit; -- PAD146
+ R18: inout bit; -- PAD150
+ R2: inout bit; -- PAD234
+ R3: inout bit; -- PAD235
+ R5: inout bit; -- PAD222
+ R6: inout bit; -- PAD215
+ R8: inout bit; -- PAD200
+ R9: inout bit; -- PAD194
+ T1: inout bit; -- PAD232
+ T12: inout bit; -- PAD174
+ T14: inout bit; -- PAD160
+ T15: inout bit; -- PAD158
+ T16: inout bit; -- PAD154
+ T17: inout bit; -- PAD151
+ T18: inout bit; -- PAD149
+ T2: inout bit; -- PAD233
+ T3: inout bit; -- PAD228
+ T4: inout bit; -- PAD224
+ T5: inout bit; -- PAD221
+ T8: inout bit; -- PAD199
+ TCK: in bit;
+ TDI: in bit;
+ TDO: out bit;
+ TMS: in bit;
+ U13: inout bit; -- PAD172
+ U15: inout bit; -- PAD156
+ U16: inout bit; -- PAD153
+ U18: inout bit; -- PAD152
+ U3: inout bit; -- PAD229
+ U4: inout bit; -- PAD225
+ U5: inout bit; -- PAD223
+ U6: inout bit; -- PAD209
+ U9: inout bit; -- PAD193
+ V11: inout bit; -- PAD187
+ V12: inout bit; -- PAD179
+ V13: inout bit; -- PAD178
+ V15: inout bit; -- PAD157
+ V5: inout bit; -- PAD211
+ V6: inout bit; -- PAD210
+ V7: inout bit; -- PAD206
+ V9: inout bit; -- PAD192
+ VCCAUX: linkage bit_vector (1 to 8);
+ VCCINT: linkage bit_vector (1 to 8);
+ VCCO_0: linkage bit_vector (1 to 5);
+ VCCO_1: linkage bit_vector (1 to 5);
+ VCCO_2: linkage bit_vector (1 to 5);
+ VCCO_3: linkage bit_vector (1 to 5)
+); --end port list
+
+-- Use Statements
+
+use STD_1149_1_2001.all;
+use STD_1532_2002.all;
+
+-- Component Conformance Statement(s)
+
+attribute COMPONENT_CONFORMANCE of XC3S1200E_FG320 : entity is
+ "STD_1149_1_2001";
+
+-- Device Package Pin Mappings
+
+attribute PIN_MAP of XC3S1200E_FG320 : entity is PHYSICAL_PIN_MAP;
+
+constant FG320: PIN_MAP_STRING:=
+ "A10:A10," &
+ "A11:A11," &
+ "A12:A12," &
+ "A13:A13," &
+ "A14:A14," &
+ "A16:A16," &
+ "A4:A4," &
+ "A6:A6," &
+ "A7:A7," &
+ "A8:A8," &
+ "B10:B10," &
+ "B11:B11," &
+ "B13:B13," &
+ "B14:B14," &
+ "B16:B16," &
+ "B4:B4," &
+ "B6:B6," &
+ "C1:C1," &
+ "C11:C11," &
+ "C14:C14," &
+ "C17:C17," &
+ "C18:C18," &
+ "C2:C2," &
+ "C3:C3," &
+ "C4:C4," &
+ "C5:C5," &
+ "C7:C7," &
+ "C9:C9," &
+ "D1:D1," &
+ "D10:D10," &
+ "D11:D11," &
+ "D13:D13," &
+ "D14:D14," &
+ "D16:D16," &
+ "D17:D17," &
+ "D2:D2," &
+ "D4:D4," &
+ "D5:D5," &
+ "D6:D6," &
+ "D7:D7," &
+ "D9:D9," &
+ "DONE:V17," &
+ "E1:E1," &
+ "E10:E10," &
+ "E11:E11," &
+ "E12:E12," &
+ "E13:E13," &
+ "E15:E15," &
+ "E16:E16," &
+ "E2:E2," &
+ "E3:E3," &
+ "E4:E4," &
+ "E6:E6," &
+ "E7:E7," &
+ "E8:E8," &
+ "E9:E9," &
+ "F1:F1," &
+ "F11:F11," &
+ "F12:F12," &
+ "F14:F14," &
+ "F15:F15," &
+ "F17:F17," &
+ "F18:F18," &
+ "F2:F2," &
+ "F7:F7," &
+ "F8:F8," &
+ "F9:F9," &
+ "G13:G13," &
+ "G14:G14," &
+ "G15:G15," &
+ "G16:G16," &
+ "G3:G3," &
+ "G4:G4," &
+ "G5:G5," &
+ "G6:G6," &
+ "G9:G9," &
+ "GND:(A1,A18,B2,B17,C10,G7,G12,H8,H9,H10," &
+ "H11,J3,J8,J11,K8,K11,K16,L8,L9,L10," &
+ "L11,M7,M12,T9,U2,U17,V1,V18)," &
+ "H1:H1," &
+ "H14:H14," &
+ "H15:H15," &
+ "H16:H16," &
+ "H17:H17," &
+ "H2:H2," &
+ "H3:H3," &
+ "H4:H4," &
+ "H5:H5," &
+ "H6:H6," &
+ "IPAD10:A5," &
+ "IPAD101:H13," &
+ "IPAD106:G18," &
+ "IPAD111:H18," &
+ "IPAD116:K18," &
+ "IPAD121:K17," &
+ "IPAD126:L13," &
+ "IPAD131:L14," &
+ "IPAD136:N17," &
+ "IPAD141:P15," &
+ "IPAD148:R17," &
+ "IPAD155:V16," &
+ "IPAD161:U14," &
+ "IPAD162:V14," &
+ "IPAD183:U11," &
+ "IPAD184:T11," &
+ "IPAD190:T10," &
+ "IPAD191:U10," &
+ "IPAD197:V8," &
+ "IPAD198:U8," &
+ "IPAD204:R7," &
+ "IPAD205:T7," &
+ "IPAD226:V3," &
+ "IPAD227:V4," &
+ "IPAD230:V2," &
+ "IPAD231:U1," &
+ "IPAD238:R1," &
+ "IPAD243:R4," &
+ "IPAD248:N2," &
+ "IPAD253:N1," &
+ "IPAD258:M1," &
+ "IPAD263:K7," &
+ "IPAD268:K2," &
+ "IPAD273:J6," &
+ "IPAD278:J7," &
+ "IPAD283:G1," &
+ "IPAD288:F5," &
+ "IPAD293:F4," &
+ "IPAD3:A3," &
+ "IPAD300:D3," &
+ "IPAD31:D8," &
+ "IPAD32:C8," &
+ "IPAD38:B9," &
+ "IPAD39:B8," &
+ "IPAD45:G10," &
+ "IPAD46:F10," &
+ "IPAD52:D12," &
+ "IPAD53:C12," &
+ "IPAD74:A15," &
+ "IPAD75:B15," &
+ "IPAD78:C15," &
+ "IPAD79:B18," &
+ "IPAD86:D18," &
+ "IPAD9:B5," &
+ "IPAD91:E17," &
+ "IPAD96:E18," &
+ "J1:J1," &
+ "J12:J12," &
+ "J13:J13," &
+ "J14:J14," &
+ "J15:J15," &
+ "J16:J16," &
+ "J17:J17," &
+ "J2:J2," &
+ "J4:J4," &
+ "J5:J5," &
+ "K12:K12," &
+ "K13:K13," &
+ "K14:K14," &
+ "K15:K15," &
+ "K3:K3," &
+ "K4:K4," &
+ "K5:K5," &
+ "K6:K6," &
+ "L1:L1," &
+ "L15:L15," &
+ "L16:L16," &
+ "L17:L17," &
+ "L18:L18," &
+ "L2:L2," &
+ "L3:L3," &
+ "L4:L4," &
+ "L5:L5," &
+ "L6:L6," &
+ "M10:M10," &
+ "M13:M13," &
+ "M14:M14," &
+ "M15:M15," &
+ "M16:M16," &
+ "M18:M18," &
+ "M3:M3," &
+ "M4:M4," &
+ "M5:M5," &
+ "M6:M6," &
+ "M9:M9," &
+ "N10:N10," &
+ "N11:N11," &
+ "N12:N12," &
+ "N14:N14," &
+ "N15:N15," &
+ "N18:N18," &
+ "N4:N4," &
+ "N5:N5," &
+ "N7:N7," &
+ "N8:N8," &
+ "N9:N9," &
+ "P1:P1," &
+ "P10:P10," &
+ "P11:P11," &
+ "P12:P12," &
+ "P13:P13," &
+ "P16:P16," &
+ "P17:P17," &
+ "P18:P18," &
+ "P2:P2," &
+ "P3:P3," &
+ "P4:P4," &
+ "P6:P6," &
+ "P7:P7," &
+ "P8:P8," &
+ "P9:P9," &
+ "PROG_B:B1," &
+ "PUDC_B:B3," &
+ "R10:R10," &
+ "R11:R11," &
+ "R12:R12," &
+ "R13:R13," &
+ "R14:R14," &
+ "R15:R15," &
+ "R16:R16," &
+ "R18:R18," &
+ "R2:R2," &
+ "R3:R3," &
+ "R5:R5," &
+ "R6:R6," &
+ "R8:R8," &
+ "R9:R9," &
+ "T1:T1," &
+ "T12:T12," &
+ "T14:T14," &
+ "T15:T15," &
+ "T16:T16," &
+ "T17:T17," &
+ "T18:T18," &
+ "T2:T2," &
+ "T3:T3," &
+ "T4:T4," &
+ "T5:T5," &
+ "T8:T8," &
+ "TCK:A17," &
+ "TDI:A2," &
+ "TDO:C16," &
+ "TMS:D15," &
+ "U13:U13," &
+ "U15:U15," &
+ "U16:U16," &
+ "U18:U18," &
+ "U3:U3," &
+ "U4:U4," &
+ "U5:U5," &
+ "U6:U6," &
+ "U9:U9," &
+ "V11:V11," &
+ "V12:V12," &
+ "V13:V13," &
+ "V15:V15," &
+ "V5:V5," &
+ "V6:V6," &
+ "V7:V7," &
+ "V9:V9," &
+ "VCCAUX:(B7,B12,G2,G17,M2,M17,U7,U12)," &
+ "VCCINT:(E5,E14,F6,F13,N6,N13,P5,P14)," &
+ "VCCO_0:(A9,C6,C13,G8,G11)," &
+ "VCCO_1:(F16,H12,J18,L12,N16)," &
+ "VCCO_2:(M8,M11,T6,T13,V10)," &
+ "VCCO_3:(F3,H7,K1,L7,N3)";
+
+
+-- Scan Port Identification
+
+attribute TAP_SCAN_OUT of TDO : signal is true;
+attribute TAP_SCAN_IN of TDI : signal is true;
+attribute TAP_SCAN_CLOCK of TCK : signal is (10.0e6, both);
+attribute TAP_SCAN_MODE of TMS : signal is true;
+
+-- Compliance-Enable Description
+
+attribute COMPLIANCE_PATTERNS of XC3S1200E_FG320 : entity is
+ "(PROG_B, PUDC_B) (10)";
+
+-- Instruction Register Description
+
+attribute INSTRUCTION_LENGTH of XC3S1200E_FG320 : entity is 6;
+
+attribute INSTRUCTION_OPCODE of XC3S1200E_FG320 : entity is
+
+ "EXTEST (001111)," &
+ "SAMPLE (000001)," &
+ "PRELOAD (000001)," & -- Same as SAMPLE
+ "USER1 (000010)," & -- Not available until after configuration
+ "USER2 (000011)," & -- Not available until after configuration
+ "CFG_OUT (000100)," & -- Not available during configuration with another mode.
+ "CFG_IN (000101)," & -- Not available during configuration with another mode.
+ "INTEST (000111)," &
+ "USERCODE (001000)," &
+ "IDCODE (001001)," &
+ "HIGHZ (001010)," &
+ "JPROGRAM (001011)," & -- Not available during configuration with another mode.
+ "JSTART (001100)," & -- Not available during configuration with another mode.
+ "JSHUTDOWN (001101)," & -- Not available during configuration with another mode.
+ "BYPASS (111111)," &
+ "ISC_ENABLE (010000)," &
+ "ISC_PROGRAM (010001)," &
+ "ISC_NOOP (010100)," &
+ "ISC_READ (010101)," &
+ "ISC_DISABLE (010110)";
+
+attribute INSTRUCTION_CAPTURE of XC3S1200E_FG320 : entity is
+-- Bit 5 is 1 when DONE is released (part of startup sequence)
+-- Bit 4 is 1 if house-cleaning is complete
+-- Bit 3 is ISC_Enabled
+-- Bit 2 is ISC_Done
+ "XXXX01" ;
+
+attribute INSTRUCTION_PRIVATE of XC3S1200E_FG320 : entity is
+ "USER1," &
+ "USER2," &
+ "CFG_OUT," &
+ "CFG_IN," &
+ "JPROGRAM," &
+ "JSTART," &
+ "JSHUTDOWN," &
+ "ISC_ENABLE," &
+ "ISC_PROGRAM," &
+ "ISC_NOOP," &
+ "ISC_READ," &
+ "ISC_DISABLE";
+
+-- Optional Register Description
+
+attribute IDCODE_REGISTER of XC3S1200E_FG320 : entity is "XXXX" & -- version
+ "0001110" & -- family
+ "000101110" & -- array size
+ "00001001001" & -- manufacturer
+ "1"; -- required by 1149.1
+
+
+attribute USERCODE_REGISTER of XC3S1200E_FG320 : entity is "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX";
+
+-- Register Access Description
+
+attribute REGISTER_ACCESS of XC3S1200E_FG320 : entity is
+ "TEST1[8] (USER1)," &
+ "TEST2[16] (USER2)," &
+ "DEVICE_ID (USERCODE,IDCODE)," &
+ "BYPASS (BYPASS,HIGHZ,JPROGRAM,JSTART,JSHUTDOWN)," &
+ "CFG_DATA[3838752] (CFG_IN)," &
+ "ISC_PDATA[16] (ISC_PROGRAM),"&
+ "ISC_RDATA[16] (ISC_READ),"&
+ "ISC_DEFAULT[5] (ISC_NOOP)," &
+ "ISC_CONFIG[5] (ISC_ENABLE,ISC_DISABLE)," &
+ "BOUNDARY (EXTEST, SAMPLE, PRELOAD, INTEST)";
+
+-- Boundary-Scan Register Description
+
+attribute BOUNDARY_LENGTH of XC3S1200E_FG320 : entity is 772;
+
+attribute BOUNDARY_REGISTER of XC3S1200E_FG320 : entity is
+-- cellnum (type, port, function, safe[, ccell, disval, disrslt])
+ " 771 (BC_2, IPAD79, input, X)," &
+ " 770 (BC_2, C17, input, X)," & -- PAD80
+ " 769 (BC_2, C17, output3, X, 768, 1, PULL1)," & -- PAD80
+ " 768 (BC_2, *, controlr, 1)," &
+ " 767 (BC_2, C18, input, X)," & -- PAD81
+ " 766 (BC_2, C18, output3, X, 765, 1, PULL1)," & -- PAD81
+ " 765 (BC_2, *, controlr, 1)," &
+ " 764 (BC_2, D16, input, X)," & -- PAD82
+ " 763 (BC_2, D16, output3, X, 762, 1, PULL1)," & -- PAD82
+ " 762 (BC_2, *, controlr, 1)," &
+ " 761 (BC_2, D17, input, X)," & -- PAD83
+ " 760 (BC_2, D17, output3, X, 759, 1, PULL1)," & -- PAD83
+ " 759 (BC_2, *, controlr, 1)," &
+ " 758 (BC_2, E16, input, X)," & -- PAD84
+ " 757 (BC_2, E16, output3, X, 756, 1, PULL1)," & -- PAD84
+ " 756 (BC_2, *, controlr, 1)," &
+ " 755 (BC_2, E15, input, X)," & -- PAD85
+ " 754 (BC_2, E15, output3, X, 753, 1, PULL1)," & -- PAD85
+ " 753 (BC_2, *, controlr, 1)," &
+ " 752 (BC_2, IPAD86, input, X)," &
+ " 751 (BC_2, *, internal, X)," & -- PAD87.I
+ " 750 (BC_2, *, internal, X)," & -- PAD87.O
+ " 749 (BC_2, *, internal, 1)," & -- PAD87.T
+ " 748 (BC_2, *, internal, X)," & -- PAD88.I
+ " 747 (BC_2, *, internal, X)," & -- PAD88.O
+ " 746 (BC_2, *, internal, 1)," & -- PAD88.T
+ " 745 (BC_2, *, internal, X)," & -- PAD89.I
+ " 744 (BC_2, *, internal, X)," & -- PAD89.O
+ " 743 (BC_2, *, internal, 1)," & -- PAD89.T
+ " 742 (BC_2, *, internal, X)," & -- PAD90.I
+ " 741 (BC_2, *, internal, X)," & -- PAD90.O
+ " 740 (BC_2, *, internal, 1)," & -- PAD90.T
+ " 739 (BC_2, IPAD91, input, X)," &
+ " 738 (BC_2, F14, input, X)," & -- PAD92
+ " 737 (BC_2, F14, output3, X, 736, 1, PULL1)," & -- PAD92
+ " 736 (BC_2, *, controlr, 1)," &
+ " 735 (BC_2, F15, input, X)," & -- PAD93
+ " 734 (BC_2, F15, output3, X, 733, 1, PULL1)," & -- PAD93
+ " 733 (BC_2, *, controlr, 1)," &
+ " 732 (BC_2, *, internal, X)," & -- PAD94.I
+ " 731 (BC_2, *, internal, X)," & -- PAD94.O
+ " 730 (BC_2, *, internal, 1)," & -- PAD94.T
+ " 729 (BC_2, *, internal, X)," & -- PAD95.I
+ " 728 (BC_2, *, internal, X)," & -- PAD95.O
+ " 727 (BC_2, *, internal, 1)," & -- PAD95.T
+ " 726 (BC_2, IPAD96, input, X)," &
+ " 725 (BC_2, G13, input, X)," & -- PAD97
+ " 724 (BC_2, G13, output3, X, 723, 1, PULL1)," & -- PAD97
+ " 723 (BC_2, *, controlr, 1)," &
+ " 722 (BC_2, G14, input, X)," & -- PAD98
+ " 721 (BC_2, G14, output3, X, 720, 1, PULL1)," & -- PAD98
+ " 720 (BC_2, *, controlr, 1)," &
+ " 719 (BC_2, F17, input, X)," & -- PAD99
+ " 718 (BC_2, F17, output3, X, 717, 1, PULL1)," & -- PAD99
+ " 717 (BC_2, *, controlr, 1)," &
+ " 716 (BC_2, F18, input, X)," & -- PAD100
+ " 715 (BC_2, F18, output3, X, 714, 1, PULL1)," & -- PAD100
+ " 714 (BC_2, *, controlr, 1)," &
+ " 713 (BC_2, IPAD101, input, X)," &
+ " 712 (BC_2, G16, input, X)," & -- PAD102
+ " 711 (BC_2, G16, output3, X, 710, 1, PULL1)," & -- PAD102
+ " 710 (BC_2, *, controlr, 1)," &
+ " 709 (BC_2, G15, input, X)," & -- PAD103
+ " 708 (BC_2, G15, output3, X, 707, 1, PULL1)," & -- PAD103
+ " 707 (BC_2, *, controlr, 1)," &
+ " 706 (BC_2, H15, input, X)," & -- PAD104
+ " 705 (BC_2, H15, output3, X, 704, 1, PULL1)," & -- PAD104
+ " 704 (BC_2, *, controlr, 1)," &
+ " 703 (BC_2, H14, input, X)," & -- PAD105
+ " 702 (BC_2, H14, output3, X, 701, 1, PULL1)," & -- PAD105
+ " 701 (BC_2, *, controlr, 1)," &
+ " 700 (BC_2, IPAD106, input, X)," &
+ " 699 (BC_2, H17, input, X)," & -- PAD107
+ " 698 (BC_2, H17, output3, X, 697, 1, PULL1)," & -- PAD107
+ " 697 (BC_2, *, controlr, 1)," &
+ " 696 (BC_2, H16, input, X)," & -- PAD108
+ " 695 (BC_2, H16, output3, X, 694, 1, PULL1)," & -- PAD108
+ " 694 (BC_2, *, controlr, 1)," &
+ " 693 (BC_2, J13, input, X)," & -- PAD109
+ " 692 (BC_2, J13, output3, X, 691, 1, PULL1)," & -- PAD109
+ " 691 (BC_2, *, controlr, 1)," &
+ " 690 (BC_2, J12, input, X)," & -- PAD110
+ " 689 (BC_2, J12, output3, X, 688, 1, PULL1)," & -- PAD110
+ " 688 (BC_2, *, controlr, 1)," &
+ " 687 (BC_2, IPAD111, input, X)," &
+ " 686 (BC_2, J14, input, X)," & -- PAD112
+ " 685 (BC_2, J14, output3, X, 684, 1, PULL1)," & -- PAD112
+ " 684 (BC_2, *, controlr, 1)," &
+ " 683 (BC_2, J15, input, X)," & -- PAD113
+ " 682 (BC_2, J15, output3, X, 681, 1, PULL1)," & -- PAD113
+ " 681 (BC_2, *, controlr, 1)," &
+ " 680 (BC_2, J16, input, X)," & -- PAD114
+ " 679 (BC_2, J16, output3, X, 678, 1, PULL1)," & -- PAD114
+ " 678 (BC_2, *, controlr, 1)," &
+ " 677 (BC_2, J17, input, X)," & -- PAD115
+ " 676 (BC_2, J17, output3, X, 675, 1, PULL1)," & -- PAD115
+ " 675 (BC_2, *, controlr, 1)," &
+ " 674 (BC_2, IPAD116, input, X)," &
+ " 673 (BC_2, K14, input, X)," & -- PAD117
+ " 672 (BC_2, K14, output3, X, 671, 1, PULL1)," & -- PAD117
+ " 671 (BC_2, *, controlr, 1)," &
+ " 670 (BC_2, K15, input, X)," & -- PAD118
+ " 669 (BC_2, K15, output3, X, 668, 1, PULL1)," & -- PAD118
+ " 668 (BC_2, *, controlr, 1)," &
+ " 667 (BC_2, K12, input, X)," & -- PAD119
+ " 666 (BC_2, K12, output3, X, 665, 1, PULL1)," & -- PAD119
+ " 665 (BC_2, *, controlr, 1)," &
+ " 664 (BC_2, K13, input, X)," & -- PAD120
+ " 663 (BC_2, K13, output3, X, 662, 1, PULL1)," & -- PAD120
+ " 662 (BC_2, *, controlr, 1)," &
+ " 661 (BC_2, IPAD121, input, X)," &
+ " 660 (BC_2, L17, input, X)," & -- PAD122
+ " 659 (BC_2, L17, output3, X, 658, 1, PULL1)," & -- PAD122
+ " 658 (BC_2, *, controlr, 1)," &
+ " 657 (BC_2, L18, input, X)," & -- PAD123
+ " 656 (BC_2, L18, output3, X, 655, 1, PULL1)," & -- PAD123
+ " 655 (BC_2, *, controlr, 1)," &
+ " 654 (BC_2, L15, input, X)," & -- PAD124
+ " 653 (BC_2, L15, output3, X, 652, 1, PULL1)," & -- PAD124
+ " 652 (BC_2, *, controlr, 1)," &
+ " 651 (BC_2, L16, input, X)," & -- PAD125
+ " 650 (BC_2, L16, output3, X, 649, 1, PULL1)," & -- PAD125
+ " 649 (BC_2, *, controlr, 1)," &
+ " 648 (BC_2, IPAD126, input, X)," &
+ " 647 (BC_2, M18, input, X)," & -- PAD127
+ " 646 (BC_2, M18, output3, X, 645, 1, PULL1)," & -- PAD127
+ " 645 (BC_2, *, controlr, 1)," &
+ " 644 (BC_2, N18, input, X)," & -- PAD128
+ " 643 (BC_2, N18, output3, X, 642, 1, PULL1)," & -- PAD128
+ " 642 (BC_2, *, controlr, 1)," &
+ " 641 (BC_2, M16, input, X)," & -- PAD129
+ " 640 (BC_2, M16, output3, X, 639, 1, PULL1)," & -- PAD129
+ " 639 (BC_2, *, controlr, 1)," &
+ " 638 (BC_2, M15, input, X)," & -- PAD130
+ " 637 (BC_2, M15, output3, X, 636, 1, PULL1)," & -- PAD130
+ " 636 (BC_2, *, controlr, 1)," &
+ " 635 (BC_2, IPAD131, input, X)," &
+ " 634 (BC_2, P18, input, X)," & -- PAD132
+ " 633 (BC_2, P18, output3, X, 632, 1, PULL1)," & -- PAD132
+ " 632 (BC_2, *, controlr, 1)," &
+ " 631 (BC_2, P17, input, X)," & -- PAD133
+ " 630 (BC_2, P17, output3, X, 629, 1, PULL1)," & -- PAD133
+ " 629 (BC_2, *, controlr, 1)," &
+ " 628 (BC_2, M13, input, X)," & -- PAD134
+ " 627 (BC_2, M13, output3, X, 626, 1, PULL1)," & -- PAD134
+ " 626 (BC_2, *, controlr, 1)," &
+ " 625 (BC_2, M14, input, X)," & -- PAD135
+ " 624 (BC_2, M14, output3, X, 623, 1, PULL1)," & -- PAD135
+ " 623 (BC_2, *, controlr, 1)," &
+ " 622 (BC_2, IPAD136, input, X)," &
+ " 621 (BC_2, *, internal, X)," & -- PAD137.I
+ " 620 (BC_2, *, internal, X)," & -- PAD137.O
+ " 619 (BC_2, *, internal, 1)," & -- PAD137.T
+ " 618 (BC_2, *, internal, X)," & -- PAD138.I
+ " 617 (BC_2, *, internal, X)," & -- PAD138.O
+ " 616 (BC_2, *, internal, 1)," & -- PAD138.T
+ " 615 (BC_2, N14, input, X)," & -- PAD139
+ " 614 (BC_2, N14, output3, X, 613, 1, PULL1)," & -- PAD139
+ " 613 (BC_2, *, controlr, 1)," &
+ " 612 (BC_2, N15, input, X)," & -- PAD140
+ " 611 (BC_2, N15, output3, X, 610, 1, PULL1)," & -- PAD140
+ " 610 (BC_2, *, controlr, 1)," &
+ " 609 (BC_2, IPAD141, input, X)," &
+ " 608 (BC_2, P16, input, X)," & -- PAD142
+ " 607 (BC_2, P16, output3, X, 606, 1, PULL1)," & -- PAD142
+ " 606 (BC_2, *, controlr, 1)," &
+ " 605 (BC_2, *, internal, X)," & -- PAD143.I
+ " 604 (BC_2, *, internal, X)," & -- PAD143.O
+ " 603 (BC_2, *, internal, 1)," & -- PAD143.T
+ " 602 (BC_2, *, internal, X)," & -- PAD144.I
+ " 601 (BC_2, *, internal, X)," & -- PAD144.O
+ " 600 (BC_2, *, internal, 1)," & -- PAD144.T
+ " 599 (BC_2, *, internal, X)," & -- PAD145.I
+ " 598 (BC_2, *, internal, X)," & -- PAD145.O
+ " 597 (BC_2, *, internal, 1)," & -- PAD145.T
+ " 596 (BC_2, R16, input, X)," & -- PAD146
+ " 595 (BC_2, R16, output3, X, 594, 1, PULL1)," & -- PAD146
+ " 594 (BC_2, *, controlr, 1)," &
+ " 593 (BC_2, R15, input, X)," & -- PAD147
+ " 592 (BC_2, R15, output3, X, 591, 1, PULL1)," & -- PAD147
+ " 591 (BC_2, *, controlr, 1)," &
+ " 590 (BC_2, IPAD148, input, X)," &
+ " 589 (BC_2, T18, input, X)," & -- PAD149
+ " 588 (BC_2, T18, output3, X, 587, 1, PULL1)," & -- PAD149
+ " 587 (BC_2, *, controlr, 1)," &
+ " 586 (BC_2, R18, input, X)," & -- PAD150
+ " 585 (BC_2, R18, output3, X, 584, 1, PULL1)," & -- PAD150
+ " 584 (BC_2, *, controlr, 1)," &
+ " 583 (BC_2, T17, input, X)," & -- PAD151
+ " 582 (BC_2, T17, output3, X, 581, 1, PULL1)," & -- PAD151
+ " 581 (BC_2, *, controlr, 1)," &
+ " 580 (BC_2, U18, input, X)," & -- PAD152
+ " 579 (BC_2, U18, output3, X, 578, 1, PULL1)," & -- PAD152
+ " 578 (BC_2, *, controlr, 1)," &
+ " 577 (BC_2, DONE, input, X)," &
+ " 576 (BC_2, DONE, output3, X, 575, 1, PULL1)," &
+ " 575 (BC_2, *, controlr, 1)," &
+ " 574 (BC_2, U16, input, X)," & -- PAD153
+ " 573 (BC_2, U16, output3, X, 572, 1, PULL1)," & -- PAD153
+ " 572 (BC_2, *, controlr, 1)," &
+ " 571 (BC_2, T16, input, X)," & -- PAD154
+ " 570 (BC_2, T16, output3, X, 569, 1, PULL1)," & -- PAD154
+ " 569 (BC_2, *, controlr, 1)," &
+ " 568 (BC_2, IPAD155, input, X)," &
+ " 567 (BC_2, U15, input, X)," & -- PAD156
+ " 566 (BC_2, U15, output3, X, 565, 1, PULL1)," & -- PAD156
+ " 565 (BC_2, *, controlr, 1)," &
+ " 564 (BC_2, V15, input, X)," & -- PAD157
+ " 563 (BC_2, V15, output3, X, 562, 1, PULL1)," & -- PAD157
+ " 562 (BC_2, *, controlr, 1)," &
+ " 561 (BC_2, T15, input, X)," & -- PAD158
+ " 560 (BC_2, T15, output3, X, 559, 1, PULL1)," & -- PAD158
+ " 559 (BC_2, *, controlr, 1)," &
+ " 558 (BC_2, R14, input, X)," & -- PAD159
+ " 557 (BC_2, R14, output3, X, 556, 1, PULL1)," & -- PAD159
+ " 556 (BC_2, *, controlr, 1)," &
+ " 555 (BC_2, T14, input, X)," & -- PAD160
+ " 554 (BC_2, T14, output3, X, 553, 1, PULL1)," & -- PAD160
+ " 553 (BC_2, *, controlr, 1)," &
+ " 552 (BC_2, IPAD161, input, X)," &
+ " 551 (BC_2, IPAD162, input, X)," &
+ " 550 (BC_2, *, internal, X)," & -- PAD163.I
+ " 549 (BC_2, *, internal, X)," & -- PAD163.O
+ " 548 (BC_2, *, internal, 1)," & -- PAD163.T
+ " 547 (BC_2, *, internal, X)," & -- PAD164.I
+ " 546 (BC_2, *, internal, X)," & -- PAD164.O
+ " 545 (BC_2, *, internal, 1)," & -- PAD164.T
+ " 544 (BC_2, *, internal, X)," & -- PAD165.I
+ " 543 (BC_2, *, internal, X)," & -- PAD165.O
+ " 542 (BC_2, *, internal, 1)," & -- PAD165.T
+ " 541 (BC_2, R13, input, X)," & -- PAD166
+ " 540 (BC_2, R13, output3, X, 539, 1, PULL1)," & -- PAD166
+ " 539 (BC_2, *, controlr, 1)," &
+ " 538 (BC_2, P13, input, X)," & -- PAD167
+ " 537 (BC_2, P13, output3, X, 536, 1, PULL1)," & -- PAD167
+ " 536 (BC_2, *, controlr, 1)," &
+ " 535 (BC_2, *, internal, X)," & -- IPAD168
+ " 534 (BC_2, *, internal, X)," & -- IPAD169
+ " 533 (BC_2, P12, input, X)," & -- PAD170
+ " 532 (BC_2, P12, output3, X, 531, 1, PULL1)," & -- PAD170
+ " 531 (BC_2, *, controlr, 1)," &
+ " 530 (BC_2, N12, input, X)," & -- PAD171
+ " 529 (BC_2, N12, output3, X, 528, 1, PULL1)," & -- PAD171
+ " 528 (BC_2, *, controlr, 1)," &
+ " 527 (BC_2, U13, input, X)," & -- PAD172
+ " 526 (BC_2, U13, output3, X, 525, 1, PULL1)," & -- PAD172
+ " 525 (BC_2, *, controlr, 1)," &
+ " 524 (BC_2, R12, input, X)," & -- PAD173
+ " 523 (BC_2, R12, output3, X, 522, 1, PULL1)," & -- PAD173
+ " 522 (BC_2, *, controlr, 1)," &
+ " 521 (BC_2, T12, input, X)," & -- PAD174
+ " 520 (BC_2, T12, output3, X, 519, 1, PULL1)," & -- PAD174
+ " 519 (BC_2, *, controlr, 1)," &
+ " 518 (BC_2, *, internal, X)," & -- IPAD175
+ " 517 (BC_2, *, internal, X)," & -- IPAD176
+ " 516 (BC_2, *, internal, X)," & -- PAD177.I
+ " 515 (BC_2, *, internal, X)," & -- PAD177.O
+ " 514 (BC_2, *, internal, 1)," & -- PAD177.T
+ " 513 (BC_2, V13, input, X)," & -- PAD178
+ " 512 (BC_2, V13, output3, X, 511, 1, PULL1)," & -- PAD178
+ " 511 (BC_2, *, controlr, 1)," &
+ " 510 (BC_2, V12, input, X)," & -- PAD179
+ " 509 (BC_2, V12, output3, X, 508, 1, PULL1)," & -- PAD179
+ " 508 (BC_2, *, controlr, 1)," &
+ " 507 (BC_2, R11, input, X)," & -- PAD180
+ " 506 (BC_2, R11, output3, X, 505, 1, PULL1)," & -- PAD180
+ " 505 (BC_2, *, controlr, 1)," &
+ " 504 (BC_2, N11, input, X)," & -- PAD181
+ " 503 (BC_2, N11, output3, X, 502, 1, PULL1)," & -- PAD181
+ " 502 (BC_2, *, controlr, 1)," &
+ " 501 (BC_2, P11, input, X)," & -- PAD182
+ " 500 (BC_2, P11, output3, X, 499, 1, PULL1)," & -- PAD182
+ " 499 (BC_2, *, controlr, 1)," &
+ " 498 (BC_2, IPAD183, input, X)," &
+ " 497 (BC_2, IPAD184, input, X)," &
+ " 496 (BC_2, N10, input, X)," & -- PAD185
+ " 495 (BC_2, N10, output3, X, 494, 1, PULL1)," & -- PAD185
+ " 494 (BC_2, *, controlr, 1)," &
+ " 493 (BC_2, M10, input, X)," & -- PAD186
+ " 492 (BC_2, M10, output3, X, 491, 1, PULL1)," & -- PAD186
+ " 491 (BC_2, *, controlr, 1)," &
+ " 490 (BC_2, V11, input, X)," & -- PAD187
+ " 489 (BC_2, V11, output3, X, 488, 1, PULL1)," & -- PAD187
+ " 488 (BC_2, *, controlr, 1)," &
+ " 487 (BC_2, P10, input, X)," & -- PAD188
+ " 486 (BC_2, P10, output3, X, 485, 1, PULL1)," & -- PAD188
+ " 485 (BC_2, *, controlr, 1)," &
+ " 484 (BC_2, R10, input, X)," & -- PAD189
+ " 483 (BC_2, R10, output3, X, 482, 1, PULL1)," & -- PAD189
+ " 482 (BC_2, *, controlr, 1)," &
+ " 481 (BC_2, IPAD190, input, X)," &
+ " 480 (BC_2, IPAD191, input, X)," &
+ " 479 (BC_2, V9, input, X)," & -- PAD192
+ " 478 (BC_2, V9, output3, X, 477, 1, PULL1)," & -- PAD192
+ " 477 (BC_2, *, controlr, 1)," &
+ " 476 (BC_2, U9, input, X)," & -- PAD193
+ " 475 (BC_2, U9, output3, X, 474, 1, PULL1)," & -- PAD193
+ " 474 (BC_2, *, controlr, 1)," &
+ " 473 (BC_2, R9, input, X)," & -- PAD194
+ " 472 (BC_2, R9, output3, X, 471, 1, PULL1)," & -- PAD194
+ " 471 (BC_2, *, controlr, 1)," &
+ " 470 (BC_2, M9, input, X)," & -- PAD195
+ " 469 (BC_2, M9, output3, X, 468, 1, PULL1)," & -- PAD195
+ " 468 (BC_2, *, controlr, 1)," &
+ " 467 (BC_2, N9, input, X)," & -- PAD196
+ " 466 (BC_2, N9, output3, X, 465, 1, PULL1)," & -- PAD196
+ " 465 (BC_2, *, controlr, 1)," &
+ " 464 (BC_2, IPAD197, input, X)," &
+ " 463 (BC_2, IPAD198, input, X)," &
+ " 462 (BC_2, T8, input, X)," & -- PAD199
+ " 461 (BC_2, T8, output3, X, 460, 1, PULL1)," & -- PAD199
+ " 460 (BC_2, *, controlr, 1)," &
+ " 459 (BC_2, R8, input, X)," & -- PAD200
+ " 458 (BC_2, R8, output3, X, 457, 1, PULL1)," & -- PAD200
+ " 457 (BC_2, *, controlr, 1)," &
+ " 456 (BC_2, P9, input, X)," & -- PAD201
+ " 455 (BC_2, P9, output3, X, 454, 1, PULL1)," & -- PAD201
+ " 454 (BC_2, *, controlr, 1)," &
+ " 453 (BC_2, N8, input, X)," & -- PAD202
+ " 452 (BC_2, N8, output3, X, 451, 1, PULL1)," & -- PAD202
+ " 451 (BC_2, *, controlr, 1)," &
+ " 450 (BC_2, P8, input, X)," & -- PAD203
+ " 449 (BC_2, P8, output3, X, 448, 1, PULL1)," & -- PAD203
+ " 448 (BC_2, *, controlr, 1)," &
+ " 447 (BC_2, IPAD204, input, X)," &
+ " 446 (BC_2, IPAD205, input, X)," &
+ " 445 (BC_2, V7, input, X)," & -- PAD206
+ " 444 (BC_2, V7, output3, X, 443, 1, PULL1)," & -- PAD206
+ " 443 (BC_2, *, controlr, 1)," &
+ " 442 (BC_2, P7, input, X)," & -- PAD207
+ " 441 (BC_2, P7, output3, X, 440, 1, PULL1)," & -- PAD207
+ " 440 (BC_2, *, controlr, 1)," &
+ " 439 (BC_2, N7, input, X)," & -- PAD208
+ " 438 (BC_2, N7, output3, X, 437, 1, PULL1)," & -- PAD208
+ " 437 (BC_2, *, controlr, 1)," &
+ " 436 (BC_2, U6, input, X)," & -- PAD209
+ " 435 (BC_2, U6, output3, X, 434, 1, PULL1)," & -- PAD209
+ " 434 (BC_2, *, controlr, 1)," &
+ " 433 (BC_2, V6, input, X)," & -- PAD210
+ " 432 (BC_2, V6, output3, X, 431, 1, PULL1)," & -- PAD210
+ " 431 (BC_2, *, controlr, 1)," &
+ " 430 (BC_2, V5, input, X)," & -- PAD211
+ " 429 (BC_2, V5, output3, X, 428, 1, PULL1)," & -- PAD211
+ " 428 (BC_2, *, controlr, 1)," &
+ " 427 (BC_2, *, internal, X)," & -- IPAD212
+ " 426 (BC_2, *, internal, X)," & -- IPAD213
+ " 425 (BC_2, P6, input, X)," & -- PAD214
+ " 424 (BC_2, P6, output3, X, 423, 1, PULL1)," & -- PAD214
+ " 423 (BC_2, *, controlr, 1)," &
+ " 422 (BC_2, R6, input, X)," & -- PAD215
+ " 421 (BC_2, R6, output3, X, 420, 1, PULL1)," & -- PAD215
+ " 420 (BC_2, *, controlr, 1)," &
+ " 419 (BC_2, *, internal, X)," & -- PAD216.I
+ " 418 (BC_2, *, internal, X)," & -- PAD216.O
+ " 417 (BC_2, *, internal, 1)," & -- PAD216.T
+ " 416 (BC_2, *, internal, X)," & -- PAD217.I
+ " 415 (BC_2, *, internal, X)," & -- PAD217.O
+ " 414 (BC_2, *, internal, 1)," & -- PAD217.T
+ " 413 (BC_2, *, internal, X)," & -- PAD218.I
+ " 412 (BC_2, *, internal, X)," & -- PAD218.O
+ " 411 (BC_2, *, internal, 1)," & -- PAD218.T
+ " 410 (BC_2, *, internal, X)," & -- IPAD219
+ " 409 (BC_2, *, internal, X)," & -- IPAD220
+ " 408 (BC_2, T5, input, X)," & -- PAD221
+ " 407 (BC_2, T5, output3, X, 406, 1, PULL1)," & -- PAD221
+ " 406 (BC_2, *, controlr, 1)," &
+ " 405 (BC_2, R5, input, X)," & -- PAD222
+ " 404 (BC_2, R5, output3, X, 403, 1, PULL1)," & -- PAD222
+ " 403 (BC_2, *, controlr, 1)," &
+ " 402 (BC_2, U5, input, X)," & -- PAD223
+ " 401 (BC_2, U5, output3, X, 400, 1, PULL1)," & -- PAD223
+ " 400 (BC_2, *, controlr, 1)," &
+ " 399 (BC_2, T4, input, X)," & -- PAD224
+ " 398 (BC_2, T4, output3, X, 397, 1, PULL1)," & -- PAD224
+ " 397 (BC_2, *, controlr, 1)," &
+ " 396 (BC_2, U4, input, X)," & -- PAD225
+ " 395 (BC_2, U4, output3, X, 394, 1, PULL1)," & -- PAD225
+ " 394 (BC_2, *, controlr, 1)," &
+ " 393 (BC_2, IPAD226, input, X)," &
+ " 392 (BC_2, IPAD227, input, X)," &
+ " 391 (BC_2, T3, input, X)," & -- PAD228
+ " 390 (BC_2, T3, output3, X, 389, 1, PULL1)," & -- PAD228
+ " 389 (BC_2, *, controlr, 1)," &
+ " 388 (BC_2, U3, input, X)," & -- PAD229
+ " 387 (BC_2, U3, output3, X, 386, 1, PULL1)," & -- PAD229
+ " 386 (BC_2, *, controlr, 1)," &
+ " 385 (BC_2, IPAD230, input, X)," &
+ " 384 (BC_2, IPAD231, input, X)," &
+ " 383 (BC_2, T1, input, X)," & -- PAD232
+ " 382 (BC_2, T1, output3, X, 381, 1, PULL1)," & -- PAD232
+ " 381 (BC_2, *, controlr, 1)," &
+ " 380 (BC_2, T2, input, X)," & -- PAD233
+ " 379 (BC_2, T2, output3, X, 378, 1, PULL1)," & -- PAD233
+ " 378 (BC_2, *, controlr, 1)," &
+ " 377 (BC_2, R2, input, X)," & -- PAD234
+ " 376 (BC_2, R2, output3, X, 375, 1, PULL1)," & -- PAD234
+ " 375 (BC_2, *, controlr, 1)," &
+ " 374 (BC_2, R3, input, X)," & -- PAD235
+ " 373 (BC_2, R3, output3, X, 372, 1, PULL1)," & -- PAD235
+ " 372 (BC_2, *, controlr, 1)," &
+ " 371 (BC_2, *, internal, X)," & -- PAD236.I
+ " 370 (BC_2, *, internal, X)," & -- PAD236.O
+ " 369 (BC_2, *, internal, 1)," & -- PAD236.T
+ " 368 (BC_2, *, internal, X)," & -- PAD237.I
+ " 367 (BC_2, *, internal, X)," & -- PAD237.O
+ " 366 (BC_2, *, internal, 1)," & -- PAD237.T
+ " 365 (BC_2, IPAD238, input, X)," &
+ " 364 (BC_2, *, internal, X)," & -- PAD239.I
+ " 363 (BC_2, *, internal, X)," & -- PAD239.O
+ " 362 (BC_2, *, internal, 1)," & -- PAD239.T
+ " 361 (BC_2, *, internal, X)," & -- PAD240.I
+ " 360 (BC_2, *, internal, X)," & -- PAD240.O
+ " 359 (BC_2, *, internal, 1)," & -- PAD240.T
+ " 358 (BC_2, P4, input, X)," & -- PAD241
+ " 357 (BC_2, P4, output3, X, 356, 1, PULL1)," & -- PAD241
+ " 356 (BC_2, *, controlr, 1)," &
+ " 355 (BC_2, P3, input, X)," & -- PAD242
+ " 354 (BC_2, P3, output3, X, 353, 1, PULL1)," & -- PAD242
+ " 353 (BC_2, *, controlr, 1)," &
+ " 352 (BC_2, IPAD243, input, X)," &
+ " 351 (BC_2, P1, input, X)," & -- PAD244
+ " 350 (BC_2, P1, output3, X, 349, 1, PULL1)," & -- PAD244
+ " 349 (BC_2, *, controlr, 1)," &
+ " 348 (BC_2, P2, input, X)," & -- PAD245
+ " 347 (BC_2, P2, output3, X, 346, 1, PULL1)," & -- PAD245
+ " 346 (BC_2, *, controlr, 1)," &
+ " 345 (BC_2, *, internal, X)," & -- PAD246.I
+ " 344 (BC_2, *, internal, X)," & -- PAD246.O
+ " 343 (BC_2, *, internal, 1)," & -- PAD246.T
+ " 342 (BC_2, *, internal, X)," & -- PAD247.I
+ " 341 (BC_2, *, internal, X)," & -- PAD247.O
+ " 340 (BC_2, *, internal, 1)," & -- PAD247.T
+ " 339 (BC_2, IPAD248, input, X)," &
+ " 338 (BC_2, N5, input, X)," & -- PAD249
+ " 337 (BC_2, N5, output3, X, 336, 1, PULL1)," & -- PAD249
+ " 336 (BC_2, *, controlr, 1)," &
+ " 335 (BC_2, N4, input, X)," & -- PAD250
+ " 334 (BC_2, N4, output3, X, 333, 1, PULL1)," & -- PAD250
+ " 333 (BC_2, *, controlr, 1)," &
+ " 332 (BC_2, M6, input, X)," & -- PAD251
+ " 331 (BC_2, M6, output3, X, 330, 1, PULL1)," & -- PAD251
+ " 330 (BC_2, *, controlr, 1)," &
+ " 329 (BC_2, M5, input, X)," & -- PAD252
+ " 328 (BC_2, M5, output3, X, 327, 1, PULL1)," & -- PAD252
+ " 327 (BC_2, *, controlr, 1)," &
+ " 326 (BC_2, IPAD253, input, X)," &
+ " 325 (BC_2, M3, input, X)," & -- PAD254
+ " 324 (BC_2, M3, output3, X, 323, 1, PULL1)," & -- PAD254
+ " 323 (BC_2, *, controlr, 1)," &
+ " 322 (BC_2, M4, input, X)," & -- PAD255
+ " 321 (BC_2, M4, output3, X, 320, 1, PULL1)," & -- PAD255
+ " 320 (BC_2, *, controlr, 1)," &
+ " 319 (BC_2, L5, input, X)," & -- PAD256
+ " 318 (BC_2, L5, output3, X, 317, 1, PULL1)," & -- PAD256
+ " 317 (BC_2, *, controlr, 1)," &
+ " 316 (BC_2, L6, input, X)," & -- PAD257
+ " 315 (BC_2, L6, output3, X, 314, 1, PULL1)," & -- PAD257
+ " 314 (BC_2, *, controlr, 1)," &
+ " 313 (BC_2, IPAD258, input, X)," &
+ " 312 (BC_2, L4, input, X)," & -- PAD259
+ " 311 (BC_2, L4, output3, X, 310, 1, PULL1)," & -- PAD259
+ " 310 (BC_2, *, controlr, 1)," &
+ " 309 (BC_2, L3, input, X)," & -- PAD260
+ " 308 (BC_2, L3, output3, X, 307, 1, PULL1)," & -- PAD260
+ " 307 (BC_2, *, controlr, 1)," &
+ " 306 (BC_2, L2, input, X)," & -- PAD261
+ " 305 (BC_2, L2, output3, X, 304, 1, PULL1)," & -- PAD261
+ " 304 (BC_2, *, controlr, 1)," &
+ " 303 (BC_2, L1, input, X)," & -- PAD262
+ " 302 (BC_2, L1, output3, X, 301, 1, PULL1)," & -- PAD262
+ " 301 (BC_2, *, controlr, 1)," &
+ " 300 (BC_2, IPAD263, input, X)," &
+ " 299 (BC_2, K5, input, X)," & -- PAD264
+ " 298 (BC_2, K5, output3, X, 297, 1, PULL1)," & -- PAD264
+ " 297 (BC_2, *, controlr, 1)," &
+ " 296 (BC_2, K6, input, X)," & -- PAD265
+ " 295 (BC_2, K6, output3, X, 294, 1, PULL1)," & -- PAD265
+ " 294 (BC_2, *, controlr, 1)," &
+ " 293 (BC_2, K4, input, X)," & -- PAD266
+ " 292 (BC_2, K4, output3, X, 291, 1, PULL1)," & -- PAD266
+ " 291 (BC_2, *, controlr, 1)," &
+ " 290 (BC_2, K3, input, X)," & -- PAD267
+ " 289 (BC_2, K3, output3, X, 288, 1, PULL1)," & -- PAD267
+ " 288 (BC_2, *, controlr, 1)," &
+ " 287 (BC_2, IPAD268, input, X)," &
+ " 286 (BC_2, J2, input, X)," & -- PAD269
+ " 285 (BC_2, J2, output3, X, 284, 1, PULL1)," & -- PAD269
+ " 284 (BC_2, *, controlr, 1)," &
+ " 283 (BC_2, J1, input, X)," & -- PAD270
+ " 282 (BC_2, J1, output3, X, 281, 1, PULL1)," & -- PAD270
+ " 281 (BC_2, *, controlr, 1)," &
+ " 280 (BC_2, J4, input, X)," & -- PAD271
+ " 279 (BC_2, J4, output3, X, 278, 1, PULL1)," & -- PAD271
+ " 278 (BC_2, *, controlr, 1)," &
+ " 277 (BC_2, J5, input, X)," & -- PAD272
+ " 276 (BC_2, J5, output3, X, 275, 1, PULL1)," & -- PAD272
+ " 275 (BC_2, *, controlr, 1)," &
+ " 274 (BC_2, IPAD273, input, X)," &
+ " 273 (BC_2, H1, input, X)," & -- PAD274
+ " 272 (BC_2, H1, output3, X, 271, 1, PULL1)," & -- PAD274
+ " 271 (BC_2, *, controlr, 1)," &
+ " 270 (BC_2, H2, input, X)," & -- PAD275
+ " 269 (BC_2, H2, output3, X, 268, 1, PULL1)," & -- PAD275
+ " 268 (BC_2, *, controlr, 1)," &
+ " 267 (BC_2, H3, input, X)," & -- PAD276
+ " 266 (BC_2, H3, output3, X, 265, 1, PULL1)," & -- PAD276
+ " 265 (BC_2, *, controlr, 1)," &
+ " 264 (BC_2, H4, input, X)," & -- PAD277
+ " 263 (BC_2, H4, output3, X, 262, 1, PULL1)," & -- PAD277
+ " 262 (BC_2, *, controlr, 1)," &
+ " 261 (BC_2, IPAD278, input, X)," &
+ " 260 (BC_2, H5, input, X)," & -- PAD279
+ " 259 (BC_2, H5, output3, X, 258, 1, PULL1)," & -- PAD279
+ " 258 (BC_2, *, controlr, 1)," &
+ " 257 (BC_2, H6, input, X)," & -- PAD280
+ " 256 (BC_2, H6, output3, X, 255, 1, PULL1)," & -- PAD280
+ " 255 (BC_2, *, controlr, 1)," &
+ " 254 (BC_2, G5, input, X)," & -- PAD281
+ " 253 (BC_2, G5, output3, X, 252, 1, PULL1)," & -- PAD281
+ " 252 (BC_2, *, controlr, 1)," &
+ " 251 (BC_2, G6, input, X)," & -- PAD282
+ " 250 (BC_2, G6, output3, X, 249, 1, PULL1)," & -- PAD282
+ " 249 (BC_2, *, controlr, 1)," &
+ " 248 (BC_2, IPAD283, input, X)," &
+ " 247 (BC_2, G4, input, X)," & -- PAD284
+ " 246 (BC_2, G4, output3, X, 245, 1, PULL1)," & -- PAD284
+ " 245 (BC_2, *, controlr, 1)," &
+ " 244 (BC_2, G3, input, X)," & -- PAD285
+ " 243 (BC_2, G3, output3, X, 242, 1, PULL1)," & -- PAD285
+ " 242 (BC_2, *, controlr, 1)," &
+ " 241 (BC_2, F2, input, X)," & -- PAD286
+ " 240 (BC_2, F2, output3, X, 239, 1, PULL1)," & -- PAD286
+ " 239 (BC_2, *, controlr, 1)," &
+ " 238 (BC_2, F1, input, X)," & -- PAD287
+ " 237 (BC_2, F1, output3, X, 236, 1, PULL1)," & -- PAD287
+ " 236 (BC_2, *, controlr, 1)," &
+ " 235 (BC_2, IPAD288, input, X)," &
+ " 234 (BC_2, *, internal, X)," & -- PAD289.I
+ " 233 (BC_2, *, internal, X)," & -- PAD289.O
+ " 232 (BC_2, *, internal, 1)," & -- PAD289.T
+ " 231 (BC_2, *, internal, X)," & -- PAD290.I
+ " 230 (BC_2, *, internal, X)," & -- PAD290.O
+ " 229 (BC_2, *, internal, 1)," & -- PAD290.T
+ " 228 (BC_2, E3, input, X)," & -- PAD291
+ " 227 (BC_2, E3, output3, X, 226, 1, PULL1)," & -- PAD291
+ " 226 (BC_2, *, controlr, 1)," &
+ " 225 (BC_2, E4, input, X)," & -- PAD292
+ " 224 (BC_2, E4, output3, X, 223, 1, PULL1)," & -- PAD292
+ " 223 (BC_2, *, controlr, 1)," &
+ " 222 (BC_2, IPAD293, input, X)," &
+ " 221 (BC_2, *, internal, X)," & -- PAD294.I
+ " 220 (BC_2, *, internal, X)," & -- PAD294.O
+ " 219 (BC_2, *, internal, 1)," & -- PAD294.T
+ " 218 (BC_2, *, internal, X)," & -- PAD295.I
+ " 217 (BC_2, *, internal, X)," & -- PAD295.O
+ " 216 (BC_2, *, internal, 1)," & -- PAD295.T
+ " 215 (BC_2, E1, input, X)," & -- PAD296
+ " 214 (BC_2, E1, output3, X, 213, 1, PULL1)," & -- PAD296
+ " 213 (BC_2, *, controlr, 1)," &
+ " 212 (BC_2, E2, input, X)," & -- PAD297
+ " 211 (BC_2, E2, output3, X, 210, 1, PULL1)," & -- PAD297
+ " 210 (BC_2, *, controlr, 1)," &
+ " 209 (BC_2, D4, input, X)," & -- PAD298
+ " 208 (BC_2, D4, output3, X, 207, 1, PULL1)," & -- PAD298
+ " 207 (BC_2, *, controlr, 1)," &
+ " 206 (BC_2, *, internal, X)," & -- PAD299.I
+ " 205 (BC_2, *, internal, X)," & -- PAD299.O
+ " 204 (BC_2, *, internal, 1)," & -- PAD299.T
+ " 203 (BC_2, IPAD300, input, X)," &
+ " 202 (BC_2, D2, input, X)," & -- PAD301
+ " 201 (BC_2, D2, output3, X, 200, 1, PULL1)," & -- PAD301
+ " 200 (BC_2, *, controlr, 1)," &
+ " 199 (BC_2, D1, input, X)," & -- PAD302
+ " 198 (BC_2, D1, output3, X, 197, 1, PULL1)," & -- PAD302
+ " 197 (BC_2, *, controlr, 1)," &
+ " 196 (BC_2, C2, input, X)," & -- PAD303
+ " 195 (BC_2, C2, output3, X, 194, 1, PULL1)," & -- PAD303
+ " 194 (BC_2, *, controlr, 1)," &
+ " 193 (BC_2, C1, input, X)," & -- PAD304
+ " 192 (BC_2, C1, output3, X, 191, 1, PULL1)," & -- PAD304
+ " 191 (BC_2, *, controlr, 1)," &
+ " 190 (BC_2, *, internal, 1)," & -- PROG_B
+ " 189 (BC_2, *, internal, 1)," & -- PUDC_B
+ " 188 (BC_2, *, internal, 1)," & -- PUDC_B
+ " 187 (BC_2, *, internal, 1)," & -- PUDC_B
+ " 186 (BC_2, C3, input, X)," & -- PAD2
+ " 185 (BC_2, C3, output3, X, 184, 1, PULL1)," & -- PAD2
+ " 184 (BC_2, *, controlr, 1)," &
+ " 183 (BC_2, IPAD3, input, X)," &
+ " 182 (BC_2, B4, input, X)," & -- PAD4
+ " 181 (BC_2, B4, output3, X, 180, 1, PULL1)," & -- PAD4
+ " 180 (BC_2, *, controlr, 1)," &
+ " 179 (BC_2, A4, input, X)," & -- PAD5
+ " 178 (BC_2, A4, output3, X, 177, 1, PULL1)," & -- PAD5
+ " 177 (BC_2, *, controlr, 1)," &
+ " 176 (BC_2, C4, input, X)," & -- PAD6
+ " 175 (BC_2, C4, output3, X, 174, 1, PULL1)," & -- PAD6
+ " 174 (BC_2, *, controlr, 1)," &
+ " 173 (BC_2, D5, input, X)," & -- PAD7
+ " 172 (BC_2, D5, output3, X, 171, 1, PULL1)," & -- PAD7
+ " 171 (BC_2, *, controlr, 1)," &
+ " 170 (BC_2, C5, input, X)," & -- PAD8
+ " 169 (BC_2, C5, output3, X, 168, 1, PULL1)," & -- PAD8
+ " 168 (BC_2, *, controlr, 1)," &
+ " 167 (BC_2, IPAD9, input, X)," &
+ " 166 (BC_2, IPAD10, input, X)," &
+ " 165 (BC_2, E6, input, X)," & -- PAD11
+ " 164 (BC_2, E6, output3, X, 163, 1, PULL1)," & -- PAD11
+ " 163 (BC_2, *, controlr, 1)," &
+ " 162 (BC_2, D6, input, X)," & -- PAD12
+ " 161 (BC_2, D6, output3, X, 160, 1, PULL1)," & -- PAD12
+ " 160 (BC_2, *, controlr, 1)," &
+ " 159 (BC_2, *, internal, X)," & -- PAD13.I
+ " 158 (BC_2, *, internal, X)," & -- PAD13.O
+ " 157 (BC_2, *, internal, 1)," & -- PAD13.T
+ " 156 (BC_2, A6, input, X)," & -- PAD14
+ " 155 (BC_2, A6, output3, X, 154, 1, PULL1)," & -- PAD14
+ " 154 (BC_2, *, controlr, 1)," &
+ " 153 (BC_2, B6, input, X)," & -- PAD15
+ " 152 (BC_2, B6, output3, X, 151, 1, PULL1)," & -- PAD15
+ " 151 (BC_2, *, controlr, 1)," &
+ " 150 (BC_2, *, internal, X)," & -- IPAD16
+ " 149 (BC_2, *, internal, X)," & -- IPAD17
+ " 148 (BC_2, *, internal, X)," & -- PAD18.I
+ " 147 (BC_2, *, internal, X)," & -- PAD18.O
+ " 146 (BC_2, *, internal, 1)," & -- PAD18.T
+ " 145 (BC_2, *, internal, X)," & -- PAD19.I
+ " 144 (BC_2, *, internal, X)," & -- PAD19.O
+ " 143 (BC_2, *, internal, 1)," & -- PAD19.T
+ " 142 (BC_2, A7, input, X)," & -- PAD20
+ " 141 (BC_2, A7, output3, X, 140, 1, PULL1)," & -- PAD20
+ " 140 (BC_2, *, controlr, 1)," &
+ " 139 (BC_2, E7, input, X)," & -- PAD21
+ " 138 (BC_2, E7, output3, X, 137, 1, PULL1)," & -- PAD21
+ " 137 (BC_2, *, controlr, 1)," &
+ " 136 (BC_2, F7, input, X)," & -- PAD22
+ " 135 (BC_2, F7, output3, X, 134, 1, PULL1)," & -- PAD22
+ " 134 (BC_2, *, controlr, 1)," &
+ " 133 (BC_2, *, internal, X)," & -- IPAD23
+ " 132 (BC_2, *, internal, X)," & -- IPAD24
+ " 131 (BC_2, *, internal, X)," & -- PAD25.I
+ " 130 (BC_2, *, internal, X)," & -- PAD25.O
+ " 129 (BC_2, *, internal, 1)," & -- PAD25.T
+ " 128 (BC_2, D7, input, X)," & -- PAD26
+ " 127 (BC_2, D7, output3, X, 126, 1, PULL1)," & -- PAD26
+ " 126 (BC_2, *, controlr, 1)," &
+ " 125 (BC_2, C7, input, X)," & -- PAD27
+ " 124 (BC_2, C7, output3, X, 123, 1, PULL1)," & -- PAD27
+ " 123 (BC_2, *, controlr, 1)," &
+ " 122 (BC_2, A8, input, X)," & -- PAD28
+ " 121 (BC_2, A8, output3, X, 120, 1, PULL1)," & -- PAD28
+ " 120 (BC_2, *, controlr, 1)," &
+ " 119 (BC_2, F8, input, X)," & -- PAD29
+ " 118 (BC_2, F8, output3, X, 117, 1, PULL1)," & -- PAD29
+ " 117 (BC_2, *, controlr, 1)," &
+ " 116 (BC_2, E8, input, X)," & -- PAD30
+ " 115 (BC_2, E8, output3, X, 114, 1, PULL1)," & -- PAD30
+ " 114 (BC_2, *, controlr, 1)," &
+ " 113 (BC_2, IPAD31, input, X)," &
+ " 112 (BC_2, IPAD32, input, X)," &
+ " 111 (BC_2, F9, input, X)," & -- PAD33
+ " 110 (BC_2, F9, output3, X, 109, 1, PULL1)," & -- PAD33
+ " 109 (BC_2, *, controlr, 1)," &
+ " 108 (BC_2, E9, input, X)," & -- PAD34
+ " 107 (BC_2, E9, output3, X, 106, 1, PULL1)," & -- PAD34
+ " 106 (BC_2, *, controlr, 1)," &
+ " 105 (BC_2, G9, input, X)," & -- PAD35
+ " 104 (BC_2, G9, output3, X, 103, 1, PULL1)," & -- PAD35
+ " 103 (BC_2, *, controlr, 1)," &
+ " 102 (BC_2, D9, input, X)," & -- PAD36
+ " 101 (BC_2, D9, output3, X, 100, 1, PULL1)," & -- PAD36
+ " 100 (BC_2, *, controlr, 1)," &
+ " 99 (BC_2, C9, input, X)," & -- PAD37
+ " 98 (BC_2, C9, output3, X, 97, 1, PULL1)," & -- PAD37
+ " 97 (BC_2, *, controlr, 1)," &
+ " 96 (BC_2, IPAD38, input, X)," &
+ " 95 (BC_2, IPAD39, input, X)," &
+ " 94 (BC_2, A10, input, X)," & -- PAD40
+ " 93 (BC_2, A10, output3, X, 92, 1, PULL1)," & -- PAD40
+ " 92 (BC_2, *, controlr, 1)," &
+ " 91 (BC_2, B10, input, X)," & -- PAD41
+ " 90 (BC_2, B10, output3, X, 89, 1, PULL1)," & -- PAD41
+ " 89 (BC_2, *, controlr, 1)," &
+ " 88 (BC_2, B11, input, X)," & -- PAD42
+ " 87 (BC_2, B11, output3, X, 86, 1, PULL1)," & -- PAD42
+ " 86 (BC_2, *, controlr, 1)," &
+ " 85 (BC_2, E10, input, X)," & -- PAD43
+ " 84 (BC_2, E10, output3, X, 83, 1, PULL1)," & -- PAD43
+ " 83 (BC_2, *, controlr, 1)," &
+ " 82 (BC_2, D10, input, X)," & -- PAD44
+ " 81 (BC_2, D10, output3, X, 80, 1, PULL1)," & -- PAD44
+ " 80 (BC_2, *, controlr, 1)," &
+ " 79 (BC_2, IPAD45, input, X)," &
+ " 78 (BC_2, IPAD46, input, X)," &
+ " 77 (BC_2, D11, input, X)," & -- PAD47
+ " 76 (BC_2, D11, output3, X, 75, 1, PULL1)," & -- PAD47
+ " 75 (BC_2, *, controlr, 1)," &
+ " 74 (BC_2, C11, input, X)," & -- PAD48
+ " 73 (BC_2, C11, output3, X, 72, 1, PULL1)," & -- PAD48
+ " 72 (BC_2, *, controlr, 1)," &
+ " 71 (BC_2, A11, input, X)," & -- PAD49
+ " 70 (BC_2, A11, output3, X, 69, 1, PULL1)," & -- PAD49
+ " 69 (BC_2, *, controlr, 1)," &
+ " 68 (BC_2, F11, input, X)," & -- PAD50
+ " 67 (BC_2, F11, output3, X, 66, 1, PULL1)," & -- PAD50
+ " 66 (BC_2, *, controlr, 1)," &
+ " 65 (BC_2, E11, input, X)," & -- PAD51
+ " 64 (BC_2, E11, output3, X, 63, 1, PULL1)," & -- PAD51
+ " 63 (BC_2, *, controlr, 1)," &
+ " 62 (BC_2, IPAD52, input, X)," &
+ " 61 (BC_2, IPAD53, input, X)," &
+ " 60 (BC_2, A12, input, X)," & -- PAD54
+ " 59 (BC_2, A12, output3, X, 58, 1, PULL1)," & -- PAD54
+ " 58 (BC_2, *, controlr, 1)," &
+ " 57 (BC_2, E12, input, X)," & -- PAD55
+ " 56 (BC_2, E12, output3, X, 55, 1, PULL1)," & -- PAD55
+ " 55 (BC_2, *, controlr, 1)," &
+ " 54 (BC_2, F12, input, X)," & -- PAD56
+ " 53 (BC_2, F12, output3, X, 52, 1, PULL1)," & -- PAD56
+ " 52 (BC_2, *, controlr, 1)," &
+ " 51 (BC_2, D13, input, X)," & -- PAD57
+ " 50 (BC_2, D13, output3, X, 49, 1, PULL1)," & -- PAD57
+ " 49 (BC_2, *, controlr, 1)," &
+ " 48 (BC_2, B13, input, X)," & -- PAD58
+ " 47 (BC_2, B13, output3, X, 46, 1, PULL1)," & -- PAD58
+ " 46 (BC_2, *, controlr, 1)," &
+ " 45 (BC_2, A13, input, X)," & -- PAD59
+ " 44 (BC_2, A13, output3, X, 43, 1, PULL1)," & -- PAD59
+ " 43 (BC_2, *, controlr, 1)," &
+ " 42 (BC_2, *, internal, X)," & -- IPAD60
+ " 41 (BC_2, *, internal, X)," & -- IPAD61
+ " 40 (BC_2, A14, input, X)," & -- PAD62
+ " 39 (BC_2, A14, output3, X, 38, 1, PULL1)," & -- PAD62
+ " 38 (BC_2, *, controlr, 1)," &
+ " 37 (BC_2, B14, input, X)," & -- PAD63
+ " 36 (BC_2, B14, output3, X, 35, 1, PULL1)," & -- PAD63
+ " 35 (BC_2, *, controlr, 1)," &
+ " 34 (BC_2, *, internal, X)," & -- PAD64.I
+ " 33 (BC_2, *, internal, X)," & -- PAD64.O
+ " 32 (BC_2, *, internal, 1)," & -- PAD64.T
+ " 31 (BC_2, *, internal, X)," & -- PAD65.I
+ " 30 (BC_2, *, internal, X)," & -- PAD65.O
+ " 29 (BC_2, *, internal, 1)," & -- PAD65.T
+ " 28 (BC_2, *, internal, X)," & -- PAD66.I
+ " 27 (BC_2, *, internal, X)," & -- PAD66.O
+ " 26 (BC_2, *, internal, 1)," & -- PAD66.T
+ " 25 (BC_2, *, internal, X)," & -- IPAD67
+ " 24 (BC_2, *, internal, X)," & -- IPAD68
+ " 23 (BC_2, *, internal, X)," & -- PAD69.I
+ " 22 (BC_2, *, internal, X)," & -- PAD69.O
+ " 21 (BC_2, *, internal, 1)," & -- PAD69.T
+ " 20 (BC_2, *, internal, X)," & -- PAD70.I
+ " 19 (BC_2, *, internal, X)," & -- PAD70.O
+ " 18 (BC_2, *, internal, 1)," & -- PAD70.T
+ " 17 (BC_2, E13, input, X)," & -- PAD71
+ " 16 (BC_2, E13, output3, X, 15, 1, PULL1)," & -- PAD71
+ " 15 (BC_2, *, controlr, 1)," &
+ " 14 (BC_2, C14, input, X)," & -- PAD72
+ " 13 (BC_2, C14, output3, X, 12, 1, PULL1)," & -- PAD72
+ " 12 (BC_2, *, controlr, 1)," &
+ " 11 (BC_2, D14, input, X)," & -- PAD73
+ " 10 (BC_2, D14, output3, X, 9, 1, PULL1)," & -- PAD73
+ " 9 (BC_2, *, controlr, 1)," &
+ " 8 (BC_2, IPAD74, input, X)," &
+ " 7 (BC_2, IPAD75, input, X)," &
+ " 6 (BC_2, A16, input, X)," & -- PAD76
+ " 5 (BC_2, A16, output3, X, 4, 1, PULL1)," & -- PAD76
+ " 4 (BC_2, *, controlr, 1)," &
+ " 3 (BC_2, B16, input, X)," & -- PAD77
+ " 2 (BC_2, B16, output3, X, 1, 1, PULL1)," & -- PAD77
+ " 1 (BC_2, *, controlr, 1)," &
+ " 0 (BC_2, IPAD78, input, X)";
+
+
+attribute ISC_PIN_BEHAVIOR of XC3S1200E_FG320 : entity is
+ "HIGHZ" ; -- clamp behavior
+ -- no status
+
+attribute ISC_STATUS of XC3S1200E_FG320 : entity is
+ "NOT IMPLEMENTED" ;
+
+attribute ISC_BLANK_USERCODE of XC3S1200E_FG320 : entity is
+ "00000000000000000000000000000000";
+
+attribute ISC_FLOW of XC3S1200E_FG320 : entity is
+ -- Enable program
+ "flow_enable " &
+ "initialize " &
+ " (ISC_ENABLE 5:00 wait TCK 16)," &
+
+ "flow_disable " &
+ "initialize " &
+ " (ISC_DISABLE wait TCK 16)" &
+ " (BYPASS 1:0 wait TCK 1)," &
+
+ "flow_program(array) " &
+ "Repeat 239922 " &
+ " (ISC_PROGRAM 16:? wait TCK 1 )," &
+
+ "flow_program(legacy) " &
+ "Initialize " &
+ " (JSHUTDOWN wait TCK 16)" &
+ " (CFG_IN 3838752:? wait TCK 1)" &
+ " (JSTART wait TCK 32)" &
+ " (BYPASS 1:0 wait TCK 1)," &
+
+ "flow_verify(idcode) " &
+ "initialize " &
+ " (IDCODE wait TCK 1 32:01C2E093*0FFFFFFF)," &
+
+ "flow_read(usercode) " &
+ "initialize " &
+ " (USERCODE wait TCK 1 32:!)," &
+
+ "flow_read(idcode) " &
+ "initialize " &
+ " (IDCODE wait TCK 1 32:!)," &
+
+ "flow_program_done " &
+ "initialize " &
+ " (BYPASS wait TCK 1)," &
+
+ "flow_error_exit " &
+ "initialize " &
+ " (BYPASS wait TCK 1)";
+
+attribute ISC_PROCEDURE of XC3S1200E_FG320 : entity is
+ "proc_enable = (flow_enable)," &
+ "proc_disable = (flow_disable)," &
+ "proc_program = (flow_program(array))," &
+ "proc_program(legacy) = (flow_program(legacy))," &
+ "proc_verify(idcode) = (flow_verify(idcode))," &
+ "proc_read(idcode) = (flow_read(idcode))," &
+ "proc_read(usercode) = (flow_read(usercode))," &
+ "proc_program_done = (flow_program_done)," &
+ "proc_error_exit = (flow_error_exit)";
+
+attribute ISC_ACTION of XC3S1200E_FG320 : entity is
+ "program = (proc_verify(idcode) recommended," &
+ " proc_enable, proc_program," &
+ " proc_disable)," &
+ "program(lgcy) = (proc_verify(idcode) recommended," &
+ " proc_enable, proc_program(legacy)," &
+ " proc_disable)," &
+ "verify(idcode) = (proc_verify(idcode))," &
+ "read(idcode) = (proc_read(idcode))," &
+ "read(usercode) = (proc_read(usercode))";
+
+-- Design Warning Section
+
+attribute DESIGN_WARNING of XC3S1200E_FG320 : entity is
+ "This is a preliminary BSDL file which has not been verified." &
+ "This BSDL file must be modified by the FPGA designer in order to" &
+ "reflect post-configuration behavior (if any)." &
+ "To avoid losing the current configuration, the PROG_B should be" &
+ "kept high. If the PROG_B pin goes low by any means," &
+ "the configuration will be cleared." &
+ "PROG_B can only be captured, not updated." &
+ "The value at the pin is always used by the device." &
+ "PUDC_B can be captured and updated." &
+ "The value at the pin is always used by the device" &
+ "before configuration is done." &
+ "During pre-configuration, the disable result of a 3-stated" &
+ "I/O in this file corresponds to PUDC_B being low" &
+ "or during EXTEST instruction." &
+ "When PUDC_B is high AND during SAMPLE instruction, change" &
+ "all PULL1s to PULL0s." &
+ "After configuration, the disable result only depends on" &
+ "the individual IO configuration setting." &
+ "In EXTEST, output and tristate values are not captured in the" &
+ "Capture-DR state - those register cells are unchanged." &
+ "In INTEST, the pin input values are not captured in the" &
+ "Capture-DR state - those register cells are unchanged." &
+ "The output and tristate capture values are not valid until after" &
+ "the device is configured." &
+ "The tristate control value is not captured properly when" &
+ "GTS is activated.";
+
+end XC3S1200E_FG320;
+
trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/bsdl/xc3s1200e_fg320_1532.bsd
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/debug/impact_bat
===================================================================
--- trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/debug/impact_bat (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/debug/impact_bat (revision 44)
@@ -0,0 +1,6 @@
+setMode -bs
+setCable -port svf -file ../debug/bitstream.svf
+addDevice -p 1 -file Board_Design_jtag.bit
+program -p 1
+closeCable
+quit
trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/debug/impact_bat
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/debug/fpga_load
===================================================================
--- trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/debug/fpga_load (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/debug/fpga_load (revision 44)
@@ -0,0 +1,6 @@
+bsdl path ../bsdl;../target/bsdl;
+cable usbblaster
+detect
+part 1
+svf bitstream.svf
+
trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/debug/fpga_load
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/filelist
===================================================================
--- trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/filelist (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/filelist (revision 44)
@@ -0,0 +1,29 @@
+verilog work ./target/Pad_Ring.v
+
+
+verilog work ../../../../../ip/T6502/rtl/gen/syn/T6502.v
+verilog work ../../../../../children/logic/ip/disp_io/rtl/gen/syn/disp_io.v
+verilog work ../../../../../children/logic/ip/io_module/rtl/gen/syn/io_module.v
+
+
+verilog work ../../../../../children/logic/ip/vga_char_ctrl/rtl/gen/syn/vga_char_ctrl.v
+verilog work ../../../../../children/logic/ip/ps2_interface/rtl/gen/syn/ps2_interface.v
+verilog work ../../../../../children/logic/ip/uart/rtl/gen/syn/uart.v
+verilog work ../../../../../children/logic/ip/serial_rcvr/rtl/gen/syn/serial_rcvr.v
+verilog work ../../../../../children/logic/ip/flash_memcontrl/rtl/gen/syn/flash_memcontrl.v
+
+
+verilog work ./target/lib/syn/cde_pads/cde_pad_se_dig.v
+verilog work ./target/lib/syn/cde_clock_sys/cde_clock_sys.v
+verilog work ./target/lib/syn/cde_jtag/cde_jtag.v
+verilog work ./target/lib/syn/cde_jtag/cde_jtag_rpc_reg.v
+verilog work ./target/lib/syn/cde_sram/cde_sram.v
+verilog work ./target/lib/syn/cde_fifo/cde_fifo.v
+verilog work ./target/lib/syn/cde_lifo/cde_lifo.v
+verilog work ./target/lib/syn/cde_synchronizers/cde_sync_with_hysteresis.v
+verilog work ./target/lib/syn/cde_divider/cde_divider.v
+verilog work ./target/lib/syn/cde_serial_rcvr/cde_serial_rcvr.v
+verilog work ./target/lib/syn/cde_serial_xmit/cde_serial_xmit.v
+
+
+
trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/filelist
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/core.v
===================================================================
--- trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/core.v (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/core.v (revision 44)
@@ -0,0 +1,112 @@
+
+ // Declare I/O Port connections
+
+
+wire clk = ck25MHz;
+wire [15:0] add_mon;
+wire [7:0] gpio_0_out;
+wire [7:0] gpio_1_out;
+
+
+assign rs_tx_pad_out = rs_rx_pad_in;
+
+assign jtag_user1_cap = jtag_user1_upd;
+assign jtag_user2_cap = add_mon;
+
+assign PosD = {gpio_0_out,gpio_1_out};
+assign PosL = 8'h12;
+
+assign ja_1_pad_out = 1'b0;
+assign ja_2_pad_out = reset;
+assign ja_3_pad_out = 1'b0;
+assign ja_4_pad_out = 1'b0 ;
+
+assign ja_7_pad_out = 1'b0;
+assign ja_8_pad_out = 1'b0;
+assign ja_9_pad_out = 1'b0;
+assign ja_10_pad_out = 1'b0;
+
+assign jb_1_pad_out = 1'b0;
+assign jb_2_pad_out = 1'b0;
+assign jb_3_pad_out = 1'b0;
+assign jb_4_pad_out = 1'b0;
+
+assign jb_7_pad_out = 1'b0;
+assign jb_8_pad_out = 1'b0;
+assign jb_9_pad_out = 1'b0;
+assign jb_10_pad_out = 1'b0;
+
+assign jc_1_pad_out = 1'b1;
+assign jc_2_pad_out = 1'b0;
+assign jc_3_pad_out = 1'b1;
+assign jc_4_pad_out = 1'b0;
+
+assign jc_7_pad_out = 1'b1;
+assign jc_8_pad_out = 1'b0;
+assign jc_9_pad_out = 1'b1;
+assign jc_10_pad_out = 1'b0;
+
+assign add_mon[15:0] = 16'h0000 ;
+
+
+
+T6502 #(
+ .ROM_WORDS (`ROM_WORDS),
+ .ROM_ADD (`ROM_ADD),
+ .ROM_FILE (`ROM_FILE),
+ .PROG_ROM_WORDS (`PROG_ROM_WORDS),
+ .PROG_ROM_ADD (`PROG_ROM_ADD),
+ .PROG_ROM_FILE (`PROG_ROM_FILE),
+ .RAM_WORDS (4096),
+ .STARTUP (`STARTUP),
+ .FONT (`FONT)
+ )
+ cpu (
+ .clk ( ck25MHz ),
+ .reset ( reset ),
+
+ .alu_status ( ),
+
+ .ext_add ( micro_addr ),
+ .ext_wdata ( micro_wdata ),
+ .ext_rdata ( micro_rdata ),
+ .ext_ub ( micro_ub ),
+ .ext_lb ( micro_lb ),
+ .ext_rd ( micro_rd ),
+ .ext_wr ( micro_wr ),
+ .ext_cs ( micro_cs ),
+
+ .ext_irq_in ( 4'h0 ),
+
+ .gpio_0_out ( gpio_0_out ),
+ .gpio_0_in ( 8'h00 ),
+ .gpio_0_oe ( ),
+ .gpio_0_lat ( ),
+
+ .gpio_1_out ( gpio_1_out ),
+ .gpio_1_in ( 8'h00 ),
+ .gpio_1_oe ( ),
+ .gpio_1_lat ( ),
+
+ .ps2_data_oe ( ps2_data_pad_oe ),
+ .ps2_data_in ( ps2_data_pad_in ),
+ .ps2_clk_oe ( ps2_clk_pad_oe ),
+ .ps2_clk_in ( ps2_clk_pad_in ),
+
+ .txd_pad_out ( txd_pad_out ),
+ .rxd_pad_in ( rxd_pad_in ),
+ .cts_pad_in ( cts_pad_in ),
+ .rts_pad_out ( rts_pad_out ),
+
+ .vgared_pad_out ( vgared_pad_out[2:0] ),
+ .vgagreen_pad_out ( vgagreen_pad_out[2:0] ),
+ .vgablue_pad_out ( vgablue_pad_out[1:0] ),
+
+ .hsync_n_pad_out ( hsync_pad_out ),
+ .vsync_n_pad_out ( vsync_pad_out )
+
+
+);
+
+
+
\ No newline at end of file
trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/core.v
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/Makefile
===================================================================
--- trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/Makefile (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/Makefile (revision 44)
@@ -0,0 +1,4 @@
+include ../../../../bin/Makefile.root
+include ./target/Makefile.brd
+Design=T6502_io_irq_2
+
trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/Makefile
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/def_file
===================================================================
--- trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/def_file (nonexistent)
+++ trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/def_file (revision 44)
@@ -0,0 +1,23 @@
+`define SYNTHESIS
+`define ROM_FILE "NONE"
+`define ROM_WORDS 128
+`define ROM_ADD 7
+
+`define PROG_ROM_FILE "../../../../../../../projects/Mos6502/sw/io_irq_2/io_irq_2.abs16"
+`define PROG_ROM_WORDS 128
+`define PROG_ROM_ADD 7
+
+
+
+`define MODULE_NAME Nexys2_T6502_io_irq_2
+
+`define STARTUP "../../../../../sw/vga_startup_screen/vga_startup_screen.abs"
+`define FONT "../../../../../sw/vga_font/vga_font.abs"
+
+
+`define JTAG_USER1_WIDTH 8
+`define JTAG_USER1_RESET 8'h12
+`define JTAG_USER1_UPDR 1'b1
+`define JTAG_USER2_WIDTH 16
+`define JTAG_USER2_RESET 16'h0000
+`define JTAG_USER2_UPDR 1'b0
trunk/projects/Mos6502/ip/T6502/syn/Nexys2_io_irq_2/def_file
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/sw/table_tim1/table_tim1.asm
===================================================================
--- trunk/projects/Mos6502/sw/table_tim1/table_tim1.asm (nonexistent)
+++ trunk/projects/Mos6502/sw/table_tim1/table_tim1.asm (revision 44)
@@ -0,0 +1,33 @@
+
+
+ cpu 6502
+ output HEX
+
+
+ * = $c000 ; assemble at $ff00
+ code
+
+
+.str_1 ASC "Mem " ;
+ DB $00 ;
+
+
+ * = $c010 ; assemble at $ff10
+
+.top db $0a,$0d ;
+ ASC "MIK";
+
+
+ * = $c0fa ; vectors
+
+ dw $0000
+ dw $0000
+ dw $0000
+
+ code
+
+
+
+
+
+
trunk/projects/Mos6502/sw/table_tim1/table_tim1.asm
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/sw/table_tim1/Makefile
===================================================================
--- trunk/projects/Mos6502/sw/table_tim1/Makefile (nonexistent)
+++ trunk/projects/Mos6502/sw/table_tim1/Makefile (revision 44)
@@ -0,0 +1,7 @@
+include ../../bin/Makefile.root
+code=table_tim1
+
+all:asm_6502
+
+
+
trunk/projects/Mos6502/sw/table_tim1/Makefile
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/sw/table/table.asm
===================================================================
--- trunk/projects/Mos6502/sw/table/table.asm (nonexistent)
+++ trunk/projects/Mos6502/sw/table/table.asm (revision 44)
@@ -0,0 +1,51 @@
+
+
+ cpu 6502
+ output HEX
+
+
+
+ * = $c000
+ code
+
+.table db $01,$02,$03,$04,$05,$06,$07,$08 ;
+ db $09,$a1,$b2,$c3,$d4,$e5,$f6,$07 ;
+ db $80,$09,$01,$02,$03,$04,$05,$06 ;
+ db $70,$8a,$b9,$c1,$d2,$e3,$f4,$05 ;
+ db $60,$70,$80,$09,$01,$02,$03,$04 ;
+ db $50,$6a,$7b,$8c,$d9,$e1,$02,$03 ;
+ db $40,$50,$60,$70,$80,$09,$f1,$00 ;
+ db $30,$4a,$5b,$6c,$7d,$8e,$09,$01 ;
+ db $20,$30,$40,$50,$60,$70,$8f,$09 ;
+ db $19,$2a,$3b,$4c,$5d,$6e,$70,$80 ;
+ db $08,$19,$20,$30,$40,$50,$6f,$70 ;
+ db $07,$a8,$19,$2c,$3d,$4e,$50,$60 ;
+ db $06,$07,$b8,$19,$20,$30,$4f,$50 ;
+ db $05,$a6,$07,$08,$19,$2e,$30,$40 ;
+ db $04,$05,$b6,$c7,$08,$19,$2f,$30 ;
+ db $03,$a4,$05,$06,$d7,$08,$19,$20 ;
+ db $02,$03,$b4,$c5,$06,$e7,$f8,$19 ;
+ db $00,$a2,$03,$04,$d5,$06,$07,$08 ;
+ db $91,$00,$b2,$c3,$04,$e5,$f6,$07 ;
+ db $80,$91,$00,$02,$d3,$04,$05,$06 ;
+ db $70,$8a,$91,$c0,$02,$e3,$f4,$05 ;
+ db $60,$70,$8b,$91,$d0,$02,$03,$04 ;
+ db $50,$6a,$70,$8c,$91,$e0,$f2,$03 ;
+ db $40,$50,$6b,$70,$80,$91,$00,$02 ;
+ db $30,$4a,$50,$6c,$7d,$8e,$91,$00 ;
+ db $20,$30,$4b,$50,$60,$70,$8f,$91 ;
+ db $00,$2a,$30,$4c,$5d,$6e,$70,$80 ;
+ db $10,$00,$2b,$30,$40,$50,$6f,$70 ;
+ db $00,$1a,$00,$2c,$3d,$4e,$50,$60 ;
+ db $00,$00,$1b,$00,$20,$30,$4f,$50 ;
+ db $00,$0a,$00,$1c,$0d,$2e,$30,$40 ;
+ db $00,$00,$00,$c0,$06,$c0,$03,$c0 ;
+
+
+ code
+
+
+
+
+
+
trunk/projects/Mos6502/sw/table/table.asm
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/sw/table/Makefile
===================================================================
--- trunk/projects/Mos6502/sw/table/Makefile (nonexistent)
+++ trunk/projects/Mos6502/sw/table/Makefile (revision 44)
@@ -0,0 +1,7 @@
+include ../../bin/Makefile.root
+code=table
+
+all:asm_6502
+
+
+
trunk/projects/Mos6502/sw/table/Makefile
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/sw/inst_2_test/inst_2_test.asm
===================================================================
--- trunk/projects/Mos6502/sw/inst_2_test/inst_2_test.asm (nonexistent)
+++ trunk/projects/Mos6502/sw/inst_2_test/inst_2_test.asm (revision 44)
@@ -0,0 +1,1462 @@
+
+
+ include ../io_module/io_module.asm
+
+ ;; page zero variables used during test
+
+ * = $0060
+t_cnt db 00
+var_1 = $04 ;
+var_2 = $05 ;
+var_3 = $06 ;
+var_4 = $07 ;
+c_test = $40 ;
+n_test = $41 ;
+v_test = $42 ;
+z_test = $43 ;
+pointer = $44 ;
+
+
+ * = $f000
+ code
+
+
+
+.start nop
+ lda #$34
+ sta t_cnt
+ lda #$00
+ sta var_1
+ sta var_2
+ sta var_3
+ sta var_4
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda io_base+io_gpio_0
+ inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda io_base+io_gpio_0
+ jmp .lab_00
+ lda #$00
+ jmp .error
+.lab_00 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda io_base+io_gpio_0
+ inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda io_base+io_gpio_0
+ clc
+ bcc .lab_01
+ lda #$01
+ jmp .error
+.lab_01 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda io_base+io_gpio_0
+ sec
+ bcc .lab_02
+ jmp .lab_025
+.lab_02 lda #$02
+ jmp .error
+.lab_025 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda io_base+io_gpio_0
+ sec
+ bcs .lab_03
+ lda #$01
+ jmp .error
+
+.lab_03 clc
+ bcs .lab_04
+ jmp .lab_045
+.lab_04 lda #$02
+ jmp .error
+.lab_045 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$05
+ cmp #$04
+ beq .lab_05
+ cmp #$05
+ beq .lab_06
+.lab_05 lda #$03
+ jmp .error
+.lab_06 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$c4
+ cmp #$e4
+ bne .lab_07
+ lda #$04
+ jmp .error
+.lab_07 cmp #$C4
+ bne .lab_08
+ jmp .lab_085
+.lab_08 lda #$05
+ jmp .error
+.lab_085 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ ldx #$42
+ cpx #$32
+ beq .lab_09
+ cpx #$42
+ beq .lab_10
+.lab_09 lda #$06
+ jmp .error
+.lab_10 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ ldy #$C3
+ cpy #$D3
+ beq .lab_11
+ cpy #$C3
+ beq .lab_12
+.lab_11 lda #$07
+ jmp .error
+.lab_12 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ ldx #$00
+ dex
+ cpx #$FF
+ beq .lab_13
+ lda #$08
+ jmp .error
+.lab_13 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ ldy #$00
+ dey
+ cpy #$FF
+ beq .lab_14
+ lda #$09
+ jmp .error
+.lab_14 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ ldx #$0F
+ inx
+ cpx #$10
+ beq .lab_15
+ lda #$10
+ jmp .error
+.lab_15 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ ldy #$7F
+ iny
+ cpy #$80
+ beq .lab_16
+ lda #$11
+ jmp .error
+.lab_16 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$ED
+ jsr .lab_165
+ cmp #$42
+ beq .lab_17
+ lda #$12
+ jmp .error
+.lab_165 lda #$42
+ rts
+.lab_17 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$35
+ tax
+ cpx #$35
+ beq .lab_18
+ lda #$12
+ jmp .error
+.lab_18 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$76
+ tay
+ cpy #$76
+ beq .lab_19
+ lda #$13
+ jmp .error
+.lab_19 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ ldx #$52
+ txa
+ cmp #$52
+ beq .lab_20
+ lda #$14
+ jmp .error
+.lab_20 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ ldy #$52
+ tya
+ cmp #$52
+ beq .lab_21
+ lda #$15
+ jmp .error
+.lab_21 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ clc
+ lda #$23
+ adc #$45
+ cmp #$68
+ beq .lab_22
+ lda #$16
+ jmp .error
+.lab_22 sec
+ lda #$42
+ adc #$63
+ cmp #$A6
+ beq .lab_23
+ lda #$17
+ jmp .error
+.lab_23 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$36
+ and #$f0
+ cmp #$30
+ beq .lab_24
+ lda #$18
+ jmp .error
+.lab_24 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ clc
+ lda #$36
+ asl a
+ cmp #$6C
+ beq .lab_25
+ lda #$19
+ jmp .error
+.lab_25 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$89
+ eor #$96
+ cmp #$1F
+ beq .lab_26
+ lda #$20
+ jmp .error
+.lab_26 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ clc
+ lda #$52
+ lsr a
+ cmp #$29
+ beq .lab_27
+ lda #$21
+ jmp .error
+.lab_27 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$B6
+ ora #$4D
+ cmp #$FF
+ beq .lab_28
+ lda #$22
+ jmp .error
+.lab_28 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ clc
+ lda #$23
+ rol a
+ cmp #$46
+ beq .lab_29
+ lda #$23
+ jmp .error
+.lab_29 sec
+ lda #$42
+ rol a
+ cmp #$85
+ beq .lab_30
+ lda #$24
+ jmp .error
+.lab_30 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ clc
+ lda #$23
+ ror a
+ cmp #$11
+ beq .lab_31
+ lda #$25
+ jmp .error
+.lab_31 sec
+ lda #$42
+ ror a
+ cmp #$A1
+ beq .lab_32
+ lda #$26
+ jmp .error
+.lab_32 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ sec
+ lda #$86
+ sbc #$45
+ cmp #$41
+ beq .lab_33
+ lda #$27
+ jmp .error
+.lab_33 clc
+ lda #$89
+ sbc #$23
+ cmp #$65
+ beq .lab_34
+ lda #$28
+ jmp .error
+.lab_34 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$42
+ sta $0200
+ lda #$9F
+ sta $0201
+ lda $0200
+ cmp #$42
+ beq .lab_35
+ lda #$29
+ jmp .error
+.lab_35 lda $0201
+ cmp #$9F
+ beq .lab_36
+ lda #$30
+ jmp .error
+.lab_36 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$94
+ sta $0201
+ lda #$41
+ sta $0200
+ lda #$53
+ clc
+ adc $0200
+ cmp $0201
+ beq .lab_37
+ lda #$31
+ jmp .error
+.lab_37 lda #$8D
+ sta $0201
+ lda #$98
+ sta $0200
+ lda #$F4
+ sec
+ adc $0200
+ cmp $0201
+ beq .lab_38
+ lda #$32
+ jmp .error
+.lab_38 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ ldy #$84
+ sty $0201
+ ldx #$B4
+ stx $0200
+ lda #$86
+ and $0200
+ cmp $0201
+ beq .lab_39
+ lda #$33
+ jmp .error
+.lab_39 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ ldx #$55
+ stx $0200
+ asl $0200
+ lda $0200
+ cmp #$AA
+ beq .lab_40
+ lda #$34
+ jmp .error
+.lab_40 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$53
+ sta $0200
+ lda #$00
+ ldx #$53
+ cpx $0200
+ beq .lab_41
+ lda #$35
+ jmp .error
+.lab_41 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$45
+ sta $0200
+ lda #$00
+ ldy #$45
+ cpy $0200
+ beq .lab_42
+ lda #$36
+ jmp .error
+.lab_42 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$EF
+ sta $0200
+ dec $0200
+ lda #$EE
+ cmp $0200
+ beq .lab_43
+ lda #$37
+ jmp .error
+.lab_43 lda #$01
+ sta $0200
+ dec $0200
+ beq .lab_44
+ lda #$38
+ jmp .error
+.lab_44 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$EF
+ sta $0200
+ inc $0200
+ lda #$F0
+ cmp $0200
+ beq .lab_45
+ lda #$39
+ jmp .error
+.lab_45 lda #$FF
+ sta $0200
+ inc $0200
+ beq .lab_46
+ lda #$40
+ jmp .error
+.lab_46 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ ldy #$32
+ sty $0201
+ ldx #$B4
+ stx $0200
+ lda #$86
+ eor $0200
+ cmp $0201
+ beq .lab_47
+ lda #$41
+ jmp .error
+.lab_47 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ ldy #$B6
+ sty $0201
+ ldx #$B4
+ stx $0200
+ lda #$86
+ ora $0200
+ cmp $0201
+ beq .lab_48
+ lda #$42
+ jmp .error
+.lab_48 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ clc
+ ldx #$AA
+ stx $0200
+ rol $0200
+ bcs .lab_49
+ lda #$43
+ jmp .error
+.lab_49 lda $0200
+ cmp #$54
+ beq .lab_50
+ lda #$44
+ jmp .error
+.lab_50 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ clc
+ ldx #$55
+ stx $0200
+ ror $0200
+ bcs .lab_51
+ lda #$45
+ jmp .error
+.lab_51 lda $0200
+ cmp #$2A
+ beq .lab_52
+ lda #$46
+ jmp .error
+.lab_52 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ ldx #$96
+ stx $0200
+ lsr $0200
+ lda $0200
+ cmp #$4B
+ beq .lab_53
+ lda #$47
+ jmp .error
+.lab_53 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ ldx #$42
+ stx $0200
+ ldx #$9F
+ stx $0201
+ ldx $0200
+ cpx #$42
+ beq .lab_54
+ lda #$48
+ jmp .error
+.lab_54 ldx $0201
+ cpx #$9F
+ beq .lab_55
+ lda #$49
+ jmp .error
+.lab_55 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ ldy #$34
+ sty $0200
+ ldy #$75
+ sty $0201
+ ldy $0200
+ cpy #$34
+ beq .lab_56
+ lda #$4A
+ jmp .error
+.lab_56 ldy $0201
+ cpy #$75
+ beq .lab_57
+ lda #$4B
+ jmp .error
+.lab_57 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$12
+ sta $0201
+ lda #$41
+ sta $0200
+ lda #$53
+ sec
+ sbc $0200
+ cmp $0201
+ beq .lab_58
+ lda #$4C
+ jmp .error
+.lab_58 lda #$5B
+ sta $0201
+ lda #$98
+ sta $0200
+ lda #$F4
+ clc
+ sbc $0200
+ cmp $0201
+ beq .lab_59
+ lda #$4D
+ jmp .error
+.lab_59 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$42
+ inc t_cnt
+ pha
+ lda #$ED
+ inc t_cnt
+ pha
+ lda #$BE
+ inc t_cnt
+ pha
+ lda #$00
+ pla
+ cmp #$BE
+ bne .lab_60
+ pla
+ cmp #$ED
+ bne .lab_60
+ pla
+ cmp #$42
+ bne .lab_60
+ jmp .lab_605
+.lab_60 lda #$4E
+ jmp .error
+.lab_605 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ ldx #$00
+ clc
+ lda #$03
+ sta $0200,X
+ adc #$07
+ inx
+ sta $0200,X
+ adc #$07
+ inx
+ sta $0200,X
+ adc #$07
+ inx
+ sta $0200,X
+ adc #$07
+ inx
+ sta $0200,X
+ adc #$07
+ inx
+ sta $0200,X
+ adc #$07
+ inx
+ sta $0200,X
+ ldx #$00
+ clc
+ lda $0200,X
+ cmp #$03
+ bne .lab_61
+ inx
+ lda $0200,X
+ cmp #$0A
+ bne .lab_61
+ inx
+ lda $0200,X
+ cmp #$11
+ bne .lab_61
+ inx
+ lda $0200,X
+ cmp #$18
+ bne .lab_61
+ inx
+ lda $0200,X
+ cmp #$1F
+ bne .lab_61
+ inx
+ lda $0200,X
+ cmp #$26
+ bne .lab_61
+ inx
+ lda $0200,X
+ cmp #$2D
+ bne .lab_61
+ jmp .lab_615
+.lab_61 lda #$4F
+ jmp .error
+.lab_615 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ ldy #$00
+ clc
+ lda #$03
+ sta $0200,Y
+ adc #$07
+ iny
+ sta $0200,Y
+ adc #$07
+ iny
+ sta $0200,Y
+ adc #$07
+ iny
+ sta $0200,Y
+ adc #$07
+ iny
+ sta $0200,Y
+ adc #$07
+ iny
+ sta $0200,Y
+ adc #$07
+ iny
+ sta $0200,Y
+ ldy #$00
+ clc
+ lda $0200,Y
+ cmp #$03
+ bne .lab_62
+ iny
+ lda $0200,Y
+ cmp #$0A
+ bne .lab_62
+ iny
+ lda $0200,Y
+ cmp #$11
+ bne .lab_62
+ iny
+ lda $0200,Y
+ cmp #$18
+ bne .lab_62
+ iny
+ lda $0200,Y
+ cmp #$1F
+ bne .lab_62
+ iny
+ lda $0200,Y
+ cmp #$26
+ bne .lab_62
+ iny
+ lda $0200,Y
+ cmp #$2D
+ bne .lab_62
+ jmp .lab_625
+.lab_62 lda #$50
+ jmp .error
+.lab_625 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$52
+ sta $0200
+ lda #$24
+ sta $0201
+ lda #$78
+ sta $0202
+ lda #$00
+ ldx #$00
+ clc
+ adc $0200,X
+ clc
+ inx
+ adc $0200,X
+ clc
+ inx
+ adc $0200,X
+ cmp #$EE
+ beq .lab_63
+ lda #$51
+ jmp .error
+.lab_63 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$68
+ sta $0200
+ lda #$13
+ sta $0201
+ lda #$95
+ sta $0202
+ lda #$00
+ ldy #$00
+ clc
+ adc $0200,Y
+ clc
+ iny
+ adc $0200,Y
+ clc
+ iny
+ adc $0200,Y
+ cmp #$10
+ beq .lab_64
+ lda #$52
+ jmp .error
+.lab_64 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$34
+ sta $0200
+ lda #$54
+ sta $0201
+ lda #$97
+ sta $0202
+ lda #$FF
+ ldy #$00
+ and $0200,Y
+ iny
+ and $0200,Y
+ iny
+ and $0200,Y
+ cmp #$14
+ beq .lab_65
+ lda #$53
+ jmp .error
+.lab_65 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$34
+ sta $0200
+ lda #$54
+ sta $0201
+ lda #$97
+ sta $0202
+ lda #$FF
+ ldx #$00
+ and $0200,X
+ inx
+ and $0200,X
+ inx
+ and $0200,X
+ cmp #$14
+ beq .lab_66
+ lda #$54
+ jmp .error
+.lab_66 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$64
+ sta $00
+ lda #$39
+ clc
+ adc $00
+ cmp #$9D
+ beq .lab_67
+ lda #$55
+ jmp .error
+.lab_67 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$95
+ sta $00
+ lda #$76
+ sta $01
+ lda #$45
+ sta $02
+ ldx #$00
+ lda #$00
+ clc
+ adc $00,X
+ inx
+ clc
+ adc $00,X
+ inx
+ clc
+ adc $00,X
+ cmp #$50
+ beq .lab_68
+ lda #$56
+ jmp .error
+.lab_68 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$64
+ sta $00
+ lda #$39
+ and $00
+ cmp #$20
+ beq .lab_69
+ lda #$57
+ jmp .error
+.lab_69 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$95
+ sta $00
+ lda #$76
+ sta $01
+ lda #$45
+ sta $02
+ ldx #$00
+ lda #$FF
+ and $00,X
+ inx
+ and $00,X
+ inx
+ and $00,X
+ cmp #$04
+ beq .lab_70
+ lda #$58
+ jmp .error
+.lab_70 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$97
+ sta $0200
+ lda #$78
+ sta $0201
+ lda #$45
+ sta $0202
+ ldx #$00
+ lda #$97
+ cmp $0200,X
+ bne .lab_71
+ lda #$78
+ inx
+ cmp $0200,X
+ bne .lab_71
+ lda #$45
+ inx
+ cmp $0200,X
+ bne .lab_71
+ jmp .lab_715
+.lab_71 lda #$59
+ jmp .error
+.lab_715 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$97
+ sta $0200
+ lda #$78
+ sta $0201
+ lda #$45
+ sta $0202
+ ldy #$00
+ lda #$97
+ cmp $0200,Y
+ bne .lab_72
+ lda #$78
+ iny
+ cmp $0200,Y
+ bne .lab_72
+ lda #$45
+ iny
+ cmp $0200,Y
+ bne .lab_72
+ jmp .lab_725
+.lab_72 lda #$5A
+ jmp .error
+.lab_725 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$97
+ sta $0200
+ lda #$78
+ sta $0201
+ lda #$45
+ sta $0202
+ ldx #$00
+ lda #$97
+ cmp $0200,X
+ bne .lab_73
+ lda #$78
+ inx
+ cmp $0200,X
+ bne .lab_73
+ lda #$45
+ inx
+ cmp $0200,X
+ bne .lab_73
+ jmp .lab_735
+.lab_73 lda #$5B
+ jmp .error
+.lab_735 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$95
+ sta $02
+ lda #$00
+ lda #$95
+ cmp $02
+ beq .lab_74
+ lda #$5C
+ jmp .error
+.lab_74 lda #$75
+ sta $02
+ lda #$67
+ cmp $02
+ bne .lab_75
+ lda #$5D
+ jmp .error
+.lab_75 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$36
+ sta $02
+ lda #$00
+ ldx #$36
+ cpx $02
+ beq .lab_76
+ lda #$5E
+ jmp .error
+.lab_76 lda #$57
+ sta $02
+ ldx #$39
+ cpx $02
+ bne .lab_77
+ lda #$5F
+ jmp .error
+.lab_77 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$75
+ sta $02
+ lda #$00
+ ldy #$75
+ cpy $02
+ beq .lab_78
+ lda #$60
+ jmp .error
+.lab_78 lda #$43
+ sta $02
+ ldy #$24
+ cpy $02
+ bne .lab_79
+ lda #$61
+ jmp .error
+.lab_79 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ nop ; was cli
+ lda #$00
+ sta var_2
+ lda #$01
+ sta var_1
+ lda #$10
+
+
+ sta io_base+io_tim0_end
+ sta io_base+io_tim0_start
+ ldx #$00
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ cpx #$10
+ beq .lab_80
+ lda #$62
+ jmp .error
+.lab_80 lda var_2
+ cmp #$00 ; was 1 if int serviced
+ beq .lab_81
+ lda #$63
+ jmp .error
+.lab_81 nop ; was sei to disable interrupt
+ lda #$00
+ sta var_2
+ lda #$01
+ sta var_1
+ lda #$10
+ sta io_base+io_tim0_end
+ sta io_base+io_tim0_start
+ ldx #$00
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ cpx #$10
+ beq .lab_82
+ lda #$62
+ jmp .error
+.lab_82 lda var_2
+ cmp #$00
+ beq .lab_83
+ lda #$63
+ jmp .error
+.lab_83 lda #$00
+ sta var_1
+ sta io_base+io_tim0_end
+ inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$00
+ sta var_4
+ lda #$01
+ sta var_3
+ lda #$10
+ sta io_base+io_tim0_end ; change to tim1 for nmi
+ sta io_base+io_tim0_start ; change to tim1 for nmi
+ ldx #$00
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ cpx #$10
+ beq .lab_84
+ lda #$64
+ jmp .error
+.lab_84 lda var_4
+ cmp #$00 ; change to 1 if nmi serviced
+ beq .lab_85
+ lda #$65
+ jmp .error
+.lab_85 lda #$00
+ sta var_3
+ sta io_base+io_tim1_end
+ inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ jmp .lab_865
+.lab_86 jmp .lab_866
+.lab_865 sec
+ bcs .lab_86
+ nop
+ nop
+ nop
+ lda #$66
+ jmp .error
+.lab_866 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ sec
+ lda #$34
+ sbc #$75
+ bcc .lab_87
+ lda #$67
+ jmp .error
+.lab_87 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+
+ ;; Break test
+ ;;
+.lab_89 ldx $00
+
+ inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$24 ; keep int disabled
+ pha
+ plp
+ stx $08
+ lda #$00
+ sta var_2
+ lda #$01
+ sta var_1
+ sta var_3
+ ldx #$59
+ nop ; was brk
+ inx
+ lda #$00
+ sta var_1
+ lda var_2
+ cmp #$00 ; was 1 if brk taken
+ beq .lab_92
+ lda #$70
+ jmp .error
+
+.lab_92 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$53
+ sta $30
+ lda #$00
+ ldx #$40
+ lda $F0,X
+ cmp #$53
+ beq .lab_93
+ lda #$73
+ jmp .error
+.lab_93 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ clc
+ lda #$FF
+ adc #$01
+ bcs .lab_94
+ lda #$74
+ jmp .error
+.lab_94 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ sec
+ lda #$7F
+ sbc #$7E
+ bvc .lab_95
+ lda #$75
+ jmp .error
+.lab_95 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$FF
+ pha
+ plp
+ php
+ pla
+ cmp #$FF
+ beq .lab_96
+ lda #$76
+ jmp .error
+.lab_96 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ lda #$40
+ ldx #$00
+ sta $0200,X
+ inx
+ lsr a
+ sta $0200,X
+ inx
+ lsr a
+ sta $0200,X
+ inx
+ lsr a
+ sta $0200,X
+ inx
+ lsr a
+ sta $0200,X
+ inx
+ lsr a
+ sta $0200,X
+ inx
+ lsr a
+ sta $0200,X
+ ldx #$00
+ asl $0200,X
+ inx
+ asl $0200,X
+ inx
+ asl $0200,X
+ inx
+ asl $0200,X
+ inx
+ asl $0200,X
+ inx
+ asl $0200,X
+ inx
+ asl $0200,X
+ lda #$00
+ clc
+ cld
+ adc $0200
+ adc $0201
+ adc $0202
+ adc $0203
+ adc $0204
+ adc $0205
+ adc $0206
+ cmp #$FE
+ beq .lab_97
+ lda #$77
+ jmp .error
+.lab_97 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ ldx #$42
+ ldy #$00
+ stx $0200
+ ldx #$9F
+ stx $0201
+ ldx $0200,Y
+ cpx #$42
+ beq .lab_98
+ lda #$48
+ jmp .error
+.lab_98 ldx $0201,Y
+ cpx #$9F
+ beq .lab_100
+ lda #$78
+ jmp .error
+
+
+ ;; indirectx test
+
+
+.lab_100 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ ldy #$00
+ ldx #$00
+ lda #$00
+ sta c_test
+ sta n_test
+ sta v_test
+ sta z_test
+ sta pointer
+ lda #$c0
+ sta pointer+1
+ clc
+.lab_101 adc (pointer,x)
+ bpl .lab_103
+ bne .lab_102
+ inc n_test
+ inc z_test
+ jmp .lab_104
+.lab_102 inc n_test
+ jmp .lab_104
+.lab_103 bne .lab_104
+ inc z_test
+.lab_104 bcc .lab_105
+ inc c_test
+.lab_105 bvc .lab_106
+ inc v_test
+.lab_106 inc pointer
+ bne .lab_101
+
+ cmp #$c8
+ bne .error
+ lda c_test
+ cmp #$4d
+ bne .error
+ lda n_test
+ cmp #$8b
+ bne .error
+ lda v_test
+ cmp #$36
+ bne .error
+ lda z_test
+ cmp #$02
+ bne .error
+
+
+
+
+
+ ;; indirecty test
+
+
+.lab_110 inc t_cnt
+ lda t_cnt
+ inc io_base+io_gpio_0
+ ldy #$00
+ ldx #$00
+ lda #$00
+ sta c_test
+ sta n_test
+ sta v_test
+ sta z_test
+ sta pointer
+ lda #$c0
+ sta pointer+1
+ clc
+.lab_111 adc (pointer),y
+ bpl .lab_113
+ bne .lab_112
+ inc n_test
+ inc z_test
+ jmp .lab_114
+.lab_112 inc n_test
+ jmp .lab_114
+.lab_113 bne .lab_114
+ inc z_test
+.lab_114 bcc .lab_115
+ inc c_test
+.lab_115 bvc .lab_116
+ inc v_test
+.lab_116 iny
+ bne .lab_111
+
+ cmp #$c8
+ bne .error
+ lda c_test
+ cmp #$4d
+ bne .error
+ lda n_test
+ cmp #$8b
+ bne .error
+ lda v_test
+ cmp #$36
+ bne .error
+ lda z_test
+ cmp #$02
+ bne .error
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ ;; pass end loop
+.good sei
+ lda #$FF
+ sta io_base+io_gpio_0
+ lda #$FF
+ sta io_base+io_gpio_1
+ jmp .end_lp
+
+ ;; error & end loop
+.error sei
+ sta io_base+io_gpio_1
+.end_lp lda #$00
+ pha
+ plp
+ jmp .end_lp
+
+
+ ;; Interrupt service routine
+.nmi_vec pha
+ txa
+ pha
+ tya
+ pha
+ lda var_1
+ cmp #$00
+ bne .nmi_001
+ lda #$E0
+ jmp .error
+.nmi_001 sta io_base+io_tim0_end
+ inc var_2
+ pla
+ tay
+ pla
+ tax
+ pla
+ rti
+
+ ;; Interrupt service routine
+
+.irq_vec pha
+ txa
+ pha
+ tya
+ pha
+ lda var_3
+ cmp #$00
+ bne .irq_001
+ lda #$E0
+ jmp .error
+.irq_001 sta io_base+io_tim1_end
+ inc var_4
+ inc var_2
+ pla
+ tay
+ pla
+ tax
+ pla
+ rti
+
+
+ * = $fffa ; vectors
+
+
+
+ dw .nmi_vec ;
+ dw .start ;
+ dw .irq_vec ;
+
+
+
+
+
+ code
+
+
+
+
+
+
trunk/projects/Mos6502/sw/inst_2_test/inst_2_test.asm
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/sw/inst_2_test/Makefile
===================================================================
--- trunk/projects/Mos6502/sw/inst_2_test/Makefile (nonexistent)
+++ trunk/projects/Mos6502/sw/inst_2_test/Makefile (revision 44)
@@ -0,0 +1,7 @@
+include ../../bin/Makefile.root
+code=inst_2_test
+
+all:asm_6502
+
+
+
trunk/projects/Mos6502/sw/inst_2_test/Makefile
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/sw/io_irq_2/io_irq_2.asm
===================================================================
--- trunk/projects/Mos6502/sw/io_irq_2/io_irq_2.asm (nonexistent)
+++ trunk/projects/Mos6502/sw/io_irq_2/io_irq_2.asm (revision 44)
@@ -0,0 +1,110 @@
+
+ include ../io_module/io_module.asm
+
+
+ * = $ff00 ; assemble start
+ code
+
+.start nop
+ ldx #00
+ ldy #00
+ lda io_base+io_gpio_0
+ sec
+ adc #00
+ sta io_base+io_gpio_0
+ lda io_base+io_gpio_0
+ sec
+ adc #00
+ sta io_base+io_gpio_0
+
+
+ lda #$01
+ ;
+ sta io_base+io_pic_irq_en
+
+ lda #$04
+ sta io_base+io_pic_nmi_en
+
+
+
+ lda #$c0
+ sta io_base+io_uart_cnt
+ lda #$42
+ sta io_base+io_uart_xmt
+ cli ; was cli
+ lda #$fe
+ sta io_base+io_tim0_start
+
+ ldx #$00
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+
+
+.lab_80 lda $05
+ jmp .lab_80
+
+
+
+
+
+
+.irq_vec pha
+ txa
+ pha
+ tya
+ pha
+ lda io_base+io_gpio_0
+ sec
+ adc #00
+ sta io_base+io_gpio_0
+ lda #$fe
+ sta io_base+io_tim0_end
+ sta io_base+io_tim0_start
+ pla
+ tay
+ pla
+ tax
+ pla
+ rti
+
+.nmi_vec pha
+ lda io_base+io_uart_rcv
+ sec
+ adc #01
+ sta io_base+io_uart_xmt
+ lda io_base+io_gpio_1
+ sec
+ adc #00
+ sta io_base+io_gpio_1
+ pla
+ rti
+
+
+ * = $fffa
+ dw .nmi_vec
+ dw .start
+ dw .irq_vec
+
+
+
+ code
+
+
+
+
+
+
trunk/projects/Mos6502/sw/io_irq_2/io_irq_2.asm
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/sw/io_irq_2/Makefile
===================================================================
--- trunk/projects/Mos6502/sw/io_irq_2/Makefile (nonexistent)
+++ trunk/projects/Mos6502/sw/io_irq_2/Makefile (revision 44)
@@ -0,0 +1,5 @@
+include ../../bin/Makefile.root
+code=io_irq_2
+
+all: asm_6502
+
trunk/projects/Mos6502/sw/io_irq_2/Makefile
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/sw/irq_2_test/irq_2_test.asm
===================================================================
--- trunk/projects/Mos6502/sw/irq_2_test/irq_2_test.asm (nonexistent)
+++ trunk/projects/Mos6502/sw/irq_2_test/irq_2_test.asm (revision 44)
@@ -0,0 +1,603 @@
+
+ include ../io_module/io_module.asm
+
+
+ ;; page zero variables used during test
+c_test = $40 ;
+n_test = $41 ;
+v_test = $42 ;
+z_test = $43 ;
+pointer = $44 ;
+counter0 = $46 ;
+counter1 = $48 ;
+
+ * = $f000 ; assemble at $f000
+ code
+
+
+.start nop
+ lda #$00
+ sta counter0
+ sta counter1
+ sta $04
+ sta $05
+ sta $06
+ sta $07
+ lda #$00
+ sta io_base+io_gpio_0
+ lda io_base+io_gpio_0
+ lda #$01
+ sta io_base+io_gpio_0
+ lda io_base+io_gpio_0
+ sta io_base+io_pic_irq_en
+ jmp .lab_00
+ lda #$00
+ jmp .error
+.lab_00 lda #$01
+ sta io_base+io_gpio_0
+ lda io_base+io_gpio_0
+ lda #$02
+ sta io_base+io_gpio_0
+ lda io_base+io_gpio_0
+ clc
+ bcc .lab_44
+ lda #$01
+ jmp .error
+
+.lab_44 lda #$28
+ sta io_base+io_gpio_0
+ lda #$EF
+ sta $0200
+ inc $0200
+ lda #$F0
+ cmp $0200
+ beq .lab_45
+ lda #$39
+ jmp .error
+.lab_45 lda #$FF
+ sta $0200
+ inc $0200
+ beq .lab_46
+ lda #$40
+ jmp .error
+.lab_46 lda #$29
+ sta io_base+io_gpio_0
+ ldy #$32
+ sty $0201
+ ldx #$B4
+ stx $0200
+ lda #$86
+ eor $0200
+ cmp $0201
+ beq .lab_47
+ lda #$41
+ jmp .error
+.lab_47 lda #$2A
+ sta io_base+io_gpio_0
+ ldy #$B6
+ sty $0201
+ ldx #$B4
+ stx $0200
+ lda #$86
+ ora $0200
+ cmp $0201
+ beq .lab_59
+ lda #$42
+ jmp .error
+
+
+
+.lab_59 lda #$31
+ sta io_base+io_gpio_0
+ lda #$42
+ pha
+ lda #$ED
+ pha
+ lda #$BE
+ pha
+ lda #$00
+ pla
+ cmp #$BE
+ bne .lab_60
+ pla
+ cmp #$ED
+ bne .lab_60
+ pla
+ cmp #$42
+ bne .lab_60
+ jmp .lab_605
+.lab_60 lda #$4E
+ jmp .error
+.lab_605 lda #$32
+ sta io_base+io_gpio_0
+ ldx #$00
+ clc
+ lda #$03
+ sta $0200,X
+ adc #$07
+ inx
+ sta $0200,X
+ adc #$07
+ inx
+ sta $0200,X
+ adc #$07
+ inx
+ sta $0200,X
+ adc #$07
+ inx
+ sta $0200,X
+ adc #$07
+ inx
+ sta $0200,X
+ adc #$07
+ inx
+ sta $0200,X
+ ldx #$00
+ clc
+ lda $0200,X
+ cmp #$03
+ bne .lab_61
+ inx
+ lda $0200,X
+ cmp #$0A
+ bne .lab_61
+ inx
+ lda $0200,X
+ cmp #$11
+ bne .lab_61
+ inx
+ lda $0200,X
+ cmp #$18
+ bne .lab_61
+ inx
+ lda $0200,X
+ cmp #$1F
+ bne .lab_61
+ inx
+ lda $0200,X
+ cmp #$26
+ bne .lab_61
+ inx
+ lda $0200,X
+ cmp #$2D
+ bne .lab_61
+ jmp .lab_615
+.lab_61 lda #$4F
+ jmp .error
+.lab_615 lda #$33
+ sta io_base+io_gpio_0
+ ldy #$00
+ clc
+ lda #$03
+ sta $0200,Y
+ adc #$07
+ iny
+ sta $0200,Y
+ adc #$07
+ iny
+ sta $0200,Y
+ adc #$07
+ iny
+ sta $0200,Y
+ adc #$07
+ iny
+ sta $0200,Y
+ adc #$07
+ iny
+ sta $0200,Y
+ adc #$07
+ iny
+ sta $0200,Y
+ ldy #$00
+ clc
+ lda $0200,Y
+ cmp #$03
+ bne .lab_62
+ iny
+ lda $0200,Y
+ cmp #$0A
+ bne .lab_62
+ iny
+ lda $0200,Y
+ cmp #$11
+ bne .lab_62
+ iny
+ lda $0200,Y
+ cmp #$18
+ bne .lab_62
+ iny
+ lda $0200,Y
+ cmp #$1F
+ bne .lab_62
+ iny
+ lda $0200,Y
+ cmp #$26
+ bne .lab_62
+ iny
+ lda $0200,Y
+ cmp #$2D
+ bne .lab_62
+ jmp .lab_625
+.lab_62 lda #$50
+ jmp .error
+.lab_625 lda #$34
+ sta io_base+io_gpio_0
+ lda #$52
+ sta $0200
+ lda #$24
+ sta $0201
+ lda #$78
+ sta $0202
+ lda #$00
+ ldx #$00
+ clc
+ adc $0200,X
+ clc
+ inx
+ adc $0200,X
+ clc
+ inx
+ adc $0200,X
+ cmp #$EE
+ beq .lab_63
+ lda #$51
+ jmp .error
+.lab_63 lda #$35
+ sta io_base+io_gpio_0
+ lda #$68
+ sta $0200
+ lda #$13
+ sta $0201
+ lda #$95
+ sta $0202
+ lda #$00
+ ldy #$00
+ clc
+ adc $0200,Y
+ clc
+ iny
+ adc $0200,Y
+ clc
+ iny
+ adc $0200,Y
+ cmp #$10
+ beq .lab_64
+ lda #$52
+ jmp .error
+.lab_64 lda #$36
+ sta io_base+io_gpio_0
+ lda #$34
+ sta $0200
+ lda #$54
+ sta $0201
+ lda #$97
+ sta $0202
+ lda #$FF
+ ldy #$00
+ and $0200,Y
+ iny
+ and $0200,Y
+ iny
+ and $0200,Y
+ cmp #$14
+ beq .lab_65
+ lda #$53
+ jmp .error
+.lab_65 lda #$37
+ sta io_base+io_gpio_0
+ lda #$34
+ sta $0200
+ lda #$54
+ sta $0201
+ lda #$97
+ sta $0202
+ lda #$FF
+ ldx #$00
+ and $0200,X
+ inx
+ and $0200,X
+ inx
+ and $0200,X
+ cmp #$14
+ beq .lab_66
+ lda #$54
+ jmp .error
+.lab_66 lda #$38
+ sta io_base+io_gpio_0
+ lda #$64
+ sta $00
+ lda #$39
+ clc
+ adc $00
+ cmp #$9D
+ beq .lab_735
+ lda #$55
+ jmp .error
+.lab_735 lda #$3F
+ sta io_base+io_gpio_0
+ lda #$95
+ sta $02
+ lda #$00
+ lda #$95
+ cmp $02
+ beq .lab_74
+ lda #$5C
+ jmp .error
+.lab_74 lda #$75
+ sta $02
+ lda #$67
+ cmp $02
+ bne .lab_75
+ lda #$5D
+ jmp .error
+.lab_75 lda #$40
+ sta io_base+io_gpio_0
+ lda #$36
+ sta $02
+ lda #$00
+ ldx #$36
+ cpx $02
+ beq .lab_76
+ lda #$5E
+ jmp .error
+.lab_76 lda #$57
+ sta $02
+ ldx #$39
+ cpx $02
+ bne .lab_77
+ lda #$5F
+ jmp .error
+.lab_77 lda #$41
+ sta io_base+io_gpio_0
+ lda #$75
+ sta $02
+ lda #$00
+ ldy #$75
+ cpy $02
+ beq .lab_78
+ lda #$60
+ jmp .error
+.lab_78 lda #$43
+ sta $02
+ ldy #$24
+ cpy $02
+ bne .lab_79
+ lda #$61
+ jmp .error
+.lab_79 lda #$42
+ sta io_base+io_gpio_0
+ cli ; was cli
+ lda #$00
+ sta $05
+ lda #$01
+ sta $04
+ lda #$10
+ sta io_base+io_tim0_end
+ sta io_base+io_tim0_start
+ ldx #$00
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ cpx #$10
+ beq .lab_80
+ lda #$62
+ jmp .error
+.lab_80 lda $05
+ cmp #$00 ; was 1 if int serviced
+ beq .lab_81
+ lda #$63
+ jmp .error
+.lab_81 nop ; was sei to disable interrupt
+ lda #$00
+ sta $05
+ lda #$01
+ sta $04
+ lda #$10
+ sta io_base+io_tim0_end
+ sta io_base+io_tim0_start
+ ldx #$00
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ cpx #$10
+ beq .lab_82
+ lda #$62
+ jmp .error
+.lab_82 lda $05
+ cmp #$00
+ beq .lab_83
+ lda #$63
+ jmp .error
+.lab_83 lda #$00
+ sta $04
+ sta io_base+io_tim0_end
+ lda #$43
+ sta io_base+io_gpio_0
+ lda #$00
+ sta $07
+ lda #$01
+ sta $06
+ lda #$10
+ sta io_base+io_tim0_end ; change to tim1 for nmi
+ sta io_base+io_tim0_start ; change to tim1 for nmi
+ ldx #$00
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ inx
+ cpx #$10
+ beq .lab_84
+ lda #$64
+ jmp .error
+.lab_84 lda $07
+ cmp #$00 ; change to 1 if nmi serviced
+ beq .lab_85
+ lda #$65
+ jmp .error
+.lab_85 lda #$00
+ sta $06
+ sta io_base+io_tim1_end
+ lda #$44
+ sta io_base+io_gpio_0
+ jmp .lab_865
+.lab_86 jmp .lab_866
+.lab_865 sec
+ bcs .lab_86
+ nop
+ nop
+ nop
+ lda #$66
+ jmp .error
+.lab_866 lda #$45
+ sta io_base+io_gpio_0
+ sec
+ lda #$34
+ sbc #$75
+ bcc .lab_92
+ lda #$67
+ jmp .error
+
+.lab_92 lda #$48
+ sta io_base+io_gpio_0
+ lda #$53
+ sta $30
+ lda #$00
+ ldx #$40
+ lda $F0,X
+ cmp #$53
+ beq .lab_93
+ lda #$73
+ jmp .error
+.lab_93 lda #$49
+ sta io_base+io_gpio_0
+ clc
+ lda #$FF
+ adc #$01
+ bcs .lab_94
+ lda #$74
+ jmp .error
+.lab_94 lda #$4A
+ sta io_base+io_gpio_0
+ sec
+ lda #$7F
+ sbc #$7E
+ bvc .good
+ lda #$75
+ jmp .error
+
+
+
+ ;; pass end loop
+.good nop
+ lda #$FF
+ sta io_base+io_gpio_0
+ jmp .end_lp
+
+ ;; error & end loop
+.error sei
+ sta io_base+io_gpio_1
+.end_lp lda #$00
+ pha
+ plp
+ jmp .end_lp
+
+
+ ;; Interrupt service routine
+.nmi_vec pha
+ txa
+ pha
+ tya
+ pha
+ lda #$10
+.nmi_001 sta io_base+io_tim0_end
+ inc $05
+ pla
+ tay
+ pla
+ tax
+ pla
+ rti
+
+ ;; Interrupt service routine
+
+.irq_vec pha
+ txa
+ pha
+ tya
+ pha
+ lda #$10
+ sta io_base+io_tim0_end
+ lda #$80
+.irq_001 sta io_base+io_tim0_start
+ inc counter0
+ bne .irq_002
+ inc counter1
+ bne .irq_002
+ inc io_base+io_gpio_1
+.irq_002 pla
+ tay
+ pla
+ tax
+ pla
+ rti
+
+
+
+
+ * = $fffa ; vectors
+
+
+
+ dw .nmi_vec ;
+ dw .start ;
+ dw .irq_vec ;
+
+
+
+
+
+ code
+
+
+
+
+
+
trunk/projects/Mos6502/sw/irq_2_test/irq_2_test.asm
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/sw/irq_2_test/Makefile
===================================================================
--- trunk/projects/Mos6502/sw/irq_2_test/Makefile (nonexistent)
+++ trunk/projects/Mos6502/sw/irq_2_test/Makefile (revision 44)
@@ -0,0 +1,5 @@
+include ../../bin/Makefile.root
+code=irq_2_test
+
+all: asm_6502
+
trunk/projects/Mos6502/sw/irq_2_test/Makefile
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/sw/io_poll_2/Makefile
===================================================================
--- trunk/projects/Mos6502/sw/io_poll_2/Makefile (nonexistent)
+++ trunk/projects/Mos6502/sw/io_poll_2/Makefile (revision 44)
@@ -0,0 +1,5 @@
+include ../../bin/Makefile.root
+code=io_poll_2
+
+all: asm_6502
+
trunk/projects/Mos6502/sw/io_poll_2/Makefile
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/Mos6502/sw/io_poll_2/io_poll_2.asm
===================================================================
--- trunk/projects/Mos6502/sw/io_poll_2/io_poll_2.asm (nonexistent)
+++ trunk/projects/Mos6502/sw/io_poll_2/io_poll_2.asm (revision 44)
@@ -0,0 +1,66 @@
+
+ include ../io_module/io_module.asm
+
+
+
+ * = $ff00 ; assemble start
+ code
+
+.start nop
+ ldx #00
+ ldy #00
+ lda io_base+io_gpio_0
+ sec
+ adc #00
+ sta io_base+io_gpio_0
+ lda io_base+io_gpio_0
+ sec
+ adc #00
+ sta io_base+io_gpio_0
+
+
+
+
+ lda #$c0
+ sta io_base+io_uart_cnt
+ lda #$42
+ sta io_base+io_uart_xmt
+
+.lab_80 lda io_base+io_pic_int
+ sta io_base+io_gpio_1
+ and #$04
+ beq .lab_80
+ lda io_base+io_uart_rcv
+ sec
+ adc #01
+ sta io_base+io_uart_xmt
+ inc io_base+io_gpio_0
+ jmp .lab_80
+
+
+
+
+.irq_vec pha
+ txa
+ tax
+ pla
+ rti
+
+.nmi_vec pha
+ pla
+ rti
+
+ * = $fffa ; vectors
+
+
+ dw .nmi_vec ;
+ dw .start ;
+ dw .irq_vec ;
+
+ code
+
+
+
+
+
+
trunk/projects/Mos6502/sw/io_poll_2/io_poll_2.asm
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: trunk/projects/logic/ip/io_module/rtl/verilog/io_module_mem.v
===================================================================
--- trunk/projects/logic/ip/io_module/rtl/verilog/io_module_mem.v (nonexistent)
+++ trunk/projects/logic/ip/io_module/rtl/verilog/io_module_mem.v (revision 44)
@@ -0,0 +1,130 @@
+`include "io_module_defines"
+
+`ifdef MEM
+
+module `VARIANT`MEM
+
+#(
+ parameter BASE_ADDR = 4'h0,
+ parameter BASE_WIDTH = 4,
+ parameter ADDR_WIDTH = 16,
+ parameter MEM_WIDTH = 23,
+ parameter MEM_FRAME = 10
+)
+
+(
+
+input wire clk,
+input wire reset,
+input wire enable,
+input wire cs,
+input wire wr,
+input wire rd,
+input wire [ADDR_WIDTH-1:0] waddr,
+input wire [ADDR_WIDTH-1:0] raddr,
+input wire [7:0] wdata,
+output reg [7:0] rdata,
+
+output reg [7:0] wait_st,
+output reg [7:0] bank,
+
+input wire cs_mem,
+input wire [15:0] mem_add,
+
+output reg [23:1] ext_add,
+output reg [15:0] ext_wdata,
+input wire [15:0] ext_rdata,
+output reg ext_ub,
+output reg ext_lb,
+output reg ext_rd,
+output reg ext_wr,
+output reg [1:0] ext_cs
+
+
+
+
+
+);
+
+parameter WAIT_ST = 4'h0;
+parameter BANK = 4'h2;
+
+reg was;
+reg ras;
+
+always@(*) was = (waddr[ADDR_WIDTH-1:ADDR_WIDTH-BASE_WIDTH] == BASE_ADDR);
+always@(*) ras = (raddr[ADDR_WIDTH-1:ADDR_WIDTH-BASE_WIDTH] == BASE_ADDR);
+
+always@(*)
+ if(rd && cs && ras)
+ begin
+ case(raddr[3:0])
+ WAIT_ST: rdata = wait_st;
+ BANK: rdata = bank;
+ default: rdata = 8'h00;
+ endcase
+ end
+ else rdata = 8'hFF;
+
+
+
+always@(posedge clk)
+if (reset)
+ begin
+ wait_st <= 8'h04;
+ bank <= 8'h00;
+ end
+else
+if(wr && was && cs && waddr[3:0] == WAIT_ST)
+ begin
+ wait_st <= wdata;
+ end
+else
+if(wr && was && cs && waddr[3:0] == BANK)
+ begin
+ bank <= wdata;
+ end
+else
+ begin
+ wait_st <= wait_st;
+ bank <= bank;
+ end
+
+
+
+
+
+
+
+
+always@(posedge clk)
+ if(reset)
+ begin
+ ext_add <= 'b0;
+ ext_wdata <= 16'b0000000000000;
+ ext_rd <= 1'b0;
+ ext_wr <= 1'b0;
+ ext_cs <= 2'b00;
+ ext_ub <= 1'b0;
+ ext_lb <= 1'b0;
+ end
+ else
+ begin
+ ext_add <= {10'b0000000000, mem_add[13:1]};
+ ext_wdata <= {wdata,wdata};
+ ext_rd <= cs_mem && rd;
+ ext_wr <= cs_mem && wr;
+ ext_cs <= {1'b0,cs_mem};
+ ext_ub <= cs_mem && mem_add[0];
+ ext_lb <= cs_mem && !mem_add[0];
+ end
+
+
+
+
+
+
+
+endmodule
+
+`endif
trunk/projects/logic/ip/io_module/rtl/verilog/io_module_mem.v
Property changes :
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property