From 6d6db65d8294a12265f9ac75dee31d98767946c9 Mon Sep 17 00:00:00 2001 From: David Woodhouse Date: Mon, 13 Feb 2017 13:38:33 +0000 Subject: x86: Enable DIAG LED on Geos Based on a patch from Chris Blake , except let's do it by using the LED configuration instead of hard-coding it for each board type. And try using /bin/board_detect to do the default behaviour, on the first boot where the config hasn't yet been generated. Signed-off-by: David Woodhouse --- target/linux/x86/base-files/etc/diag.sh | 78 +++++++++++++++++++++++++++++++++ 1 file changed, 78 insertions(+) create mode 100644 target/linux/x86/base-files/etc/diag.sh (limited to 'target/linux/x86/base-files/etc/diag.sh') diff --git a/target/linux/x86/base-files/etc/diag.sh b/target/linux/x86/base-files/etc/diag.sh new file mode 100644 index 0000000000..3af4b23583 --- /dev/null +++ b/target/linux/x86/base-files/etc/diag.sh @@ -0,0 +1,78 @@ +#!/bin/sh +# +# Copyright © 2017 OpenWrt.org +# + +. /lib/functions.sh +. /lib/functions/leds.sh +. /usr/share/libubox/jshn.sh + +preinit_match_diag_led() { + local CFG keys key cfg name sysfs default + + CFG=/etc/board.json + if [ ! -s $CFG ]; then + CFG=/tmp/board.json + [ -s /tmp/sysinfo/model ] || return + /bin/board_detect $CFG || return + fi + + json_init + json_load "$(cat $CFG)" + json_get_keys keys led + json_select led + for key in $keys; do + json_select "$key" + json_get_vars name sysfs default + + if [ "$name" = "DIAG" -a "$default" = "1" ]; then + status_led="$sysfs" + return + fi + json_select .. + done +} + +match_diag_led() { + local name + local default + local sysfs + config_get name "$1" name + config_get default "$1" default + config_get sysfs "$1" sysfs + + if [ "$name" = "DIAG" -a "$default" = "1" ]; then + status_led="$sysfs" + fi +} + +get_status_led() { + if [ -s /etc/config/system ]; then + config_load system + config_foreach match_diag_led led + else + preinit_match_diag_led + fi +} + +set_state() { + get_status_led + + case "$1" in + preinit) + status_led_blink_preinit + ;; + + failsafe) + status_led_blink_failsafe + ;; + + preinit_regular) + status_led_blink_preinit_regular + ;; + + done) + status_led_on + ;; + esac +} -- cgit v1.2.3