| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495 |
- # SPDX-License-Identifier: GPL-2.0-or-later
- # xilinx spartan6
- # http://www.xilinx.com/support/documentation/user_guides/ug380.pdf
- if { [info exists CHIPNAME] } {
- set _CHIPNAME $CHIPNAME
- } else {
- set _CHIPNAME xc6s
- }
- # the 4 top bits (28:31) are the die stepping. ignore it.
- jtag newtap $_CHIPNAME tap -irlen 6 -ignore-version \
- -expected-id 0x04000093 \
- -expected-id 0x04001093 \
- -expected-id 0x04002093 \
- -expected-id 0x04004093 \
- -expected-id 0x04024093 \
- -expected-id 0x04008093 \
- -expected-id 0x04028093 \
- -expected-id 0x0400E093 \
- -expected-id 0x0402E093 \
- -expected-id 0x04011093 \
- -expected-id 0x04031093 \
- -expected-id 0x0401D093 \
- -expected-id 0x0403D093
- pld create $_CHIPNAME.pld virtex2 -chain-position $_CHIPNAME.tap
- virtex2 set_user_codes $_CHIPNAME.pld 0x02 0x03 0x1A 0x1B
- set XC6S_CFG_IN 0x05
- set XC6S_JSHUTDOWN 0x0d
- set XC6S_JPROGRAM 0x0b
- set XC6S_JSTART 0x0c
- set XC6S_BYPASS 0x3f
- proc xc6s_program {tap} {
- echo "DEPRECATED! use 'virtex2 program ...' not 'xc6s_program'"
- global XC6S_JSHUTDOWN XC6S_JPROGRAM XC6S_JSTART XC6S_BYPASS
- irscan $tap $XC6S_JSHUTDOWN
- irscan $tap $XC6S_JPROGRAM
- irscan $tap $XC6S_JSTART
- irscan $tap $XC6S_BYPASS
- }
- #xtp038 and xc3sprog approach
- proc xc6s_program_iprog {tap} {
- echo "DEPRECATED! use 'virtex2 program ...' not 'xc6s_program_iprog'"
- global XC6S_JSHUTDOWN XC6S_JSTART XC6S_BYPASS XC6S_CFG_IN
- irscan $tap $XC6S_JSHUTDOWN
- runtest 16
- irscan $tap $XC6S_CFG_IN
- # xtp038 IPROG 16bit flipped
- drscan $tap 16 0xffff 16 0x9955 16 0x66aa 16 0x850c 16 0x7000 16 0x0004
- irscan $tap $XC6S_JSTART
- runtest 32
- irscan $tap $XC6S_BYPASS
- runtest 1
- }
- set XC6S_ISC_ENABLE 0x10
- set XC6S_ISC_DISABLE 0x16
- set XC6S_ISC_DNA 0x30
- # Get the "Device DNA" from the Spartan 6.
- # Most Xilinx FPGA devices contain an embedded, unique device identifier called
- # the "Device DNA". The identifier is nonvolatile, permanently programmed into
- # the FPGA, and is unchangeable providing a great serial / tracking number.
- proc xc6s_get_dna {tap} {
- global XC6S_ISC_ENABLE XC6S_ISC_DISABLE XC6S_ISC_DNA
- irscan $tap $XC6S_ISC_ENABLE
- runtest 64
- irscan $tap $XC6S_ISC_DNA
- # Device DNA is 57 bits long, but we can only read 32bits at a time
- # with OpenOCD.
- set dna [drscan $tap 16 0 16 0 16 0 9 0]
- runtest 64
- irscan $tap $XC6S_ISC_DISABLE
- runtest 64
- # Convert the binary data into the order impact uses
- scan $dna "%x %x %x %x" v1 v2 v3 v4
- set bin_dna [string reverse [concat [format "%09b" $v4][format "%016b" $v3][format "%016b" $v2][format "%016b" $v1]]]
- # Return a hex version of binary
- scan [format "0b%s" $bin_dna] "%i" hex_dna
- return $hex_dna
- }
- # Print out the "Device DNA" in the same format that impact uses.
- proc xc6s_print_dna {tap} {
- set hex_dna [xc6s_get_dna $tap]
- puts [format "DNA = %57b (0x%x)\n" $hex_dna $hex_dna]
- }
|