GPIO
General-Purpose Input/Output (GPIO) pins can be configured as either inputs or outputs. Many signals on the phyCORE-Connector can be used as GPIOs through multiplexing. The AM67x processor features five independent GPIO modules. For detailed information about the phyCORE-AM67x GPIO interface, please refer to the GPIO section in the Hardware Manual
GPIO Signal Names and Chip Mapping
GPIOn_x is generic name used to describe a GPIO signal, where n represents the specific GPIO module and x represents one of the input/output signals associated with the module. Usually you find this names in the schematics and in comments in our device trees in the muxing section.
The AM67x provides three GPIO modules:
GPIO0
GPIO1
MCU_GPIO0
Linux represents these modules as gpiochips. You can list them using the gpiodetect command:
sh-phyboard-rigel-am67xx-1:~# gpiodetect
gpiochip0 [4201000.gpio] (24 lines)
gpiochip1 [600000.gpio] (87 lines)
gpiochip2 [601000.gpio] (73 lines)
gpiochip3 [tps65219-gpio.2.auto] (3 lines)
gpiochip4 [pcf8574] (8 lines)
gpiochip5 [pcf8574] (8 lines)
gpiochip6 [pcf8574] (8 lines)
The second column shows the hardware address of each GPIO module. In the device tree, these GPIOs are accessed using node labels:
main_gpio0 (gpio@600000)
main_gpio1 (gpio@601000)
mcu_gpio0 (gpio@4201000)
gpio_exp
Note
GPIO chip numbers may change between system boots. For consistent numbering, configure udev rules.
Active GPIO Signals
The following command shows GPIO signals that are currently allocated by kernel drivers. These GPIOs are already in use and attempting to access them with gpioget or gpioset will result in a “Device or resource busy” error.
See the allocated GPIO signals by running:
sh-phyboard-rigel-am67xx-1:~# cat /sys/kernel/debug/gpio
gpiochip0: GPIOs 512-535, parent: platform/4201000.gpio, 4201000.gpio:
gpiochip1: GPIOs 536-622, parent: platform/600000.gpio, 600000.gpio:
 gpio-549 (                    |green:heartbeat     ) out lo
 gpio-558 (                    |enable              ) out hi ACTIVE LOW
 gpio-567 (                    |reset               ) out hi
gpiochip2: GPIOs 623-695, parent: platform/601000.gpio, 601000.gpio:
 gpio-646 (                    |home                ) in  lo
 gpio-673 (                    |p50-hog             ) out hi
gpiochip3: GPIOs 696-698, parent: i2c/0-0030, tps65219-gpio.2.auto, can sleep:
gpiochip4: GPIOs 699-706, parent: i2c/2-0020, pcf8574, can sleep:
 gpio-699 (CSI3_STROBE         )
 gpio-700 (CSI3_TRIGGER        )
 gpio-701 (CSI3_SHUTTER        )
 gpio-702 (CSI3_OE             )
 gpio-703 (CSI2_STROBE         )
 gpio-704 (CSI2_TRIGGER        )
 gpio-705 (CSI2_SHUTTER        )
 gpio-706 (CSI2_OE             )
gpiochip5: GPIOs 707-714, parent: i2c/2-0021, pcf8574, can sleep:
 gpio-707 (GPIO0_HDMI_RST      )
 gpio-708 (GPIO1_CAN_nEN       |standby             ) out lo
 gpio-709 (GPIO2_LED           )
 gpio-710 (GPIO3_MCU_CAN0_nEN  )
 gpio-711 (GPIO4_BUT2          |menu                ) in  lo IRQ
 gpio-712 (GPIO5_MCU_CAN1_nEN  )
 gpio-713 (GPIO6_AUDIO_GPIO    )
 gpio-714 (GPIO7_AUDIO_USER_RES|reset               ) out hi ACTIVE LOW
