2023-03-02 17:43:26 -05:00
|
|
|
SHELL := /bin/bash
|
|
|
|
|
|
|
|
PYTHON_FILES = \
|
|
|
|
usb_test.py \
|
|
|
|
icenvcm.py \
|
2023-03-02 17:52:52 -05:00
|
|
|
icebin2nvcm.py \
|
|
|
|
encode_usb_strings.py \
|
|
|
|
reset.py
|
2023-03-02 12:17:11 -05:00
|
|
|
|
2023-03-06 06:41:21 -05:00
|
|
|
# autopep8: Fixes simple format errors automatically
|
|
|
|
# mypy: static type hint analysis
|
|
|
|
# pylint: pep8 and static code analysis
|
2023-03-02 12:17:11 -05:00
|
|
|
lint:
|
2023-03-02 17:43:26 -05:00
|
|
|
autopep8 --in-place --max-line-length 70 --aggressive --aggressive ${PYTHON_FILES}
|
|
|
|
mypy --disallow-untyped-defs ${PYTHON_FILES}
|
2023-03-06 06:41:21 -05:00
|
|
|
pylint --generated-member=usb1.TRANSFER_COMPLETED,usb1.USBErrorInterrupted,usb1.USBErrorIO ${PYTHON_FILES}
|
2023-03-02 17:43:26 -05:00
|
|
|
|
|
|
|
# Check that the NVCM generator gives a correct output for a known binary
|
|
|
|
verify-nvcm:
|
|
|
|
./icebin2nvcm.py nvcm_test/application_fpga.bin verify.nvcm
|
|
|
|
cmp verify.nvcm nvcm_test/application_fpga.nvcm
|
|
|
|
|
|
|
|
verify:
|
|
|
|
time ./icenvcm.py --verify nvcm_test/application_fpga.bin
|
|
|
|
|
|
|
|
program:
|
2023-03-06 06:41:21 -05:00
|
|
|
./icenvcm.py -i
|
|
|
|
time ./icenvcm.py --my-design-is-good-enough --ignore-blank --write ../application_fpga/application_fpga.bin --verify nvcm_test/application_fpga.bin
|
|
|
|
./icenvcm.py -b
|