diff -r 4950117e9c11 -r ec6e1bf8d53b shell/gpio.sh
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/shell/gpio.sh Sat Nov 05 17:38:05 2016 +0100
@@ -0,0 +1,108 @@
+#!/bin/bash
+
+# GPIO.sh
+# Copyright © 2016 František Kučera (frantovo.cz)
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see .
+
+# GPIO.sh is a set of functions for controlling GPIO pins of Raspberry Pi or similar computer
+
+_gpio_valid_port() {
+ case $1 in 0|1|4|7|8|9|10|11|14|15|17|18|21|22|23|24|25)
+ return 0;;
+ *)
+ return 1;;
+ esac
+}
+
+# export -f _gpio_valid_port
+# seq 0 30 | xargs -n1 bash -c 'printf "%4s" "$0: "; _gpio_valid_port $0 ; if [ $? -eq 0 ]; then echo "valid port number"; else echo; fi'
+
+
+_gpio_log_error() {
+ # TODO: $(date --rfc-3339=seconds) or ● ?
+ echo -e "\e[1;31m$1\e[0m"; > /dev/stderr;
+}
+
+_gpio_log_warning() {
+ echo -e "\e[2;33m$1 \e[0m"; > /dev/stderr;
+}
+
+
+# open (export) the port and set its direction
+# parameters:
+# port number
+# direction: in/out
+gpio_open() {
+ local port="$1";
+ local direction="$2";
+ if [ $# -ne 2 ] || [[ "$direction" != @("in"|"out") ]]; then _gpio_log_error "usage: ${FUNCNAME[0]} "; return 1; fi
+ if ! _gpio_valid_port "$port"; then _gpio_log_error "invalid port number: $port"; return 1; fi;
+
+ if [ -d "/sys/class/gpio/gpio$port" ]; then
+ _gpio_log_warning "port $port is already exported → will just set direction: $direction";
+ else
+ echo "$port" > "/sys/class/gpio/export" || return 1;
+ fi;
+
+ echo "$direction" > "/sys/class/gpio/gpio$1/direction";
+}
+
+
+# close (unexport) the port and set its direction
+# parameters:
+# port number
+gpio_close() {
+ local port="$1";
+ if [ $# -ne 1 ]; then _gpio_log_error "usage: ${FUNCNAME[0]} "; return 1; fi
+ if ! _gpio_valid_port "$port"; then _gpio_log_error "invalid port number: $port"; return 1; fi;
+
+ if [ -d "/sys/class/gpio/gpio$port" ]; then
+ echo "$port" > "/sys/class/gpio/unexport";
+ else
+ _gpio_log_error "port $port is not open";
+ return 1;
+ fi;
+}
+
+# reads value of given port
+# parameters:
+# port number
+gpio_read() {
+ local port="$1";
+ if [ $# -ne 1 ]; then _gpio_log_error "usage: ${FUNCNAME[0]} "; return 1; fi
+ if ! _gpio_valid_port "$port"; then _gpio_log_error "invalid port number: $port"; return 1; fi;
+
+ if ! cat "/sys/class/gpio/gpio$port/value"; then
+ _gpio_log_error "unable to read value of port $port";
+ return 1;
+ fi
+}
+
+# writes the value to given port
+# parameters:
+# port number
+# value: 0/1
+gpio_write() {
+ local port="$1";
+ local value="$2";
+ if [ $# -ne 2 ] || [[ "$value" != @("0"|"1") ]]; then _gpio_log_error "usage: ${FUNCNAME[0]} <0|1>"; return 1; fi
+ if ! _gpio_valid_port "$port"; then _gpio_log_error "invalid port number: $port"; return 1; fi;
+
+ if ! echo "$value" > "/sys/class/gpio/gpio$port/value"; then
+ _gpio_log_error "unable to write value $value to port $port";
+ return 1;
+ fi
+}
+