-m util.fusecli

Examine and modify fuses using symbolic names and values.

The set of fuses to operate on is specified using a set of hierarchical selectors. Each level of the selector can match either a single numbered entity (e.g. MC3, PT1), or all numbered entities on the same level (e.g. PT, GOE).

If the requested operation is to examine fuses, the names and values of all selected fuses are printed to standard output. If no selector is specified, all fuses are selected.

If the requested operation is to modify fuses, the values of all selected fuses are changed to the value specified on the command line.

When modifying product term fuses, multiple choices can be specified as a single comma-separated value. It is possible to modify (rather than replace) product term fuses by prefixing all choices with + or -. The special value VCC sets all fuses to 1, and the special value GND sets all fuses to 0.

usage: python3 -m util.fusecli [-h] [-v] [-d DEVICE] MANGLE COMMAND ...

Positional Arguments

MANGLE

Manipulate fuses in JED file MANGLE.

COMMAND

Possible choices: get, set

Operation to perform.

Named Arguments

-v, --verbose

Show fuse indexes and states next to the symbolic value.

Default: False

-d, --device

Possible choices: ATF1502AS, ATF1502BE, ATF1504AS, ATF1504BE

Select the device to use.

Default: 'ATF1502AS'

Sub-commands

get

Examine fuse states.

python3 -m util.fusecli get [-h] [SELECTOR ...]

Positional Arguments

SELECTOR

Print values of fuses that match SELECTOR.

set

Modify fuse states.

python3 -m util.fusecli set [-h] ...

Positional Arguments

SELECTOR VALUE

Change values of fuses that match SELECTOR to be VALUE.

Examples

Examining fuses

To print all known fuses:

$ python3 -m util.fusecli design.jed get
MC1:
  PT1: GND
  PT2: GND
[output trimmed]

To print macrocell MC1 product term PT1:

$ python3 -m util.fusecli design.jed get MC1.PT1
MC1:
  PT1: GND

To print all product terms of macrocell MC1:

$ python3 -m util.fusecli design.jed get MC1.PT
MC1:
  PT1: GND
  PT2: GND
  PT3: GND
  PT4: GND
  PT5: GND

To print option gclk_mux of every macrocell:

$ python3 -m util.fusecli design.jed get MC.gclk_mux
MC1:
  CFG:
    gclk_mux       = GCLK2
MC2:
  CFG:
    gclk_mux       = GCLK2
MC3:
[output trimmed]

To print options pt1_mux and pt2_mux of every macrocell:

$ python3 -m util.fusecli design.jed get MC.pt1_mux MC.pt2_mux
MC1:
  CFG:
    pt1_mux        = sum
    pt2_mux        = sum
MC2:
[output trimmed]

Modifying fuses

To change option gclk_mux of macrocell MC8 to be GCLK2:

$ python3 -m util.fusecli design.jed set MC8.gclk_mux GCLK2
MC8:
  CFG:
    gclk_mux       = GCLK2
Changed 1 fields, 2 fuses.

To change option low_power of every macrocell to be on:

$ python3 -m util.fusecli design.jed set MC.low_power on
MC1:
  CFG:
    low_power      = on
[output trimmed]
MC32:
  CFG:
    low_power      = on
Changed 32 fields, 32 fuses.

To change options pt1_mux and pt2_mux of every macrocell to be sum:

$ python3 -m util.fusecli design.jed set MC.pt1_mux sum MC.pt2_mux sum
MC1:
  CFG:
    pt1_mux        = sum
[output trimmed]
MC32:
  CFG:
    pt2_mux        = sum
Changed 64 fields, 0 fuses.

To set product term PT1 of macrocell MC1 to UIM2_P & UIM4_N:

$ python3 -m util.fusecli design.jed set MC1.PT1 UIM2_P,UIM4_N
MC1:
  PT1: UIM2_P,UIM4_N
Changed 1 fields, 94 fuses.
$ python3 -m util.fusecli design.jed get MC1.PT1
MC1:
  PT1: UIM2_P & UIM4_N

To remove UIM4_N from product term PT1 of macrocell MC1 and add UIM8_P instead:

$ python3 -m util.fusecli design.jed set MC1.PT1 -UIM4_N,+UIM8_P
MC1:
  PT1: -UIM4_N,+UIM8_P
Changed 1 fields, 2 fuses.
$ python3 -m util.fusecli design.jed get MC1.PT1
MC1:
  PT1: UIM2_P & UIM8_P

To clear product term PT1 of every macrocell:

$ python3 -m util.fusecli design.jed set MC.PT1 GND
MC1:
  PT1: GND
[output trimmed]
MC32:
  PT1: GND
Changed 32 fields, 94 fuses.