gpiochip6: GPIOs 715-722, parent: i2c/2-0023, pcf8574, can sleep:
 gpio-715 (CSI1_STROBE         )
 gpio-716 (CSI1_TRIGGER        )
 gpio-717 (CSI1_SHUTTER        )
 gpio-718 (CSI1_OE             )
 gpio-719 (CSI0_STROBE         )
 gpio-720 (CSI0_TRIGGER        )
 gpio-721 (CSI0_SHUTTER        )
 gpio-722 (CSI0_OE             )
Using GPIOs
To access GPIOs from userspace applications, use the libgpiod library. This library provides tools for interacting with Linux GPIO devices. Here are some common usage examples:
- List all available GPIO chips: 
sh-phyboard-rigel-am67xx-1:~# gpiodetect
gpiochip0 [4201000.gpio] (24 lines)
gpiochip1 [600000.gpio] (87 lines)
gpiochip2 [601000.gpio] (73 lines)
gpiochip3 [tps65219-gpio.2.auto] (3 lines)
gpiochip4 [pcf8574] (8 lines)
gpiochip5 [pcf8574] (8 lines)
gpiochip6 [pcf8574] (8 lines)
- Display detailed GPIO chip information (names, consumers, direction, active state, and flags): 
sh-phyboard-rigel-am67xx-1:~# gpioinfo -c gpiochip2
- Read the value of a GPIO (e.g GPIO 36 from chip2): 
sh-phyboard-rigel-am67xx-1:~# gpioget -c gpiochip2 36
- Set the value of GPIO 36 on chip2 to 0 and exit tool: 
sh-phyboard-rigel-am67xx-1:~# gpioset -z -c gpiochip2 36=0
Note
Interacting with a Signal as GPIO requires a proper muxing. The signal needs to be muxed in mux mode 7 (GPIO).
GPIOs via sysfs
Warning
Accessing GPIOs via sysfs is deprecated. We strongly encourage using libgpiod instead.
Sysfs GPIO access is no longer enabled by default. To enable it, enable CONFIG_EXPERT & CONFIG_GPIO_SYSFS in the kernel configuration.
Using LEDs
The phyBOARD-Rigel AM67x features several user-controllable LEDs that are connected to GPIO pins. While these LEDs can be controlled through the standard GPIO interface, Linux provides a dedicated LED subsystem that offers a more convenient way to manage them.
 
LED Control Interface
The LED subsystem is accessible through the sysfs interface at /sys/class/leds/. Each LED has its own directory containing control files:
- brightness: Write values to control the LED state
- 0turns the LED off
- Any non-zero value turns the LED on 
 
 
- max_brightness: Read-only file showing the maximum brightness value
- trigger: Allows setting automatic triggers (e.g., heartbeat, disk activity)
Note
While the interface supports brightness levels, most onboard LEDs are simple on/off LEDs without hardware brightness control. Any non-zero brightness value will simply turn them on.
Available LEDs
To list all available LEDs on your system:
sh-phyboard-rigel-am67xx-1:~# ls /sys/class/leds/
green:heartbeat@  mmc0::@  mmc1::@
Controlling LEDs
You can control LEDs using simple shell commands:
- To toggle the LEDs ON: - sh-phyboard-rigel-am67xx-1:~# echo 255 > /sys/class/leds/led-1/brightness - To toggle the LEDs OFF: 
 - sh-phyboard-rigel-am67xx-1:~# echo 0 > /sys/class/leds/led-1/brightness 
Advanced Usage
For more details about LED configuration, refer to the Linux kernel documentation at https://www.kernel.org/doc/Documentation/leds/leds-class.txt
- Set LED triggers (e.g., for heartbeat effect): - sh-phyboard-rigel-am67xx-1:~# echo heartbeat > /sys/class/leds/green\:heartbeat/trigger 
- Disable LED trigger: - sh-phyboard-rigel-am67xx-1:~# echo none > /sys/class/leds/green\:heartbeat/trigger