diff options
author | Julius Werner <jwerner@chromium.org> | 2017-05-18 16:03:26 -0700 |
---|---|---|
committer | Julius Werner <jwerner@chromium.org> | 2017-06-13 20:53:09 +0200 |
commit | 01f9aa5e54cf55ecca1b35185373835e61f10615 (patch) | |
tree | 8cd1ecb517bd948ac2dc2616de789a84a999a911 /src/lib | |
parent | d9762f70acc1cc2db5b3905756f5f5a995b9a21a (diff) |
Consolidate reset API, add generic reset_prepare mechanism
There are many good reasons why we may want to run some sort of generic
callback before we're executing a reset. Unfortunateley, that is really
hard right now: code that wants to reset simply calls the hard_reset()
function (or one of its ill-differentiated cousins) which is directly
implemented by a myriad of different mainboards, northbridges, SoCs,
etc. More recent x86 SoCs have tried to solve the problem in their own
little corner of soc/intel/common, but it's really something that would
benefit all of coreboot.
This patch expands the concept onto all boards: hard_reset() and friends
get implemented in a generic location where they can run hooks before
calling the platform-specific implementation that is now called
do_hard_reset(). The existing Intel reset_prepare() gets generalized as
soc_reset_prepare() (and other hooks for arch, mainboard, etc. can now
easily be added later if necessary). We will also use this central point
to ensure all platforms flush their cache before reset, which is
generally useful for all cases where we're trying to persist information
in RAM across reboots (like the new persistent CBMEM console does).
Also remove cpu_reset() completely since it's not used anywhere and
doesn't seem very useful compared to the others.
Change-Id: I41b89ce4a923102f0748922496e1dd9bce8a610f
Signed-off-by: Julius Werner <jwerner@chromium.org>
Reviewed-on: https://review.coreboot.org/19789
Reviewed-by: Aaron Durbin <adurbin@chromium.org>
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Furquan Shaikh <furquan@google.com>
Diffstat (limited to 'src/lib')
-rw-r--r-- | src/lib/Makefile.inc | 7 | ||||
-rw-r--r-- | src/lib/reset.c | 59 |
2 files changed, 66 insertions, 0 deletions
diff --git a/src/lib/Makefile.inc b/src/lib/Makefile.inc index c4d4f6ab40..5079bbfea5 100644 --- a/src/lib/Makefile.inc +++ b/src/lib/Makefile.inc @@ -223,6 +223,13 @@ romstage-y += halt.c ramstage-y += halt.c smm-y += halt.c +bootblock-y += reset.c +verstage-y += reset.c +romstage-y += reset.c +postcar-y += reset.c +ramstage-y += reset.c +smm-y += reset.c + postcar-y += bootmode.c postcar-y += boot_device.c postcar-y += cbfs.c diff --git a/src/lib/reset.c b/src/lib/reset.c new file mode 100644 index 0000000000..703118a6f5 --- /dev/null +++ b/src/lib/reset.c @@ -0,0 +1,59 @@ +/* + * This file is part of the coreboot project. + * + * Copyright 2017 Google, Inc. + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; version 2 of the License. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + */ + +#include <arch/cache.h> +#include <console/console.h> +#include <halt.h> +#include <reset.h> + +__attribute__((noreturn)) static void __hard_reset(void) { + if (IS_ENABLED(CONFIG_HAVE_HARD_RESET)) + do_hard_reset(); + else + printk(BIOS_CRIT, "No hard_reset implementation, hanging...\n"); + halt(); +} + +/* Not all platforms implement all reset types. Fall back to hard_reset. */ +__attribute__((weak)) void do_global_reset(void) { __hard_reset(); } +__attribute__((weak)) void do_soft_reset(void) { __hard_reset(); } + +__attribute__((weak)) void soc_reset_prepare(enum reset_type rt) { /* no-op */ } + +void global_reset(void) +{ + printk(BIOS_INFO, "%s() called!\n", __func__); + soc_reset_prepare(GLOBAL_RESET); + dcache_clean_all(); + do_global_reset(); + halt(); +} + +void hard_reset(void) +{ + printk(BIOS_INFO, "%s() called!\n", __func__); + soc_reset_prepare(HARD_RESET); + dcache_clean_all(); + __hard_reset(); +} + +void soft_reset(void) +{ + printk(BIOS_INFO, "%s() called!\n", __func__); + soc_reset_prepare(SOFT_RESET); + dcache_clean_all(); + do_soft_reset(); + halt(); +} |