From 20eee0d6cb669abcaa9fba8710d47eba1e44c656 Mon Sep 17 00:00:00 2001 From: Daniel Golle Date: Sun, 17 Jul 2022 21:42:05 +0100 Subject: [PATCH] uboot-mediatek: mt7986: add generic reset button support Allow resetting environment to default values when defined button exists in device tree. Signed-off-by: Daniel Golle --- ...7986-generic-reset-button-ignore-env.patch | 40 +++++++++++++++++++ 1 file changed, 40 insertions(+) create mode 100644 package/boot/uboot-mediatek/patches/303-mt7986-generic-reset-button-ignore-env.patch diff --git a/package/boot/uboot-mediatek/patches/303-mt7986-generic-reset-button-ignore-env.patch b/package/boot/uboot-mediatek/patches/303-mt7986-generic-reset-button-ignore-env.patch new file mode 100644 index 000000000000..5011e7425799 --- /dev/null +++ b/package/boot/uboot-mediatek/patches/303-mt7986-generic-reset-button-ignore-env.patch @@ -0,0 +1,40 @@ +--- a/board/mediatek/mt7986/mt7986_rfb.c ++++ b/board/mediatek/mt7986/mt7986_rfb.c +@@ -6,9 +6,16 @@ + + #include + #include ++#include ++#include + #include + #include + #include ++#include ++ ++#ifndef CONFIG_RESET_BUTTON_LABEL ++#define CONFIG_RESET_BUTTON_LABEL "reset" ++#endif + + #include + #include +@@ -25,7 +32,19 @@ int board_init(void) + + int board_late_init(void) + { +- gd->env_valid = 1; //to load environment variable from persistent store ++ struct udevice *dev; ++ ++ gd->env_valid = ENV_VALID; ++ if (!button_get_by_label(CONFIG_RESET_BUTTON_LABEL, &dev)) { ++ puts("reset button found\n"); ++#ifdef CONFIG_RESET_BUTTON_SETTLE_DELAY ++ mdelay(CONFIG_RESET_BUTTON_SETTLE_DELAY); ++#endif ++ if (button_get_state(dev) == BUTTON_ON) { ++ puts("button pushed, resetting environment\n"); ++ gd->env_valid = ENV_INVALID; ++ } ++ } + env_relocate(); + return 0; + } -- 2.30.2