diff options
author | Sascha Hauer <s.hauer@pengutronix.de> | 2010-07-03 10:26:21 +0200 |
---|---|---|
committer | Sascha Hauer <s.hauer@pengutronix.de> | 2010-07-03 10:26:21 +0200 |
commit | 6d1d9e8d8b4be5645d3613522093cdcaddad5bff (patch) | |
tree | f0147f6620fc6bce6b403f9e9c006e629ae6796f /scripts/netconsole | |
parent | 0db4be97f2ebd6cedad9c113ca49667c0b1e8d75 (diff) | |
parent | 7f5644fad10f8f7a86742dd30d2812261cd0a623 (diff) | |
download | barebox-6d1d9e8d8b4be5645d3613522093cdcaddad5bff.tar.gz barebox-6d1d9e8d8b4be5645d3613522093cdcaddad5bff.tar.xz |
Merge branch 'next'
Diffstat (limited to 'scripts/netconsole')
-rwxr-xr-x | scripts/netconsole | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/scripts/netconsole b/scripts/netconsole new file mode 100755 index 0000000000..c8109bb095 --- /dev/null +++ b/scripts/netconsole @@ -0,0 +1,59 @@ +#!/bin/sh + +usage() { + ( + echo "Usage: $0 <board IP> [board port]" + echo "" + echo "If port is not specified, '6666' will be used" + [ -z "$*" ] && exit 0 + echo "" + echo "ERROR: $*" + exit 1 + ) 1>&2 + exit $? +} + +while [ -n "$1" ] ; do + case $1 in + -h|--help) usage;; + --) break;; + -*) usage "Invalid option $1";; + *) break;; + esac + shift +done + +ip=$1 +port=${2:-6666} + +if [ -z "${ip}" ] || [ -n "$3" ] ; then + usage "Invalid number of arguments" +fi + +for nc in netcat nc ; do + type ${nc} >/dev/null 2>&1 && break +done + +trap "stty icanon echo intr ^C" 0 2 3 5 10 13 15 +echo "NOTE: the interrupt signal (normally ^C) has been remapped to ^T" + +stty -icanon -echo intr ^T +( +if type ncb 2>/dev/null ; then + # see if ncb is in $PATH + exec ncb ${port} + +elif [ -x ${0%/*}/ncb ] ; then + # maybe it's in the same dir as the netconsole script + exec ${0%/*}/ncb ${port} + +else + # blah, just use regular netcat + while ${nc} -u -l -p ${port} < /dev/null ; do + : + done +fi +) & +pid=$! +${nc} -u ${ip} ${port} +kill ${pid} 2>/dev/null |