diff options
-rw-r--r-- | recipes-connectivity/ppp/files/default | 8 | ||||
-rw-r--r-- | recipes-connectivity/ppp/files/init.patch | 34 | ||||
-rw-r--r-- | recipes-connectivity/ppp/files/poff.patch | 12 | ||||
-rw-r--r-- | recipes-connectivity/ppp/ppp_%.bbappend | 17 |
4 files changed, 71 insertions, 0 deletions
diff --git a/recipes-connectivity/ppp/files/default b/recipes-connectivity/ppp/files/default new file mode 100644 index 0000000..6cc92df --- /dev/null +++ b/recipes-connectivity/ppp/files/default @@ -0,0 +1,8 @@ +# Check to see if the SIM is registered before using ppp. +# Need this if using a cellular connection. +CHECKREGISTRATION=1 +# Note that boot will not complete until +# ppp completes, and the PPPTIMEOUT is the +# maximum wait time for the SIM to register +# for cellular PPP. +PPPTIMEOUT=60 diff --git a/recipes-connectivity/ppp/files/init.patch b/recipes-connectivity/ppp/files/init.patch new file mode 100644 index 0000000..e74e981 --- /dev/null +++ b/recipes-connectivity/ppp/files/init.patch @@ -0,0 +1,34 @@ +diff -Naru old/init new/init +--- old/init 2017-09-05 19:07:19.810885424 -0500 ++++ new/init 2017-09-05 19:08:05.106884083 -0500 +@@ -8,11 +8,29 @@ + + test -x /usr/sbin/pppd -a -f /etc/ppp/ppp_on_boot || exit 0 + if [ -x /etc/ppp/ppp_on_boot ]; then RUNFILE=1; fi +- ++: ${PPPTIMEOUT:=60} ++logger timeout is $PPPTIMEOUT ++[ -f /etc/default/ppp ] && . /etc/default/ppp + case "$1" in + start) ++ t0=($(cat /proc/uptime)) ++ if (( CHECKREGISTRATION == 1 )) ; then while : ; do ++ REG=$(/usr/bin/radio-query --netreg) ++ [[ $REG == "REGISTERED" ]] && break ++ t1=($(cat /proc/uptime)) ++ diff=$(awk "BEGIN{print int($t1-$t0)}") ++ logger -s "Modem not ready. Waited $diff of $PPPTIMEOUT seconds" ++ if ((diff > PPPTIMEOUT)) ; then ++ logger -s "Timed out waiting for modem registration" ++ exit 1 ++ fi ++ sleep 1 ++ done ; fi ++ ++ logger "Starting up PPP link: pppd" + echo -n "Starting up PPP link: pppd" + if [ "$RUNFILE" = "1" ]; then ++ logger "ppp_on_boot" + /etc/ppp/ppp_on_boot + else + pppd call provider diff --git a/recipes-connectivity/ppp/files/poff.patch b/recipes-connectivity/ppp/files/poff.patch new file mode 100644 index 0000000..2385886 --- /dev/null +++ b/recipes-connectivity/ppp/files/poff.patch @@ -0,0 +1,12 @@ +diff -Naru old/poff new/poff +--- old/poff 2017-09-05 19:07:11.630885666 -0500 ++++ new/poff 2017-09-05 19:08:09.586883950 -0500 +@@ -1,7 +1,7 @@ + #!/bin/sh + + # Lets see how many pppds are running.... +-set -- `cat /var/run/ppp*.pid 2>/dev/null` ++set -- `cat /var/run/ppp[0-9]*.pid 2>/dev/null` + + case $# in + 0) # pppd only creates a pid file once ppp is up, so let's try killing pppd diff --git a/recipes-connectivity/ppp/ppp_%.bbappend b/recipes-connectivity/ppp/ppp_%.bbappend new file mode 100644 index 0000000..54b2de1 --- /dev/null +++ b/recipes-connectivity/ppp/ppp_%.bbappend @@ -0,0 +1,17 @@ +SRC_URI_append = "\ + file://init.patch;patchdir=.. \ + file://poff.patch;patchdir=.. \ + file://default" + +PR = "r9" + +FILESEXTRAPATHS_prepend := "${THISDIR}/files:" + +FILES_${PN} += "/etc/default/ppp" + +CONFFILES_${PN} += "${sysconfdir}/default/ppp" + +do_install_append() { + install -d -m 0755 ${D}/${sysconfdir}/default/ + install -m 644 ${WORKDIR}/default ${D}/${sysconfdir}/default/ppp +} |