This makes the gpio-tools tests use the gpio-sim kernel module instead of the old gpio-mockup. Signed-off-by: Bartosz Golaszewski <brgl@xxxxxxxx> --- tools/gpio-tools-test | 7 +- tools/gpio-tools-test.bats | 626 +++++++++++++++++++++---------------- 2 files changed, 354 insertions(+), 279 deletions(-) diff --git a/tools/gpio-tools-test b/tools/gpio-tools-test index 9517974..234f9bd 100755 --- a/tools/gpio-tools-test +++ b/tools/gpio-tools-test @@ -2,7 +2,8 @@ # SPDX-License-Identifier: GPL-2.0-or-later # SPDX-FileCopyrightText: 2017-2021 Bartosz Golaszewski <bartekgola@xxxxxxxxx> -MIN_KERNEL_VERSION="5.5.0" +# Switch to v5.17.0 once released +MIN_KERNEL_VERSION="5.16.0" BATS_SCRIPT="gpio-tools-test.bats" SOURCE_DIR="$(dirname ${BASH_SOURCE[0]})" @@ -51,4 +52,8 @@ fi BATS_PATH=$(which bats) +modprobe gpio-sim || die "unable to load the gpio-sim module" +mountpoint /sys/kernel/config/ > /dev/null 2> /dev/null || \ + die "configfs not mounted at /sys/kernel/config/" + exec $BATS_PATH $SOURCE_DIR/$BATS_SCRIPT ${1+"$@"} diff --git a/tools/gpio-tools-test.bats b/tools/gpio-tools-test.bats index a5b97e1..68da3f2 100755 --- a/tools/gpio-tools-test.bats +++ b/tools/gpio-tools-test.bats @@ -10,6 +10,10 @@ COPROC_OUTPUT=$BATS_TMPDIR/gpio-tools-test-output # once it exits as the COPROC_PID will be cleared. COPROC_SAVED_PID="" +GPIOSIM_CHIPS="" +GPIOSIM_CONFIGFS="/sys/kernel/config/gpio-sim/" +GPIOSIM_SYSFS="/sys/devices/platform/" + # Run the command in $* and return 0 if the command failed. The way we do it # here is a workaround for the way bats handles failing processes. assert_fail() { @@ -50,64 +54,122 @@ output_regex_match() { return 1 } -# Probe the gpio-mockup kernel module. The routine expects a list of chip -# sizes and optionally the 'named-lines' flag. -gpio_mockup_probe() { - local CMDLINE="gpio_mockup_ranges=" +random_name() { + cat /proc/sys/kernel/random/uuid +} + +gpiosim_chip() { + local VAR=$1 + local NAME=$(random_name) + local DEVPATH=$GPIOSIM_CONFIGFS/$NAME + local BANKPATH=$DEVPATH/$NAME + + mkdir -p $BANKPATH for ARG in $* do - if [ $ARG = "named-lines" ] + local KEY=$(echo $ARG | cut -d"=" -f1) + local VAL=$(echo $ARG | cut -d"=" -f2) + + if [ "$KEY" = "num_lines" ] then - CMDLINE="gpio_mockup_named_lines $CMDLINE" - continue + echo $VAL > $BANKPATH/num_lines + elif [ "$KEY" = "line_name" ] + then + local OFFSET=$(echo $VAL | cut -d":" -f1) + local LINENAME=$(echo $VAL | cut -d":" -f2) + local LINEPATH=$BANKPATH/line$OFFSET + + mkdir -p $LINEPATH + echo $LINENAME > $LINEPATH/name fi + done - regex_matches "[0-9]+" "$ARG" + echo 1 > $DEVPATH/live - CMDLINE="$CMDLINE-1,$ARG," - done + GPIOSIM_CHIPS="$VAR:$NAME $GPIOSIM_CHIPS" +} + +gpiosim_chip_map_name() { + local VAR=$1 - CMDLINE=${CMDLINE%?} + for CHIP in $GPIOSIM_CHIPS + do + KEY=$(echo $CHIP | cut -d":" -f1) + VAL=$(echo $CHIP | cut -d":" -f2) - modprobe gpio-mockup $CMDLINE - udevadm settle + if [ "$KEY" = "$VAR" ] + then + echo $VAL + fi + done } -gpio_mockup_remove() { - if [ -d /sys/module/gpio_mockup ] - then - rmmod gpio-mockup - fi +gpiosim_chip_name() { + local VAR=$1 + local NAME=$(gpiosim_chip_map_name $VAR) + + cat $GPIOSIM_CONFIGFS/$NAME/$NAME/chip_name } -gpio_mockup_chip_name() { - local CHIPNUM=$1 +gpiosim_dev_name() { + local VAR=$1 + local NAME=$(gpiosim_chip_map_name $VAR) - test -d /sys/devices/platform/gpio-mockup.$CHIPNUM/ || return 1 - echo $(ls /sys/devices/platform/gpio-mockup.$CHIPNUM/ | grep gpiochip) + cat $GPIOSIM_CONFIGFS/$NAME/dev_name } -gpio_mockup_set_pull() { - local CHIPNUM=$1 - local LINE=$2 +gpiosim_set_pull() { + local VAR=$1 + local OFFSET=$2 local PULL=$3 + local DEVNAME=$(gpiosim_dev_name $VAR) + local CHIPNAME=$(gpiosim_chip_name $VAR) - FILE="/sys/kernel/debug/gpio-mockup/$(gpio_mockup_chip_name $CHIPNUM)/$LINE" - test -f $FILE || return 1 - echo "$PULL" > $FILE + echo $PULL > $GPIOSIM_SYSFS/$DEVNAME/$CHIPNAME/sim_gpio$OFFSET/pull } -gpio_mockup_check_value() { - local CHIPNUM=$1 - local LINE=$2 +gpiosim_check_value() { + local VAR=$1 + local OFFSET=$2 local EXPECTED=$3 + local DEVNAME=$(gpiosim_dev_name $VAR) + local CHIPNAME=$(gpiosim_chip_name $VAR) - FILE="/sys/kernel/debug/gpio-mockup/$(gpio_mockup_chip_name $CHIPNUM)/$LINE" - test -f $FILE || return 1 + VAL=$(cat $GPIOSIM_SYSFS/$DEVNAME/$CHIPNAME/sim_gpio$OFFSET/value) + if [ "$VAL" = "$EXPECTED" ] + then + return 0 + fi - VAL=$(cat $FILE) - test $VAL -eq $EXPECTED || return 1 + return 1 +} + +gpiosim_cleanup() { + for CHIP in $GPIOSIM_CHIPS + do + local NAME=$(echo $CHIP | cut -d":" -f2) + + local DEVPATH=$GPIOSIM_CONFIGFS/$NAME + local BANKPATH=$DEVPATH/$NAME + + echo 0 > $DEVPATH/live + + ls $BANKPATH/line* 2> /dev/null + if [ "$?" = "0" ] + then + for LINE in $(find $BANKPATH/ | egrep "line[0-9]+$") + do + test -e $LINE/hog && rmdir $LINE/hog + rmdir $LINE + done + fi + + rmdir $BANKPATH + rmdir $DEVPATH + done + + GPIOSIM_CHIPS="" } run_tool() { @@ -147,10 +209,6 @@ coproc_tool_wait() { rm -f $COPROC_OUTPUT } -setup() { - gpio_mockup_remove -} - teardown() { if [ -n "$BG_PROC_PID" ] then @@ -159,7 +217,7 @@ teardown() { BG_PROC_PID="" fi - gpio_mockup_remove + gpiosim_cleanup } # @@ -167,14 +225,16 @@ teardown() { # @test "gpiodetect: list chips" { - gpio_mockup_probe 4 8 16 + gpiosim_chip sim0 num_lines=4 + gpiosim_chip sim1 num_lines=8 + gpiosim_chip sim2 num_lines=16 run_tool gpiodetect test "$status" -eq 0 - output_contains_line "$(gpio_mockup_chip_name 0) [gpio-mockup-A] (4 lines)" - output_contains_line "$(gpio_mockup_chip_name 1) [gpio-mockup-B] (8 lines)" - output_contains_line "$(gpio_mockup_chip_name 2) [gpio-mockup-C] (16 lines)" + output_contains_line "$(gpiosim_chip_name sim0) [$(gpiosim_dev_name sim0)-node0] (4 lines)" + output_contains_line "$(gpiosim_chip_name sim1) [$(gpiosim_dev_name sim1)-node0] (8 lines)" + output_contains_line "$(gpiosim_chip_name sim2) [$(gpiosim_dev_name sim2)-node0] (16 lines)" } @test "gpiodetect: invalid args" { @@ -187,28 +247,30 @@ teardown() { # @test "gpioinfo: dump all chips" { - gpio_mockup_probe 4 8 + gpiosim_chip sim0 num_lines=4 + gpiosim_chip sim1 num_lines=8 run_tool gpioinfo test "$status" -eq 0 - output_contains_line "$(gpio_mockup_chip_name 0) - 4 lines:" - output_contains_line "$(gpio_mockup_chip_name 1) - 8 lines:" + output_contains_line "$(gpiosim_chip_name sim0) - 4 lines:" + output_contains_line "$(gpiosim_chip_name sim1) - 8 lines:" output_regex_match "\\s+line\\s+0:\\s+unnamed\\s+unused\\s+input\\s+active-high" output_regex_match "\\s+line\\s+7:\\s+unnamed\\s+unused\\s+input\\s+active-high" } @test "gpioinfo: dump all chips with one line exported" { - gpio_mockup_probe 4 8 + gpiosim_chip sim0 num_lines=4 + gpiosim_chip sim1 num_lines=8 - coproc_run_tool gpioset --mode=signal --active-low "$(gpio_mockup_chip_name 1)" 7=1 + coproc_run_tool gpioset --mode=signal --active-low "$(gpiosim_chip_name sim1)" 7=1 run_tool gpioinfo test "$status" -eq 0 - output_contains_line "$(gpio_mockup_chip_name 0) - 4 lines:" - output_contains_line "$(gpio_mockup_chip_name 1) - 8 lines:" + output_contains_line "$(gpiosim_chip_name sim0) - 4 lines:" + output_contains_line "$(gpiosim_chip_name sim1) - 8 lines:" output_regex_match "\\s+line\\s+0:\\s+unnamed\\s+unused\\s+input\\s+active-high" output_regex_match "\\s+line\\s+7:\\s+unnamed\\s+\\\"gpioset\\\"\\s+output\\s+active-low" @@ -217,28 +279,32 @@ teardown() { } @test "gpioinfo: dump one chip" { - gpio_mockup_probe 8 4 + gpiosim_chip sim0 num_lines=8 + gpiosim_chip sim1 num_lines=4 - run_tool gpioinfo "$(gpio_mockup_chip_name 1)" + run_tool gpioinfo "$(gpiosim_chip_name sim1)" test "$status" -eq 0 - assert_fail output_contains_line "$(gpio_mockup_chip_name 0) - 8 lines:" - output_contains_line "$(gpio_mockup_chip_name 1) - 4 lines:" + assert_fail output_contains_line "$(gpiosim_chip_name sim0) - 8 lines:" + output_contains_line "$(gpiosim_chip_name sim1) - 4 lines:" output_regex_match "\\s+line\\s+0:\\s+unnamed\\s+unused\\s+input\\s+active-high" assert_fail output_regex_match "\\s+line\\s+7:\\s+unnamed\\s+unused\\s+input\\s+active-high" } @test "gpioinfo: dump all but one chip" { - gpio_mockup_probe 4 4 8 4 + gpiosim_chip sim0 num_lines=4 + gpiosim_chip sim1 num_lines=4 + gpiosim_chip sim2 num_lines=8 + gpiosim_chip sim3 num_lines=4 - run_tool gpioinfo "$(gpio_mockup_chip_name 0)" \ - "$(gpio_mockup_chip_name 1)" "$(gpio_mockup_chip_name 3)" + run_tool gpioinfo "$(gpiosim_chip_name sim0)" \ + "$(gpiosim_chip_name sim1)" "$(gpiosim_chip_name sim3)" test "$status" -eq 0 - output_contains_line "$(gpio_mockup_chip_name 0) - 4 lines:" - output_contains_line "$(gpio_mockup_chip_name 1) - 4 lines:" - assert_fail output_contains_line "$(gpio_mockup_chip_name 2) - 8 lines:" - output_contains_line "$(gpio_mockup_chip_name 3) - 4 lines:" + output_contains_line "$(gpiosim_chip_name sim0) - 4 lines:" + output_contains_line "$(gpiosim_chip_name sim1) - 4 lines:" + assert_fail output_contains_line "$(gpiosim_chip_name sim2) - 8 lines:" + output_contains_line "$(gpiosim_chip_name sim3) - 4 lines:" output_regex_match "\\s+line\\s+0:\\s+unnamed\\s+unused\\s+input\\s+active-high" assert_fail output_regex_match "\\s+line\\s+7:\\s+unnamed\\s+unused\\s+input\\s+active-high" } @@ -254,16 +320,20 @@ teardown() { # @test "gpiofind: line found" { - gpio_mockup_probe named-lines 4 8 16 + gpiosim_chip sim0 num_lines=4 line_name=1:foo line_name=3:bar + gpiosim_chip sim1 num_lines=8 line_name=0:baz line_name=4:xyz line_name=7:foobar + gpiosim_chip sim2 num_lines=16 - run_tool gpiofind gpio-mockup-B-7 + run_tool gpiofind foobar test "$status" -eq "0" - test "$output" = "$(gpio_mockup_chip_name 1) 7" + test "$output" = "$(gpiosim_chip_name sim1) 7" } @test "gpiofind: line not found" { - gpio_mockup_probe named-lines 4 8 16 + gpiosim_chip sim0 num_lines=4 + gpiosim_chip sim1 num_lines=8 + gpiosim_chip sim2 num_lines=16 run_tool gpiofind nonexistent-line @@ -280,69 +350,69 @@ teardown() { # @test "gpioget: read all lines" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - gpio_mockup_set_pull 1 2 1 - gpio_mockup_set_pull 1 3 1 - gpio_mockup_set_pull 1 5 1 - gpio_mockup_set_pull 1 7 1 + gpiosim_set_pull sim0 2 pull-up + gpiosim_set_pull sim0 3 pull-up + gpiosim_set_pull sim0 5 pull-up + gpiosim_set_pull sim0 7 pull-up - run_tool gpioget "$(gpio_mockup_chip_name 1)" 0 1 2 3 4 5 6 7 + run_tool gpioget "$(gpiosim_chip_name sim0)" 0 1 2 3 4 5 6 7 test "$status" -eq "0" test "$output" = "0 0 1 1 0 1 0 1" } @test "gpioget: read all lines (active-low)" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - gpio_mockup_set_pull 1 2 1 - gpio_mockup_set_pull 1 3 1 - gpio_mockup_set_pull 1 5 1 - gpio_mockup_set_pull 1 7 1 + gpiosim_set_pull sim0 2 pull-up + gpiosim_set_pull sim0 3 pull-up + gpiosim_set_pull sim0 5 pull-up + gpiosim_set_pull sim0 7 pull-up - run_tool gpioget --active-low "$(gpio_mockup_chip_name 1)" 0 1 2 3 4 5 6 7 + run_tool gpioget --active-low "$(gpiosim_chip_name sim0)" 0 1 2 3 4 5 6 7 test "$status" -eq "0" test "$output" = "1 1 0 0 1 0 1 0" } @test "gpioget: read all lines (pull-up)" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - gpio_mockup_set_pull 1 2 1 - gpio_mockup_set_pull 1 3 1 - gpio_mockup_set_pull 1 5 1 - gpio_mockup_set_pull 1 7 1 + gpiosim_set_pull sim0 2 pull-up + gpiosim_set_pull sim0 3 pull-up + gpiosim_set_pull sim0 5 pull-up + gpiosim_set_pull sim0 7 pull-up - run_tool gpioget --bias=pull-up "$(gpio_mockup_chip_name 1)" 0 1 2 3 4 5 6 7 + run_tool gpioget --bias=pull-up "$(gpiosim_chip_name sim0)" 0 1 2 3 4 5 6 7 test "$status" -eq "0" test "$output" = "1 1 1 1 1 1 1 1" } @test "gpioget: read all lines (pull-down)" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - gpio_mockup_set_pull 1 2 1 - gpio_mockup_set_pull 1 3 1 - gpio_mockup_set_pull 1 5 1 - gpio_mockup_set_pull 1 7 1 + gpiosim_set_pull sim0 2 pull-up + gpiosim_set_pull sim0 3 pull-up + gpiosim_set_pull sim0 5 pull-up + gpiosim_set_pull sim0 7 pull-up - run_tool gpioget --bias=pull-down "$(gpio_mockup_chip_name 1)" 0 1 2 3 4 5 6 7 + run_tool gpioget --bias=pull-down "$(gpiosim_chip_name sim0)" 0 1 2 3 4 5 6 7 test "$status" -eq "0" test "$output" = "0 0 0 0 0 0 0 0" } @test "gpioget: read some lines" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - gpio_mockup_set_pull 1 1 1 - gpio_mockup_set_pull 1 4 1 - gpio_mockup_set_pull 1 6 1 + gpiosim_set_pull sim0 1 pull-up + gpiosim_set_pull sim0 4 pull-up + gpiosim_set_pull sim0 6 pull-up - run_tool gpioget "$(gpio_mockup_chip_name 1)" 0 1 4 6 + run_tool gpioget "$(gpiosim_chip_name sim0)" 0 1 4 6 test "$status" -eq "0" test "$output" = "0 1 1 1" @@ -356,36 +426,36 @@ teardown() { } @test "gpioget: no lines specified" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - run_tool gpioget "$(gpio_mockup_chip_name 1)" + run_tool gpioget "$(gpiosim_chip_name sim0)" test "$status" -eq "1" output_regex_match ".*at least one GPIO line offset must be specified" } @test "gpioget: too many lines specified" { - gpio_mockup_probe 4 + gpiosim_chip sim0 num_lines=4 - run_tool gpioget "$(gpio_mockup_chip_name 1)" 0 1 2 3 4 + run_tool gpioget "$(gpiosim_chip_name sim0)" 0 1 2 3 4 test "$status" -eq "1" output_regex_match ".*unable to retrieve GPIO lines from chip" } @test "gpioget: same line twice" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - run_tool gpioget "$(gpio_mockup_chip_name 1)" 0 0 + run_tool gpioget "$(gpiosim_chip_name sim0)" 0 0 test "$status" -eq "1" output_regex_match ".*unable to request lines.*" } @test "gpioget: invalid bias" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - run_tool gpioget --bias=bad "$(gpio_mockup_chip_name 1)" 0 1 + run_tool gpioget --bias=bad "$(gpiosim_chip_name sim0)" 0 1 test "$status" -eq "1" output_regex_match ".*invalid bias.*" @@ -396,19 +466,19 @@ teardown() { # @test "gpioset: set lines and wait for SIGTERM" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - coproc_run_tool gpioset --mode=signal "$(gpio_mockup_chip_name 2)" \ + coproc_run_tool gpioset --mode=signal "$(gpiosim_chip_name sim0)" \ 0=0 1=0 2=1 3=1 4=1 5=1 6=0 7=1 - gpio_mockup_check_value 2 0 0 - gpio_mockup_check_value 2 1 0 - gpio_mockup_check_value 2 2 1 - gpio_mockup_check_value 2 3 1 - gpio_mockup_check_value 2 4 1 - gpio_mockup_check_value 2 5 1 - gpio_mockup_check_value 2 6 0 - gpio_mockup_check_value 2 7 1 + gpiosim_check_value sim0 0 0 + gpiosim_check_value sim0 1 0 + gpiosim_check_value sim0 2 1 + gpiosim_check_value sim0 3 1 + gpiosim_check_value sim0 4 1 + gpiosim_check_value sim0 5 1 + gpiosim_check_value sim0 6 0 + gpiosim_check_value sim0 7 1 coproc_tool_kill coproc_tool_wait @@ -417,19 +487,19 @@ teardown() { } @test "gpioset: set lines and wait for SIGTERM (active-low)" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - coproc_run_tool gpioset --active-low --mode=signal "$(gpio_mockup_chip_name 2)" \ + coproc_run_tool gpioset --active-low --mode=signal "$(gpiosim_chip_name sim0)" \ 0=0 1=0 2=1 3=1 4=1 5=1 6=0 7=1 - gpio_mockup_check_value 2 0 1 - gpio_mockup_check_value 2 1 1 - gpio_mockup_check_value 2 2 0 - gpio_mockup_check_value 2 3 0 - gpio_mockup_check_value 2 4 0 - gpio_mockup_check_value 2 5 0 - gpio_mockup_check_value 2 6 1 - gpio_mockup_check_value 2 7 0 + gpiosim_check_value sim0 0 1 + gpiosim_check_value sim0 1 1 + gpiosim_check_value sim0 2 0 + gpiosim_check_value sim0 3 0 + gpiosim_check_value sim0 4 0 + gpiosim_check_value sim0 5 0 + gpiosim_check_value sim0 6 1 + gpiosim_check_value sim0 7 0 coproc_tool_kill coproc_tool_wait @@ -438,19 +508,19 @@ teardown() { } @test "gpioset: set lines and wait for SIGTERM (push-pull)" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - coproc_run_tool gpioset --drive=push-pull --mode=signal "$(gpio_mockup_chip_name 2)" \ + coproc_run_tool gpioset --drive=push-pull --mode=signal "$(gpiosim_chip_name sim0)" \ 0=0 1=0 2=1 3=1 4=1 5=1 6=0 7=1 - gpio_mockup_check_value 2 0 0 - gpio_mockup_check_value 2 1 0 - gpio_mockup_check_value 2 2 1 - gpio_mockup_check_value 2 3 1 - gpio_mockup_check_value 2 4 1 - gpio_mockup_check_value 2 5 1 - gpio_mockup_check_value 2 6 0 - gpio_mockup_check_value 2 7 1 + gpiosim_check_value sim0 0 0 + gpiosim_check_value sim0 1 0 + gpiosim_check_value sim0 2 1 + gpiosim_check_value sim0 3 1 + gpiosim_check_value sim0 4 1 + gpiosim_check_value sim0 5 1 + gpiosim_check_value sim0 6 0 + gpiosim_check_value sim0 7 1 coproc_tool_kill coproc_tool_wait @@ -459,24 +529,24 @@ teardown() { } @test "gpioset: set lines and wait for SIGTERM (open-drain)" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - gpio_mockup_set_pull 2 2 1 - gpio_mockup_set_pull 2 3 1 - gpio_mockup_set_pull 2 5 1 - gpio_mockup_set_pull 2 7 1 + gpiosim_set_pull sim0 2 pull-up + gpiosim_set_pull sim0 3 pull-up + gpiosim_set_pull sim0 5 pull-up + gpiosim_set_pull sim0 7 pull-up - coproc_run_tool gpioset --drive=open-drain --mode=signal "$(gpio_mockup_chip_name 2)" \ + coproc_run_tool gpioset --drive=open-drain --mode=signal "$(gpiosim_chip_name sim0)" \ 0=0 1=0 2=1 3=1 4=1 5=1 6=0 7=1 - gpio_mockup_check_value 2 0 0 - gpio_mockup_check_value 2 1 0 - gpio_mockup_check_value 2 2 1 - gpio_mockup_check_value 2 3 1 - gpio_mockup_check_value 2 4 0 - gpio_mockup_check_value 2 5 1 - gpio_mockup_check_value 2 6 0 - gpio_mockup_check_value 2 7 1 + gpiosim_check_value sim0 0 0 + gpiosim_check_value sim0 1 0 + gpiosim_check_value sim0 2 1 + gpiosim_check_value sim0 3 1 + gpiosim_check_value sim0 4 0 + gpiosim_check_value sim0 5 1 + gpiosim_check_value sim0 6 0 + gpiosim_check_value sim0 7 1 coproc_tool_kill coproc_tool_wait @@ -485,24 +555,24 @@ teardown() { } @test "gpioset: set lines and wait for SIGTERM (open-source)" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - gpio_mockup_set_pull 2 2 1 - gpio_mockup_set_pull 2 3 1 - gpio_mockup_set_pull 2 5 1 - gpio_mockup_set_pull 2 7 1 + gpiosim_set_pull sim0 2 pull-up + gpiosim_set_pull sim0 3 pull-up + gpiosim_set_pull sim0 5 pull-up + gpiosim_set_pull sim0 7 pull-up - coproc_run_tool gpioset --drive=open-source --mode=signal "$(gpio_mockup_chip_name 2)" \ + coproc_run_tool gpioset --drive=open-source --mode=signal "$(gpiosim_chip_name sim0)" \ 0=0 1=0 2=1 3=0 4=1 5=1 6=0 7=1 - gpio_mockup_check_value 2 0 0 - gpio_mockup_check_value 2 1 0 - gpio_mockup_check_value 2 2 1 - gpio_mockup_check_value 2 3 1 - gpio_mockup_check_value 2 4 1 - gpio_mockup_check_value 2 5 1 - gpio_mockup_check_value 2 6 0 - gpio_mockup_check_value 2 7 1 + gpiosim_check_value sim0 0 0 + gpiosim_check_value sim0 1 0 + gpiosim_check_value sim0 2 1 + gpiosim_check_value sim0 3 1 + gpiosim_check_value sim0 4 1 + gpiosim_check_value sim0 5 1 + gpiosim_check_value sim0 6 0 + gpiosim_check_value sim0 7 1 coproc_tool_kill coproc_tool_wait @@ -511,16 +581,16 @@ teardown() { } @test "gpioset: set some lines and wait for ENTER" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - coproc_run_tool gpioset --mode=wait "$(gpio_mockup_chip_name 2)" \ + coproc_run_tool gpioset --mode=wait "$(gpiosim_chip_name sim0)" \ 1=0 2=1 5=1 6=0 7=1 - gpio_mockup_check_value 2 1 0 - gpio_mockup_check_value 2 2 1 - gpio_mockup_check_value 2 5 1 - gpio_mockup_check_value 2 6 0 - gpio_mockup_check_value 2 7 1 + gpiosim_check_value sim0 1 0 + gpiosim_check_value sim0 2 1 + gpiosim_check_value sim0 5 1 + gpiosim_check_value sim0 6 0 + gpiosim_check_value sim0 7 1 coproc_tool_stdin_write "" coproc_tool_wait @@ -529,11 +599,11 @@ teardown() { } @test "gpioset: set some lines and wait for SIGINT" { - gpio_mockup_probe 8 + gpiosim_chip sim0 num_lines=4 - coproc_run_tool gpioset --mode=signal "$(gpio_mockup_chip_name 0)" 0=1 + coproc_run_tool gpioset --mode=signal "$(gpiosim_chip_name sim0)" 0=1 - gpio_mockup_check_value 0 0 1 + gpiosim_check_value sim0 0 1 coproc_tool_kill -SIGINT coproc_tool_wait @@ -542,14 +612,14 @@ teardown() { } @test "gpioset: set some lines and wait with --mode=time" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 coproc_run_tool gpioset --mode=time --sec=1 --usec=200000 \ - "$(gpio_mockup_chip_name 1)" 0=1 5=0 7=1 + "$(gpiosim_chip_name sim0)" 0=1 5=0 7=1 - gpio_mockup_check_value 1 0 1 - gpio_mockup_check_value 1 5 0 - gpio_mockup_check_value 1 7 1 + gpiosim_check_value sim0 0 1 + gpiosim_check_value sim0 5 0 + gpiosim_check_value sim0 7 1 coproc_tool_wait @@ -564,107 +634,107 @@ teardown() { } @test "gpioset: no lines specified" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - run_tool gpioset "$(gpio_mockup_chip_name 1)" + run_tool gpioset "$(gpiosim_chip_name sim1)" test "$status" -eq "1" output_regex_match ".*at least one GPIO line offset to value mapping must be specified" } @test "gpioset: too many lines specified" { - gpio_mockup_probe 4 + gpiosim_chip sim0 num_lines=4 - run_tool gpioset "$(gpio_mockup_chip_name 1)" 0=1 1=1 2=1 3=1 4=1 5=1 + run_tool gpioset "$(gpiosim_chip_name sim0)" 0=1 1=1 2=1 3=1 4=1 5=1 test "$status" -eq "1" output_regex_match ".*unable to retrieve GPIO lines from chip" } @test "gpioset: use --sec without --mode=time" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - run_tool gpioset --mode=exit --sec=1 "$(gpio_mockup_chip_name 1)" 0=1 + run_tool gpioset --mode=exit --sec=1 "$(gpiosim_chip_name sim0)" 0=1 test "$status" -eq "1" output_regex_match ".*can't specify wait time in this mode" } @test "gpioset: use --usec without --mode=time" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - run_tool gpioset --mode=exit --usec=1 "$(gpio_mockup_chip_name 1)" 0=1 + run_tool gpioset --mode=exit --usec=1 "$(gpiosim_chip_name sim1)" 0=1 test "$status" -eq "1" output_regex_match ".*can't specify wait time in this mode" } @test "gpioset: default mode" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - run_tool gpioset "$(gpio_mockup_chip_name 1)" 0=1 + run_tool gpioset "$(gpiosim_chip_name sim0)" 0=1 test "$status" -eq "0" } @test "gpioset: invalid mapping" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - run_tool gpioset "$(gpio_mockup_chip_name 1)" 0=c + run_tool gpioset "$(gpiosim_chip_name sim1)" 0=c test "$status" -eq "1" output_regex_match ".*invalid offset<->value mapping" } @test "gpioset: invalid value" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - run_tool gpioset "$(gpio_mockup_chip_name 1)" 0=3 + run_tool gpioset "$(gpiosim_chip_name sim1)" 0=3 test "$status" -eq "1" output_regex_match ".*value must be 0 or 1" } @test "gpioset: invalid offset" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - run_tool gpioset "$(gpio_mockup_chip_name 1)" 4000000000=0 + run_tool gpioset "$(gpiosim_chip_name sim1)" 4000000000=0 test "$status" -eq "1" output_regex_match ".*invalid offset" } @test "gpioset: invalid bias" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - run_tool gpioset --bias=bad "$(gpio_mockup_chip_name 1)" 0=1 1=1 + run_tool gpioset --bias=bad "$(gpiosim_chip_name sim1)" 0=1 1=1 test "$status" -eq "1" output_regex_match ".*invalid bias.*" } @test "gpioset: invalid drive" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - run_tool gpioset --drive=bad "$(gpio_mockup_chip_name 1)" 0=1 1=1 + run_tool gpioset --drive=bad "$(gpiosim_chip_name sim1)" 0=1 1=1 test "$status" -eq "1" output_regex_match ".*invalid drive.*" } @test "gpioset: daemonize in invalid mode" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - run_tool gpioset --background "$(gpio_mockup_chip_name 1)" 0=1 + run_tool gpioset --background "$(gpiosim_chip_name sim1)" 0=1 test "$status" -eq "1" output_regex_match ".*can't daemonize in this mode" } @test "gpioset: same line twice" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - run_tool gpioset "$(gpio_mockup_chip_name 1)" 0=1 0=1 + run_tool gpioset "$(gpiosim_chip_name sim0)" 0=1 0=1 test "$status" -eq "1" output_regex_match ".*unable to request lines.*" @@ -675,11 +745,11 @@ teardown() { # @test "gpiomon: single rising edge event" { - gpio_mockup_probe 8 8 + gpiosim_chip sim0 num_lines=8 - coproc_run_tool gpiomon --rising-edge "$(gpio_mockup_chip_name 1)" 4 + coproc_run_tool gpiomon --rising-edge "$(gpiosim_chip_name sim0)" 4 - gpio_mockup_set_pull 1 4 1 + gpiosim_set_pull sim0 4 pull-up sleep 0.2 coproc_tool_kill @@ -691,12 +761,12 @@ teardown() { } @test "gpiomon: single falling edge event" { - gpio_mockup_probe 8 8 + gpiosim_chip sim0 num_lines=8 - coproc_run_tool gpiomon --falling-edge "$(gpio_mockup_chip_name 1)" 4 + coproc_run_tool gpiomon --falling-edge "$(gpiosim_chip_name sim0)" 4 - gpio_mockup_set_pull 1 4 1 - gpio_mockup_set_pull 1 4 0 + gpiosim_set_pull sim0 4 pull-up + gpiosim_set_pull sim0 4 pull-down sleep 0.2 coproc_tool_kill @@ -708,13 +778,13 @@ teardown() { } @test "gpiomon: single falling edge event (pull-up)" { - gpio_mockup_probe 8 8 + gpiosim_chip sim0 num_lines=8 - gpio_mockup_set_pull 1 4 0 + gpiosim_set_pull sim0 4 pull-down - coproc_run_tool gpiomon --bias=pull-up "$(gpio_mockup_chip_name 1)" 4 + coproc_run_tool gpiomon --bias=pull-up "$(gpiosim_chip_name sim0)" 4 - gpio_mockup_set_pull 1 4 0 + gpiosim_set_pull sim0 4 pull-down sleep 0.2 coproc_tool_kill @@ -726,13 +796,13 @@ teardown() { } @test "gpiomon: single rising edge event (pull-down)" { - gpio_mockup_probe 8 8 + gpiosim_chip sim0 num_lines=8 - gpio_mockup_set_pull 1 4 1 + gpiosim_set_pull sim0 4 pull-up - coproc_run_tool gpiomon --bias=pull-down "$(gpio_mockup_chip_name 1)" 4 + coproc_run_tool gpiomon --bias=pull-down "$(gpiosim_chip_name sim0)" 4 - gpio_mockup_set_pull 1 4 1 + gpiosim_set_pull sim0 4 pull-up sleep 0.2 coproc_tool_kill @@ -744,13 +814,13 @@ teardown() { } @test "gpiomon: single rising edge event (active-low)" { - gpio_mockup_probe 8 8 + gpiosim_chip sim0 num_lines=8 - gpio_mockup_set_pull 1 4 1 + gpiosim_set_pull sim0 4 pull-up - coproc_run_tool gpiomon --rising-edge --active-low "$(gpio_mockup_chip_name 1)" 4 + coproc_run_tool gpiomon --rising-edge --active-low "$(gpiosim_chip_name sim0)" 4 - gpio_mockup_set_pull 1 4 0 + gpiosim_set_pull sim0 4 pull-down sleep 0.2 coproc_tool_kill @@ -762,11 +832,11 @@ teardown() { } @test "gpiomon: single rising edge event (silent mode)" { - gpio_mockup_probe 8 8 + gpiosim_chip sim0 num_lines=8 - coproc_run_tool gpiomon --rising-edge --silent "$(gpio_mockup_chip_name 1)" 4 + coproc_run_tool gpiomon --rising-edge --silent "$(gpiosim_chip_name sim0)" 4 - gpio_mockup_set_pull 1 4 1 + gpiosim_set_pull sim0 4 pull-up sleep 0.2 coproc_tool_kill @@ -777,17 +847,17 @@ teardown() { } @test "gpiomon: four alternating events" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - coproc_run_tool gpiomon --num-events=4 "$(gpio_mockup_chip_name 1)" 4 + coproc_run_tool gpiomon --num-events=4 "$(gpiosim_chip_name sim0)" 4 - gpio_mockup_set_pull 1 4 1 + gpiosim_set_pull sim0 4 pull-up sleep 0.2 - gpio_mockup_set_pull 1 4 0 + gpiosim_set_pull sim0 4 pull-down sleep 0.2 - gpio_mockup_set_pull 1 4 1 + gpiosim_set_pull sim0 4 pull-up sleep 0.2 - gpio_mockup_set_pull 1 4 0 + gpiosim_set_pull sim0 4 pull-down sleep 0.2 coproc_tool_wait @@ -800,9 +870,9 @@ teardown() { } @test "gpiomon: exit after SIGINT" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - coproc_run_tool gpiomon "$(gpio_mockup_chip_name 1)" 4 + coproc_run_tool gpiomon "$(gpiosim_chip_name sim0)" 4 coproc_tool_kill -SIGINT coproc_tool_wait @@ -812,9 +882,9 @@ teardown() { } @test "gpiomon: exit after SIGTERM" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - coproc_run_tool gpiomon "$(gpio_mockup_chip_name 1)" 4 + coproc_run_tool gpiomon "$(gpiosim_chip_name sim0)" 4 coproc_tool_kill -SIGTERM coproc_tool_wait @@ -824,13 +894,13 @@ teardown() { } @test "gpiomon: both event flags" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - coproc_run_tool gpiomon --falling-edge --rising-edge "$(gpio_mockup_chip_name 1)" 4 + coproc_run_tool gpiomon --falling-edge --rising-edge "$(gpiosim_chip_name sim0)" 4 - gpio_mockup_set_pull 1 4 1 + gpiosim_set_pull sim0 4 pull-up sleep 0.2 - gpio_mockup_set_pull 1 4 0 + gpiosim_set_pull sim0 4 pull-down sleep 0.2 coproc_tool_kill @@ -844,13 +914,13 @@ teardown() { } @test "gpiomon: watch multiple lines" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - coproc_run_tool gpiomon --format=%o "$(gpio_mockup_chip_name 1)" 1 2 3 4 5 + coproc_run_tool gpiomon --format=%o "$(gpiosim_chip_name sim0)" 1 2 3 4 5 - gpio_mockup_set_pull 1 2 1 - gpio_mockup_set_pull 1 3 1 - gpio_mockup_set_pull 1 4 1 + gpiosim_set_pull sim0 2 pull-up + gpiosim_set_pull sim0 3 pull-up + gpiosim_set_pull sim0 4 pull-up sleep 0.2 coproc_tool_kill @@ -863,13 +933,13 @@ teardown() { } @test "gpiomon: watch multiple lines (lines in mixed-up order)" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - coproc_run_tool gpiomon --format=%o "$(gpio_mockup_chip_name 1)" 5 2 7 1 6 + coproc_run_tool gpiomon --format=%o "$(gpiosim_chip_name sim0)" 5 2 7 1 6 - gpio_mockup_set_pull 1 2 1 - gpio_mockup_set_pull 1 1 1 - gpio_mockup_set_pull 1 6 1 + gpiosim_set_pull sim0 2 pull-up + gpiosim_set_pull sim0 1 pull-up + gpiosim_set_pull sim0 6 pull-up sleep 0.2 coproc_tool_kill @@ -882,9 +952,9 @@ teardown() { } @test "gpiomon: same line twice" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - run_tool gpiomon "$(gpio_mockup_chip_name 1)" 0 0 + run_tool gpiomon "$(gpiosim_chip_name sim0)" 0 0 test "$status" -eq "1" output_regex_match ".*unable to request GPIO lines for events" @@ -898,38 +968,38 @@ teardown() { } @test "gpiomon: line not specified" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - run_tool gpiomon "$(gpio_mockup_chip_name 1)" + run_tool gpiomon "$(gpiosim_chip_name sim0)" test "$status" -eq "1" output_regex_match ".*GPIO line offset must be specified" } @test "gpiomon: line out of range" { - gpio_mockup_probe 4 + gpiosim_chip sim0 num_lines=4 - run_tool gpiomon "$(gpio_mockup_chip_name 0)" 5 + run_tool gpiomon "$(gpiosim_chip_name sim0)" 5 test "$status" -eq "1" output_regex_match ".*unable to retrieve GPIO lines from chip" } @test "gpiomon: invalid bias" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - run_tool gpiomon --bias=bad "$(gpio_mockup_chip_name 1)" 0 1 + run_tool gpiomon --bias=bad "$(gpiosim_chip_name sim0)" 0 1 test "$status" -eq "1" output_regex_match ".*invalid bias.*" } @test "gpiomon: custom format (event type + offset)" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - coproc_run_tool gpiomon "--format=%e %o" "$(gpio_mockup_chip_name 1)" 4 + coproc_run_tool gpiomon "--format=%e %o" "$(gpiosim_chip_name sim0)" 4 - gpio_mockup_set_pull 1 4 1 + gpiosim_set_pull sim0 4 pull-up sleep 0.2 coproc_tool_kill @@ -940,11 +1010,11 @@ teardown() { } @test "gpiomon: custom format (event type + offset joined)" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - coproc_run_tool gpiomon "--format=%e%o" "$(gpio_mockup_chip_name 1)" 4 + coproc_run_tool gpiomon "--format=%e%o" "$(gpiosim_chip_name sim0)" 4 - gpio_mockup_set_pull 1 4 1 + gpiosim_set_pull sim0 4 pull-up sleep 0.2 coproc_tool_kill @@ -955,11 +1025,11 @@ teardown() { } @test "gpiomon: custom format (timestamp)" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - coproc_run_tool gpiomon "--format=%e %o %s.%n" "$(gpio_mockup_chip_name 1)" 4 + coproc_run_tool gpiomon "--format=%e %o %s.%n" "$(gpiosim_chip_name sim0)" 4 - gpio_mockup_set_pull 1 4 1 + gpiosim_set_pull sim0 4 pull-up sleep 0.2 coproc_tool_kill @@ -970,11 +1040,11 @@ teardown() { } @test "gpiomon: custom format (double percent sign)" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - coproc_run_tool gpiomon "--format=%%" "$(gpio_mockup_chip_name 1)" 4 + coproc_run_tool gpiomon "--format=%%" "$(gpiosim_chip_name sim0)" 4 - gpio_mockup_set_pull 1 4 1 + gpiosim_set_pull sim0 4 pull-up sleep 0.2 coproc_tool_kill @@ -985,11 +1055,11 @@ teardown() { } @test "gpiomon: custom format (double percent sign + event type specifier)" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - coproc_run_tool gpiomon "--format=%%e" "$(gpio_mockup_chip_name 1)" 4 + coproc_run_tool gpiomon "--format=%%e" "$(gpiosim_chip_name sim0)" 4 - gpio_mockup_set_pull 1 4 1 + gpiosim_set_pull sim0 4 pull-up sleep 0.2 coproc_tool_kill @@ -1000,11 +1070,11 @@ teardown() { } @test "gpiomon: custom format (single percent sign)" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - coproc_run_tool gpiomon "--format=%" "$(gpio_mockup_chip_name 1)" 4 + coproc_run_tool gpiomon "--format=%" "$(gpiosim_chip_name sim0)" 4 - gpio_mockup_set_pull 1 4 1 + gpiosim_set_pull sim0 4 pull-up sleep 0.2 coproc_tool_kill @@ -1015,11 +1085,11 @@ teardown() { } @test "gpiomon: custom format (single percent sign between other characters)" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - coproc_run_tool gpiomon "--format=foo % bar" "$(gpio_mockup_chip_name 1)" 4 + coproc_run_tool gpiomon "--format=foo % bar" "$(gpiosim_chip_name sim0)" 4 - gpio_mockup_set_pull 1 4 1 + gpiosim_set_pull sim0 4 pull-up sleep 0.2 coproc_tool_kill @@ -1030,11 +1100,11 @@ teardown() { } @test "gpiomon: custom format (unknown specifier)" { - gpio_mockup_probe 8 8 8 + gpiosim_chip sim0 num_lines=8 - coproc_run_tool gpiomon "--format=%x" "$(gpio_mockup_chip_name 1)" 4 + coproc_run_tool gpiomon "--format=%x" "$(gpiosim_chip_name sim0)" 4 - gpio_mockup_set_pull 1 4 1 + gpiosim_set_pull sim0 4 pull-up sleep 0.2 coproc_tool_kill -- 2.30.1