meta-fii: meta-kudo: Use GPIO line names instead of number
Replaces hard-coded GPIO throughout the Kudo layer with a reference
to its line name from DTS.
The process to dynamically obtain the GPIO number for Get is added
to kudo-lib.sh,
1. Use `gpiofind <Line Name>` to obtain gpiochip# and pin#
2. If the gpiochip# exceeds the number of GPIO banks of Nuvoton,
then it is an I/O Expander.
a. Use `gpiodetect` and extract the I2C bus-addr
b. Obtain GPIO base value from sysfs using bus-addr
c. The GPIO number is then the (base + pin#)
3. If the gpiochip# is within Nuvoton GPIO banks, then calculate
the GPIO number as ((gpiochip#)*32 + pin#)
Then the GPIO number can be used in the export to obtain the value.
Tested with Nuvoton:
- Can read/set Nuvoton GPIO with defined line names
- Can read/set GPIO from I/O Expanders with defined line names
Signed-off-by: Charles Boyer <Charles.Boyer@fii-usa.com>
Change-Id: I651c0707a8bbc170d3c5a5fc261e5f9c62453e9f
diff --git a/meta-fii/meta-kudo/recipes-kudo/kudo-sys-utility/kudo-boot/init_once.sh b/meta-fii/meta-kudo/recipes-kudo/kudo-sys-utility/kudo-boot/init_once.sh
index cd80674..fa5395d 100644
--- a/meta-fii/meta-kudo/recipes-kudo/kudo-sys-utility/kudo-boot/init_once.sh
+++ b/meta-fii/meta-kudo/recipes-kudo/kudo-sys-utility/kudo-boot/init_once.sh
@@ -6,17 +6,17 @@
function set_mux_default(){
# set all mux route to CPU before power on host
- # BMC_CPU_RTC_I2C_SEL #120
- set_gpio_ctrl 120 out 1
- # BMC_CPU_DDR_I2C_SEL #84
- set_gpio_ctrl 84 out 1
- # BMC_CPU_EEPROM_I2C_SEL #85
- set_gpio_ctrl 85 out 1
- # BMC_CPU_PMBUS_SEL #86
- set_gpio_ctrl 86 out 1
+ # BMC_CPU_RTC_I2C_SEL
+ set_gpio_ctrl CPU_RTC_SEL 1
+ # BMC_CPU_DDR_I2C_SEL
+ set_gpio_ctrl CPU_DDR_SEL 1
+ # BMC_CPU_EEPROM_I2C_SEL
+ set_gpio_ctrl CPU_EEPROM_SEL 1
+ # BMC_CPU_PMBUS_SEL
+ set_gpio_ctrl CPU_VRD_SEL 1
# LED control
- # LED_BMC_LIVE #7
- set_gpio_ctrl 7 out 1
+ # LED_BMC_LIVE
+ set_gpio_ctrl LED_BMC_ALIVE 1
# SPI control
# Send command to CPLD to switch the bios spi interface to host
@@ -32,27 +32,27 @@
# Set BMC_I2C_BACKUP_SEL to secondary.
if [[ $boardver -lt 64 ]]; then
echo "EVT system. Choosing secondary SCP EEPROM."
- set_gpio_ctrl 168 out 0
+ set_gpio_ctrl BACKUP_SCP_SEL 0
set_mux_default
# Power control
- # S0_BMC_OK, GPIO 69
- set_gpio_ctrl 69 out 1
+ # S0_BMC_OK
+ set_gpio_ctrl S0_BMC_OK 1
else
echo "DVT or PVT system"
# sleep so that FRU and all ipmitool Devices are ready before HOST OS
- # gpio 143 for HPM_STBY_RST_N do to DC-SCM spec
- set_gpio_ctrl 143 out 1 # on DVT this became HPM_STBY_RST_N (EVT1 came from CPLD)
+ # HPM_STBY_RST_N to DC-SCM spec
+ set_gpio_ctrl HPM_STBY_RST_N 1 # on DVT this became HPM_STBY_RST_N (EVT1 came from CPLD)
sleep 5 # for the MUX to get ready
set_mux_default
# Power control
- # S0_BMC_OK, GPIO 69
- set_gpio_ctrl 69 out 1
+ # S0_BMC_OK
+ set_gpio_ctrl S0_BMC_OK 1
fi
# Disable CPU 1 CLK when cpu not detected
# echo init_once cpu $CPU1_STATUS > /dev/ttyS0
# echo init_once board $boardver > /dev/ttyS0
-CPU1_STATUS_N=$(get_gpio_ctrl 136)
+CPU1_STATUS_N=$(get_gpio_ctrl S1_STATUS_N)
if [[ $CPU1_STATUS_N == 1 ]]; then
#Execute this only on DVT systems
if [[ $boardver -lt 64 ]]; then
diff --git a/meta-fii/meta-kudo/recipes-kudo/kudo-sys-utility/kudo-cmd/kudo.sh b/meta-fii/meta-kudo/recipes-kudo/kudo-sys-utility/kudo-cmd/kudo.sh
index 694c23c..58d0d0e 100644
--- a/meta-fii/meta-kudo/recipes-kudo/kudo-sys-utility/kudo-cmd/kudo.sh
+++ b/meta-fii/meta-kudo/recipes-kudo/kudo-sys-utility/kudo-cmd/kudo.sh
@@ -45,38 +45,38 @@
function reset() {
case $1 in
hotswap)
- # Virtual reset #94
- set_gpio_ctrl 94 out 1
+ # Virtual reset
+ set_gpio_ctrl HOTSWAP 1
;;
system)
- # S0 system reset #65
- set_gpio_ctrl 65 out 0
+ # S0 system reset
+ set_gpio_ctrl S0_SYSRESET 0
sleep 1
- set_gpio_ctrl 65 out 1
+ set_gpio_ctrl S0_SYSRESET 1
;;
btn)
- # power button #203
- set_gpio_ctrl 203 out 1
+ # virtual power button
+ set_gpio_ctrl POWER_OUT 1
sleep 1
- set_gpio_ctrl 203 out 0
+ set_gpio_ctrl POWER_OUT 0
;;
shutdown)
- # BMC_CPU_SHD_REQ #70
- set_gpio_ctrl 70 out 0
+ # BMC_CPU_SHD_REQ
+ set_gpio_ctrl S0_SHD_REQ 0
sleep 3
- set_gpio_ctrl 70 out 1
+ set_gpio_ctrl S0_SHD_REQ 1
;;
forceOff)
- # power button #203
- set_gpio_ctrl 203 out 1
+ # virtual power button
+ set_gpio_ctrl POWER_OUT 1
sleep 6
- set_gpio_ctrl 203 out 0
+ set_gpio_ctrl POWER_OUT 0
;;
display)
- echo "Virtual reset #94" "$(get_gpio_ctrl 94)"
- echo "S0 System reset #65" "$(get_gpio_ctrl 65)"
- echo "Power Button #203" "$(get_gpio_ctrl 203)"
- echo "BMC_CPU SHD Req #70" "$(get_gpio_ctrl 70)"
+ echo "Virtual reset #$(get_gpio_num HOTSWAP)" "$(get_gpio_ctrl HOTSWAP)"
+ echo "S0 System reset #$(get_gpio_num S0_SYSRESET)" "$(get_gpio_ctrl S0_SYSRESET)"
+ echo "Power Button #$(get_gpio_num POWER_OUT)" "$(get_gpio_ctrl POWER_OUT)"
+ echo "BMC_CPU SHD Req #$(get_gpio_num S0_SHD_REQ)" "$(get_gpio_ctrl S0_SHD_REQ)"
;;
*)
usage_rst
@@ -149,49 +149,49 @@
fi
;;
swhost)
- set_gpio_ctrl 167 out 1
+ set_gpio_ctrl S0_UART0_BMC_SEL 1
;;
swscp1)
- set_gpio_ctrl 161 out 1
- set_gpio_ctrl 177 out 1
- set_gpio_ctrl 198 out 0
+ set_gpio_ctrl S0_UART1_BMC_SEL 1
+ set_gpio_ctrl S1_UART0_BMC_SEL 1
+ set_gpio_ctrl S1_UART1_BMC_SEL 0
;;
swscp2)
- set_gpio_ctrl 161 out 1
- set_gpio_ctrl 177 out 1
- set_gpio_ctrl 198 out 1
+ set_gpio_ctrl S0_UART1_BMC_SEL 1
+ set_gpio_ctrl S1_UART0_BMC_SEL 1
+ set_gpio_ctrl S1_UART1_BMC_SEL 1
;;
swhosthr)
- set_gpio_ctrl 167 out 0
+ set_gpio_ctrl S0_UART0_BMC_SEL 0
;;
swscphr)
- set_gpio_ctrl 161 out 0
- set_gpio_ctrl 177 out 0
+ set_gpio_ctrl S0_UART1_BMC_SEL 0
+ set_gpio_ctrl S1_UART0_BMC_SEL 0
;;
display)
- if [ "$(get_gpio_ctrl 167)" -eq 1 ]; then
+ if [ "$(get_gpio_ctrl S0_UART0_BMC_SEL)" -eq 1 ]; then
echo " CPU host to BMC console"
else
echo " CPU host to header"
fi
- if [ "$(get_gpio_ctrl 161)" -eq 1 ] && [ "$(get_gpio_ctrl 177)" -eq 1 ]; then
- if [ "$(get_gpio_ctrl 198)" -eq 1 ]; then
+ if [ "$(get_gpio_ctrl S0_UART1_BMC_SEL)" -eq 1 ] && [ "$(get_gpio_ctrl S1_UART0_BMC_SEL)" -eq 1 ]; then
+ if [ "$(get_gpio_ctrl S1_UART1_BMC_SEL)" -eq 1 ]; then
echo " SCP2 host to BMC console"
else
echo " SCP1 host to BMC console"
fi
- elif [ "$(get_gpio_ctrl 161)" -eq 0 ] && [ "$(get_gpio_ctrl 177)" -eq 0 ]; then
- if [ "$(get_gpio_ctrl 198)" -eq 1 ]; then
+ elif [ "$(get_gpio_ctrl S0_UART1_BMC_SEL)" -eq 0 ] && [ "$(get_gpio_ctrl S1_UART0_BMC_SEL)" -eq 0 ]; then
+ if [ "$(get_gpio_ctrl S1_UART1_BMC_SEL)" -eq 1 ]; then
echo " SCP2 host to Header"
else
echo " SCP1 host to Header"
fi
else
echo "It's unknown status"
- echo "167" "$(get_gpio_ctrl 167)"
- echo "161" "$(get_gpio_ctrl 161)"
- echo "177" "$(get_gpio_ctrl 177)"
- echo "198" "$(get_gpio_ctrl 198)"
+ echo "S0_UART0_BMC_SEL $(get_gpio_ctrl S0_UART0_BMC_SEL)"
+ echo "S0_UART1_BMC_SEL $(get_gpio_ctrl S0_UART1_BMC_SEL)"
+ echo "S1_UART0_BMC_SEL $(get_gpio_ctrl S1_UART0_BMC_SEL)"
+ echo "S1_UART1_BMC_SEL $(get_gpio_ctrl S1_UART1_BMC_SEL)"
fi
;;
*)