1
0
mirror of git://projects.qi-hardware.com/wernermisc.git synced 2025-01-26 02:21:05 +02:00
Werner Almesberger 037be5062e m1nor: accept multiple file arguments; clarified diagnostics
One can now pass all files to flash in the same invocation. m1nor
does a first pass to verify the argument, a second pass to do the
flashing, and a third pass to report that it has done.

Diagnostics now begin with the file name followed by a description
of the problem encountered.
2011-11-30 20:05:09 -03:00
..

m1nor - Flash a file to M1 NOR partition selected by the file name
==================================================================

During software development, one often need to update only the
content of a single partition. reflash_m1.sh is a bit unwieldy
for this kind of task.

I've written a small script called m1nor that selects the target 
partition based on the file name. E.g., m1nor flickernoise.fbi
would update the regular Flickernoise partition.

The matching algorithm checks the beginning of the file name,
so names like flickernoise-test.fbi would also work. Furthermore,
it checks the file extension, so if you try to flash flickernoise
(ELF, for debugging) or flickernoise.bin (an intermediate form
unsuitable for booting from NOR), it will politely refuse to do
so.

You need to have fjmem.bit somwehere. It searches for it under
$HOME/.qi/milkymist/, where reflash_m1.sh caches it. You can also
specify the location directly by setting the environment variable
FJMEM_BIT.


xdltap - Route nets from inside the FPGA to I/O pads
====================================================

xdltap adds routes from signals inside the FPGA to I/O pads. It
does this by converting the .ncd file generated by synthesis 

xdltap signal=output ... [xdl-file]

The path to the signal to be tapped has to be fully qualified.
Note that not all signals are listed in the .pcf file. Some may
only show up in .xdl

The output is the name of a global net that has to be connected
to an input (!) pad.

Signal names containing < and > can be written with { and }, to
avoid extra escaping for the shell.

Since xdl chokes on its own .xdl files, xdlfixes applies a number
of ugly hacks to either avoid errors or to propagate them to a
later stage, where they can be ignored.

Example:

map ... foo.ngd			# generates foo.ncd
xdl -ncd2xdl foo.ncd		# generates foo.xdl
xdltap usb/sie/rx_pending=exp{8} foo.xdl | xdlfixes >foo-dbg.xdl
xdl -xdl2ncd foo-dbg.xdl	# generates foo-dbg.ncd
par ... foo-dbg.ncd ...