diff options
author | Timothy Pearson <kb9vqf@pearsoncomputing.net> | 2012-10-01 21:07:55 -0500 |
---|---|---|
committer | Timothy Pearson <kb9vqf@pearsoncomputing.net> | 2012-10-01 21:07:55 -0500 |
commit | d1b70f80180fe4b5ac6078e2be9678fc36d74c5c (patch) | |
tree | 2e46de7a644f89e36842247af6826ff00a0d3fa4 /fpga/xilinx/programmer/dependencies/libxsvf/xsvftool-xpcu.src/.svn/text-base/hardware.v.svn-base | |
parent | ae161b4a6a978922747cf09e8c04479340825852 (diff) | |
download | ulab-d1b70f80180fe4b5ac6078e2be9678fc36d74c5c.tar.gz ulab-d1b70f80180fe4b5ac6078e2be9678fc36d74c5c.zip |
Add initial files for direct FPGA programming
Diffstat (limited to 'fpga/xilinx/programmer/dependencies/libxsvf/xsvftool-xpcu.src/.svn/text-base/hardware.v.svn-base')
-rw-r--r-- | fpga/xilinx/programmer/dependencies/libxsvf/xsvftool-xpcu.src/.svn/text-base/hardware.v.svn-base | 141 |
1 files changed, 141 insertions, 0 deletions
diff --git a/fpga/xilinx/programmer/dependencies/libxsvf/xsvftool-xpcu.src/.svn/text-base/hardware.v.svn-base b/fpga/xilinx/programmer/dependencies/libxsvf/xsvftool-xpcu.src/.svn/text-base/hardware.v.svn-base new file mode 100644 index 0000000..09713fb --- /dev/null +++ b/fpga/xilinx/programmer/dependencies/libxsvf/xsvftool-xpcu.src/.svn/text-base/hardware.v.svn-base @@ -0,0 +1,141 @@ +/* + * xsvftool-xpcu - An (X)SVF player for the Xilinx Platform Cable USB + * + * Copyright (C) 2011 RIEGL Research ForschungsGmbH + * Copyright (C) 2011 Clifford Wolf <clifford@clifford.at> + * + * Permission to use, copy, modify, and/or distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + * + */ + +module top( + clk, + tck, tms, tdi, tdo, init, init_b, + fd0, fd1, fd2, fd3, fd4, fd5, fd6, fd7, + ctl0, ctl1, ctl2, + pc0, pc1, pc2, pc3, pc4, pc5, pc6, pc7, + pd0, pd1, pd2, pd3, pd4, pd5, pd6, pd7 +); + +// General Signal +input clk; + +// JTAG Interface +output tck, tms, tdi, init; +input tdo, init_b; + +// GPIF Interface +input fd0, fd1, fd2, fd3, fd4, fd5, fd6, fd7; +input ctl0, ctl1, ctl2; + +// The entire PC and PD regs for various flags +output pc0, pc1, pc2, pc3, pc4, pc5, pc6, pc7; +input pd0, pd1, pd2, pd3, pd4, pd5, pd6, pd7; + +// simple direct i/o mappings +assign pc3 = tdo; +assign pc1 = init_b; +assign init = pd2; + +// checksum +wire chksum_rst, chksum_clk; +reg [23:0] chksum_buffer; +always @(posedge chksum_clk) begin + if (chksum_rst) + chksum_buffer <= + `include "hardware_cksum_vl.inc" + ; + else + chksum_buffer <= chksum_buffer << 1; +end +assign chksum_rst = pd0; +assign chksum_clk = pd1; +assign pc2 = chksum_buffer[23]; + +// main engine +reg [3:0] sync; +reg [7:0] lastbyte; +reg go_exec0, go_exec1, set_sync, err; +reg reg_tck, reg_tms, reg_tdi, reg_tdo, reg_tdo_en; +always @(negedge clk) begin + go_exec0 <= 0; + go_exec1 <= 0; + if (!ctl0) begin + lastbyte <= { fd7, fd6, fd5, fd4, fd3, fd2, fd1, fd0 }; + go_exec0 <= 1; + end + if (!ctl1) begin + lastbyte <= lastbyte >> 4; + go_exec0 <= 1; + end + if (!ctl2) begin + go_exec1 <= 1; + end + if (go_exec0) begin + reg_tdo_en <= 0; + if (set_sync) begin + sync <= lastbyte[3:0]; + set_sync <= 0; + end else + if (lastbyte[3:0] == 0) begin + /* NOP */ + end else + if (lastbyte[3:0] == 1) begin + /* Set sync signal in next insn */ + set_sync <= 1; + end else + if (lastbyte[3:1] == 1) begin + /* reserved */ + end else + if (lastbyte[3:2] == 1) begin + /* transaction with or without TDO check */ + reg_tck <= 0; + reg_tdo <= 'bx; + reg_tms <= lastbyte[1]; + reg_tdi <= lastbyte[0]; + end else + if (lastbyte[3] == 1) begin + /* transaction with TDO check */ + reg_tck <= 0; + reg_tdo <= lastbyte[2]; + reg_tms <= lastbyte[1]; + reg_tdi <= lastbyte[0]; + reg_tdo_en <= 1; + end + end + if (go_exec1) begin + reg_tck <= 1; + if (reg_tdo_en && tdo != reg_tdo) + err <= 1; + end + if (pd3) begin + /* RESET ERR */ + err <= 0; + end + if (pd4) begin + /* RESET SYNC */ + set_sync <= 0; + sync <= 0; + end +end +assign tck = reg_tck; +assign tms = reg_tms; +assign tdi = reg_tdi; +assign pc7 = sync[3]; +assign pc6 = sync[2]; +assign pc5 = sync[1]; +assign pc4 = sync[0]; +assign pc0 = err; + +endmodule + |