d0762e5439
The 200ns reset time specified in the datasheet are a minimum time; and the nanoseconds were being rounded to whole microseconds anyway. Also make it the same type as `config_delay_us` (`uint16_t`). Signed-off-by: Armin Brauns <armin.brauns@embedded-solutions.at>
100 lines
2.9 KiB
YAML
100 lines
2.9 KiB
YAML
# Copyright (c) 2022 Meta
|
|
# SPDX-License-Identifier: Apache-2.0
|
|
|
|
description: Lattice iCE40 FPGA
|
|
|
|
compatible: "lattice,ice40-fpga"
|
|
|
|
include: spi-device.yaml
|
|
|
|
properties:
|
|
load-mode:
|
|
type: int
|
|
required: true
|
|
description: |
|
|
Configure the method used to load the bitstream.
|
|
The bitstream may be loaded via 2 separate methods:
|
|
0 := load the FPGA via SPI transfer
|
|
1 := load the FPGA via bit-banged GPIO
|
|
Option 0 may be suitable for some high-end microcontrollers.
|
|
Option 1 is suitable for low-end microcontrollers. This option
|
|
requires clk-gpios, pico-gpios, gpios-set-reg, and gpios-clear-reg
|
|
to be defined.
|
|
Example usage:
|
|
load-mode = <0>;
|
|
cdone-gpios:
|
|
type: phandle-array
|
|
required: true
|
|
description: |
|
|
Configuration Done output from iCE40.
|
|
Example usage:
|
|
cdone-gpios = <&gpio0 0 0>;
|
|
creset-gpios:
|
|
type: phandle-array
|
|
required: true
|
|
description: |
|
|
Configuration Reset input on iCE40.
|
|
Example usage:
|
|
creset-gpios = <&gpio0 1 GPIO_PUSH_PULL);
|
|
clk-gpios:
|
|
type: phandle-array
|
|
description: |
|
|
SPI Clock GPIO input on iCE40.
|
|
Example usage:
|
|
clk-gpios = <&gpio0 5 GPIO_PUSH_PULL>;
|
|
pico-gpios:
|
|
type: phandle-array
|
|
description: |
|
|
Peripheral-In Controller-Out GPIO input on iCE40.
|
|
Example usage:
|
|
pico-gpios = <&gpio0 7 GPIO_PUSH_PULL>;
|
|
gpios-set-reg:
|
|
type: int
|
|
description: |
|
|
Register address for setting a GPIO.
|
|
Example usage:
|
|
gpios-set-reg = <0x60004008>;
|
|
gpios-clear-reg:
|
|
type: int
|
|
description: |
|
|
Register address for clearing a GPIO.
|
|
Example usage:
|
|
gpios-clear-reg = <0x6000400c>;
|
|
mhz-delay-count:
|
|
type: int
|
|
description: |
|
|
in order to create a 1 MHz square wave in the following
|
|
process.
|
|
while(true) {
|
|
*gpios_set_reg |= BIT(n);
|
|
for(int i = mhz_delay_count; i > 0; --i);
|
|
*gpios_clear_reg |= BIT(n);
|
|
for(int i = mhz_delay_count; i > 0; --i);
|
|
}
|
|
Example usage / default:
|
|
mhz-delay-count = <0>;
|
|
creset-delay-us:
|
|
type: int
|
|
description: |
|
|
Delay (in microseconds) between asserting CRESET_B and releasing CRESET_B.
|
|
Example usage / default:
|
|
creset-delay-us = <1>;
|
|
config-delay-us:
|
|
type: int
|
|
description: |
|
|
Delay (in microseconds) after releasing CRESET_B to clear internal configuration memory.
|
|
Example usage / default:
|
|
config-delay-us = <1200>;
|
|
leading-clocks:
|
|
type: int
|
|
description: |
|
|
Prior to sending the bitstream, issue this number of leading clocks with SPI_CS pulled high.
|
|
Example usage / default:
|
|
leading-clocks = <8>;
|
|
trailing-clocks:
|
|
type: int
|
|
description: |
|
|
After sending the bitstream, issue this number of trailing clocks with SPI_CS pulled high.
|
|
Example usage / default:
|
|
trailing-clocks = <49>;
|