forked from cores/microwatt
flash-arty: Add support for specifying the file type
By default openocd tries to "guess" the file type and interpret it accordingly. For example it will detect an ELF file based on the presence of an ELF header and will try to load the relevant segments into the flash. This may not be what we want. For example, I want to load the raw ELF file into the flash. Additionally the ELF parser in most distro's OpenOCD version only supports ELF32 and will error out. This adds a "-t" argument to flash-arty to allow us to specify the file format. For example "-t bin" will treat the file as raw binary. Unfortunately I had to copy and modify jtagspi.cfg from OpenOCD to achieve this. Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>jtag-port
parent
3592be733e
commit
d3c274d01e
@ -0,0 +1,48 @@
|
|||||||
|
set _USER1 0x02
|
||||||
|
|
||||||
|
if { [info exists JTAGSPI_IR] } {
|
||||||
|
set _JTAGSPI_IR $JTAGSPI_IR
|
||||||
|
} else {
|
||||||
|
set _JTAGSPI_IR $_USER1
|
||||||
|
}
|
||||||
|
|
||||||
|
if { [info exists DR_LENGTH] } {
|
||||||
|
set _DR_LENGTH $DR_LENGTH
|
||||||
|
} else {
|
||||||
|
set _DR_LENGTH 1
|
||||||
|
}
|
||||||
|
|
||||||
|
if { [info exists TARGETNAME] } {
|
||||||
|
set _TARGETNAME $TARGETNAME
|
||||||
|
} else {
|
||||||
|
set _TARGETNAME $_CHIPNAME.proxy
|
||||||
|
}
|
||||||
|
|
||||||
|
if { [info exists FLASHNAME] } {
|
||||||
|
set _FLASHNAME $FLASHNAME
|
||||||
|
} else {
|
||||||
|
set _FLASHNAME $_CHIPNAME.spi
|
||||||
|
}
|
||||||
|
|
||||||
|
target create $_TARGETNAME testee -chain-position $_CHIPNAME.tap
|
||||||
|
flash bank $_FLASHNAME jtagspi 0 0 0 0 $_TARGETNAME $_JTAGSPI_IR $_DR_LENGTH
|
||||||
|
|
||||||
|
proc jtagspi_init {chain_id proxy_bit} {
|
||||||
|
# load proxy bitstream $proxy_bit and probe spi flash
|
||||||
|
global _FLASHNAME
|
||||||
|
pld load $chain_id $proxy_bit
|
||||||
|
reset halt
|
||||||
|
flash probe $_FLASHNAME
|
||||||
|
}
|
||||||
|
|
||||||
|
proc jtagspi_program {bin addr {type ""} } {
|
||||||
|
# write and verify binary file $bin at offset $addr
|
||||||
|
global _FLASHNAME
|
||||||
|
if { $type eq "" } {
|
||||||
|
flash write_image erase $bin $addr
|
||||||
|
flash verify_bank $_FLASHNAME $bin $addr
|
||||||
|
} else {
|
||||||
|
flash write_image erase $bin $addr $type
|
||||||
|
flash verify_bank $_FLASHNAME $bin $addr $type
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue