GUF-Yocto-34.0-r5756-0
VINCELL
User Manual
6
Accessing the hardware
This chapter gives a short overview of how to access the different hardware parts and interfaces from within the
Linux operating system. It is written universally in order to fit all Garz & Fricke platforms in general.
6.1
Digital I/O
The digital I/O pins for a platform are controlled by the kernel’s
GPIO Library
interface driver. This driver exports
a sysfs interface to the user space. For each pin, there is a virtual folder in the file system under
/sys/class/gpio/
with the same name as in the hardware manual.
Each folder contains the following virtual files that can be accessed like normal files. In the command shell, there
are the standard Linux commands
cat
for read access and
echo
for write access. To acces those virtual files
from C/C++ code, the standard POSIX operations open(), read(), write() and close() can be used.
sysfs file
Valid values
Meaning
value
0, 1
The current level of the GPIO pin. The
acive_low
flag (see
below) has to be taken into account for interpretation.
direction
in, out
The direction of the GPIO pin.
active_low
0, 1
Indicates if the pin is interpreted active low.
Most of the Garz & Fricke hardware platforms include a dedicated connector with isolated digital I/O pins. On
these pins, the direction cannot be changed, since it is determined by the wiring. Thus, the direction file is missing
here. Some platforms also have a keypad connector, which can be used as a bi-directional GPIO port.
The following examples show how to use the virtual files in order to control the GPIO pins.
Example 1:
Verify that the GPIO pin
keypad_pin7
, which is pin 7 on the keypad connector, is interpreted as
active high
, configure the pin as an output and set it to high level in the Linux shell:
root@vincell:~# cat /sys/class/gpio/keypad_pin7/active_low
0
root@vincell:~# echo out > /sys/class/gpio/keypad_pin7/direction
root@vincell:~# echo 1 > /sys/class/gpio/keypad_pin7/value
Example 2:
Verify that
keypad_pin12
is an input pin and interpreted as
active low
and verify that the level
LOW
is recognized by this pin in the Linux shell:
root@vincell:~# cat /sys/class/gpio/keypad_pin12/direction
in
root@vincell:~# cat /sys/class/gpio/keypad_pin12/active_low
1
root@vincell:~# cat /sys/class/gpio/keypad_pin12/value
1
Example 3:
C function to set / clear the
dig_out1
output pin:
void set_gpio(unsigned int state)
{
int fd = -1; // GPIO file handle
char gpio[4];
fd = open("/sys/class/gpio/dig_out1/value", O_RDWR);
if (fd == -1)
{
printf("GPIO-ERR\n");
return;
}
sprintf(gpio, "%d", state);
write(fd, gpio, strlen(gpio));
close(fd);
}
26