Now it is time to add a GPIO driver to our system and attach it to the led
component instance. We'll also connect the led
component instance to a 1 Hz rate group. Finally, we'll configure the driver to manage the GPIO 13 pin on our hardware. Once this section is finished, the system is ready for running on hardware.
F´ provides a GPIO driver for Linux systems called Drv.LinuxGpioDriver
. This should be added to both the instance definition list and the topology instance list just like we did for the led
component. Since the GPIO driver is a passive component, its definition is a bit more simple.
Add to "Passive Component" section of led-blinker/LedBLinker/Top/instance.fpp
:
instance gpioDriver: Drv.LinuxGpioDriver base id 0x4C00
Add to the instance list of led-blinker/LedBLinker/Top/topology.fpp
:
instance gpioDriver
In
led-blinker/LedBLinker
build the deployment and resolve any errors before continuing.
The Led
component defines the gpioSet
output port and the LinuxGpioDriver
defines the gpioWrite
input port. These two ports need to be connected from output to input. The ActiveRateGroup
component defines an array of ports called RateGroupMemberOut
and one of these needs to be connected to run
port defined on the Led
component.
We can create a named connections block in the topology and connect the two port pairs. Remember to use the component instances and not the component definitions for each connection.
To do this, add the following lines to led-blinker/LedBLinker/Top/topology.fpp
:
# Named connection group
connections LedConnections {
# Rate Group 1 (1Hz cycle) ouput is connected to led's run input
rateGroup1.RateGroupMemberOut[3] -> led.run
# led's gpioSet output is connected to gpioDriver's gpioWrite input
led.gpioSet -> gpioDriver.gpioWrite
}
rateGroup1
is preconfigured to call allRateGroupMemberOut
at a rate of 1 Hz. We use indexRateGroupMemberOut[3]
becauseRateGroupMemberOut[0]
throughRateGroupMemberOut[2]
were used previously in theRateGroups
connection block.
So far the GPIO driver has been instantiated and wired, but has not been told what GPIO pin to control. For this tutorial, GPIO pin 13 will be used. To configure this, the open
function needs to be called in the topology's C++ implementation and passed the pin's number and direction.
This is done by adding the following line to the configureTopology
function defined in led-blinker/LedBLinker/Top/LedBLinkerTopology.cpp
.
void configureTopology() {
...
bool gpio_success = gpioDriver.open(13, Drv::LinuxGpioDriver::GpioDirection::GPIO_OUT);
if (!gpio_success) {
Fw::Logger::logMsg("[ERROR] Failed to open GPIO pin\n");
}
}
This code tells the GPIO driver to open pin 13 as an output pin. If this fails, an error is printed to the console, but the system continues to start.
In
led-blinker/LedBLinker
build the deployment and resolve any errors before continuing.
Congratulations! You've wired your component to the rate group driver and GPIO driver components. It is time to try it on hardware.