oprava pri volani jako funkce
[mirrors/Programs.git] / bash / serial_loopback_test.sh
CommitLineData
4eb6c240 1#!/bin/sh
cab857a9 2#
4257d52f 3#Serial line tester v0.3
4eb6c240 4#(c) Tomas Mudrunka 2022-2024
cab857a9
TM
5#
6#Tested in: busybox ash, bash
55d43182 7
052685bd
TM
8function serial_loopback_test() {
9
c30e1c36
TM
10unset port_tx
11unset port_rx
4eb6c240
TM
12trylimit=0
13seconds=0
14baudrate=115200
15workaround_rs485=false
16
17while getopts ":t:r:b:l:s:w" OPT; do
18 #echo "$OPT ==> $OPTARG";
19 case $OPT in
20 t) port_tx=$OPTARG;;
21 r) port_rx=$OPTARG;;
22 b) baudrate=$OPTARG;;
23 l) trylimit=$OPTARG;;
24 s) seconds=$OPTARG;;
25 w) workaround_rs485=true;;
26
e10dcb9e
TM
27 '?') echo "Usage: $0 -t /dev/ttyTX [-r /dev/ttyRX] [-b 9600] [-l 10] [-s 10] [-w]" >&2; return 250;;
28 ':') echo "Missing option argument for -$OPTARG" >&2; return 251;;
29 * ) echo "Unimplemented option: -$OPT" >&2; return 252;;
4eb6c240
TM
30 esac
31done
32
33[ -z "$port_tx" ] && port_tx="$port_rx"
34[ -z "$port_rx" ] && port_rx="$port_tx"
e10dcb9e 35[ -z "$port_rx" ] && { echo Port not specified; return 253; }
55d43182 36
55d43182
TM
37
38testdata="${RANDOM}d82b2ae45432e7c80699852ab557b279c42180a379711aae85487bda0cc58602f65c0ab5af0d510d6ac1606c52f887f3332052f67c45212dbbf2730${RANDOM}"
39
4eb6c240
TM
40echo "Running $baudrate baud loopback test on $port_tx -> $port_rx"
41echo "Limiting to $trylimit iterations and $seconds seconds (0 = no limit)"
55d43182 42
4eb6c240
TM
43stty -F "$port_tx" raw -echo "$baudrate"
44stty -F "$port_rx" raw -echo "$baudrate"
55d43182
TM
45
46exec 5>"$port_tx"
47exec 6<"$port_rx"
48
4eb6c240
TM
49$workaround_rs485 && {
50 echo "Deasserting RTS on buggy RS485 drivers by writing to RX port"
51 echo>"$port_rx"
52 read -rst 1 -u 6
53}
54
55d43182 55errcnt=0
4eb6c240
TM
56trycnt=0
57datestart="$(date +%s)"
58dateend="$(($datestart+$seconds))"
55d43182
TM
59while true; do
60 echo "$testdata" >&5
61 unset line
62 read -rst 1 -u 6 line
63 #echo "LINE: $line"
4257d52f 64 [ "$line" != "$testdata" ] && errcnt=$((errcnt+1)) &&
55d43182 65 echo -e "$(date +'%D %T')\t$errcnt\tError receiving data $port_tx -> $port_rx"
4eb6c240
TM
66 trycnt=$((trycnt+1))
67 #echo "try $trycnt err $errcnt lim $trylimit"
68 [ $trylimit -gt 0 -a $trycnt -gt $trylimit ] && break
69 [ $seconds -gt 0 ] && [ $(date +%s) -gt $dateend ] && break
55d43182
TM
70done
71
72exec 5>&-
73exec 6<&-
4eb6c240
TM
74
75echo TRANSMITTED: $trycnt, ERRORS: $errcnt, SECONDS: $(($(date +%s)-$datestart))
e10dcb9e
TM
76[ "$errcnt" = "0" -a "$trycnt" -gt 0 ] && return 0
77return 255
052685bd
TM
78
79}
80
81serial_loopback_test "$@"
This page took 0.309109 seconds and 4 git commands to generate.