-
Notifications
You must be signed in to change notification settings - Fork 3
Home
- Youtube Videos
- Introduction
- FPGA IO Blocks
- Installation in Icestudio
- Using the collection
All the documentation is in English, except these videos which are in Spanish
Click on the images to see the videos in Youtube (TODO)
TODO
In this collection you will find blocks for working with the FPGA pins. Use it in your digital circuits for opensource FPGAs created with icestudio. The blocks in this collection depend on a particular FPGA family. Each FPGA has its own Input/Output block. If you use the wrong block (a block that is for other FPGA) you will get an error message
These are examples of some blocks of this collection:
Notice that these blocks have a different color than usual. This is for hightlighting the fact that they are special blocks that depends on the type of FPGA, and should always be connected to an FPGA pin
The FPGAs have some special blocks called PIOs (Programable Input/Outputs). These blocks are located near each of the FPGA pins and they are in charge of configuring each pin either as input or output. In addition, special features can be configured as well, like enabling the internal pull-ups
Each FPGA has its own specialized PIO blocks. Usually these blocks are placed and configured automatically by the Synthesis tool. But sometimes it is needed to place them manually and connect their ports to our circuit. That is the case when using bidirection pins
The iceIO collection contains the blocks for configuring the pins and using them, for the different FPGA families
Find information about collections and how to install them on this link: Installing the iceK collection in Icestudio. It was written for the iceK collection as an example. Use the repo of the icewires collection instead
- Download the ZIP file from the latest release
- ...or get the ZIP file with the latest changes from the main branch: iceIO-main.zip
There are two types of blocks: one for configuring the pins as input or output, and other for enabling the internal pull-ups. All these blocks should always be conected directly to an FPGA pin (if not, you will get an error message). Also, these blocks only can be used for an FPGA family. They are not valid for all the FPGAs
The InOut block is used for configuring the FPGA pin as input or output. It can be found in the InOut Menu and the FPGA family submenu (ex. InOut/ICE40/InOut)
This block has 4 ports:
- pin: It should be conected directly to an FPGA pin. If it is connected to something different than a pin an error message is displayed
- oe: Output enable. This port is used for configuring the pin as input or output: 0: The pin is configured as input 1: The pin is configured as output
- din: Input data. When the pin is configured as input, the data comming from the outside can be read from this port
- dout: Output data. When the pin is configured as output, the bits written in this port are sent outside the FPGA
There is another block, InOut-right, that is exactly the same but the pin port is located on the right instead that on the left
Every FPGA family has its own InOut blocks. They all look the same (the same 4 ports)
This example is available on the File/Examples/01-Input-Config/Alhmabra-II/01-button-LED menu. It is an example of the manually configuration of a pin as input, for the Alhambra-II ICE40 FPGA board
The SW1 button is displayed on the LED0
This is just an example on how to configure manually the pin as input using the InOut block. Usually this is done automatically by the Synthesizer
As the InOut blocks are foundamental, they all are implemented in Verilog
SB_IO #(
.PIN_TYPE(6'b1010_01),
.PULLUP(1'b0)
) triState (
.PACKAGE_PIN(pin),
.OUTPUT_ENABLE(oe),
.D_OUT_0(dout),
.D_IN_0(din)
);
You can double click on the block for displaying its implementation:
This example is available on the File/Examples/02-Output-Config/Alhmabra-II/01-blinking-LED menu. It is an example of the manually configuration of a pin as output, for the Alhambra-II ICE40 FPGA board
The LED0 is blinking at the rate of 0.5Hz
This is just an example on how to configure manually the pin as output using the InOut-right block. Usually this is done automatically by the Synthesizer
This example is available on the File/Examples/03-InOut-test/Alhmabra-II/01-Inout-button-LED menu. It is an example of the manually configuration of a pin as input/output, for the Alhambra-II ICE40 FPGA board
The button SW2 is used for seting the configuration of the pin:
- 0: Button not pressed. Input pin
- 1: Button pressed. Output pin
An external wire should be used to connect the DO pin to the D1 or D2 pins. The former is for reading a button (input) and the later for writing on a LED (output)
The InOut block for the ECP5 FPGA Family is used in a similar way than for the ICE40 family
This example is available on the File/Examples/01-Input-Config/ULX3S-12F/01-button-LED menu. It is an example of the manually configuration of a pin as input, for the Radiona ULX3S-12F ECP5 FPGA board
The B1 button is displayed on the D1 LED
This is the implementation of the InOut block for the ECP5 FPGA Family, in Verilog
TRELLIS_IO #(
.DIR("BIDIR")
) siod_out_bidir (
.B(pin),
.T(~oe),
.I(dout),
.O(din)
);
You can double click on the block for displaying its implementation:
This example is available on the File/Examples/02-Output-Config/ULX3S-12F/01-blinking-LED menu. It is an example of the manually configuration of a pin as output, for the Radiona ULX3S ECP5 FPGA board
The LED 0 is blinking
This is just an example on how to configure manually the pin as output using the InOut-right block. Usually this is done automatically by the Synthesizer
This example is available on the File/Examples/03-InOut-test/ULX3S-12F/01-Inout-button-LED menu. It is an example of the manually configuration of a pin as input/output, for the Radiona ULX3S ECP5 FPGA board
The button B2 is used for seting the configuration of the pin:
- 0: Button not pressed. Input pin
- 1: Button pressed. Output pin
An external wire should be used to connect the GN0 pin to the GN1 or GN2 pins. The former is for reading a button (input) and the later for writing on a LED (output)
For working with multiple pins we use the InOut-xN and ****InOut-right-xN blocks, where N is the number of bits. They contanin N InOut blocks in paralell
They look similar to the 1-bit version, except for the width of the Pin, din and dout ports In this picture you can see the 2-bits InOut blocks:
In this example, two input pins are configured manually as inputs. The state of the two buttons, SW1 and SW2 is shown on LEDs 0 and 1
The Implementation of the InOut blocks for N bits is the same for all the FPGA families. In this picture the implementation of the 2-bits InOut blocks is shown
It consist of two InOut blocks placed in paralell
In some FPGAs the PIO blocks can also be used for enabling the internal pull-ups when configured as inputs. In that cases we use the Pull-up blocks
In this picture the pull-up and Pull-up-x2 blocks are shown
The top parameter is used for configuring the pull-up. If it is set to 0, the pull-up is not active. If it is 1, the internal pull-up is enabled
The pin ports should always be connected directly to FPGA pins. If not, an error message will be displayed
The PIO blocks of the ICE40 FPGA family have internal pull-ups that can be configured
In this example the internal pull-up is actived. The state of the D0 input pin is shown on LED0
The two internal pull-ups of the D0 and D1 pines are enabled. The state of these pins are shown on the LEDs 0 and 1
The pull-up for the ICE40 FPGA family is implemented in Verilog:
// 1-Pull up
//-- Place the IO block, configured as
//-- input with pull-up
SB_IO
#(
.PIN_TYPE(6'b 1010_01),
//-- The pull-up is activated or not
//-- depeding on the ON parameter
.PULLUP(ON)
) input_pin (
//--- Input pin
.PACKAGE_PIN(i),
//-- Block output
.D_IN_0(o),
//-- Configured as input
.OUTPUT_ENABLE(1'b0),
//-- Not used
.D_OUT_0(1'b0)
);
You can double click on the block for displaying its implementation:
The arrays of N pull-ups are implemented placing N of this modules in paralell. In this figure it is shown the implementation of the pull-up-x02 block
Work in progress
- Message errors:
- Conect something different than a pin
- Using the block with the wrong FPGA