From 01f9aa5e54cf55ecca1b35185373835e61f10615 Mon Sep 17 00:00:00 2001 From: Julius Werner Date: Thu, 18 May 2017 16:03:26 -0700 Subject: 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 Reviewed-on: https://review.coreboot.org/19789 Reviewed-by: Aaron Durbin Tested-by: build bot (Jenkins) Reviewed-by: Furquan Shaikh --- src/southbridge/intel/bd82x6x/reset.c | 4 ++-- src/southbridge/intel/fsp_bd82x6x/reset.c | 4 ++-- src/southbridge/intel/fsp_i89xx/reset.c | 4 ++-- src/southbridge/intel/fsp_rangeley/reset.c | 4 ++-- src/southbridge/intel/i3100/reset.c | 2 +- src/southbridge/intel/i82801ax/reset.c | 2 +- src/southbridge/intel/i82801bx/reset.c | 2 +- src/southbridge/intel/i82801dx/reset.c | 2 +- src/southbridge/intel/i82801gx/reset.c | 6 +++--- src/southbridge/intel/lynxpoint/reset.c | 4 ++-- 10 files changed, 17 insertions(+), 17 deletions(-) (limited to 'src/southbridge/intel') diff --git a/src/southbridge/intel/bd82x6x/reset.c b/src/southbridge/intel/bd82x6x/reset.c index 804fb8137c..7faadb62df 100644 --- a/src/southbridge/intel/bd82x6x/reset.c +++ b/src/southbridge/intel/bd82x6x/reset.c @@ -17,12 +17,12 @@ #include #include -void soft_reset(void) +void do_soft_reset(void) { outb(0x04, 0xcf9); } -void hard_reset(void) +void do_hard_reset(void) { outb(0x06, 0xcf9); } diff --git a/src/southbridge/intel/fsp_bd82x6x/reset.c b/src/southbridge/intel/fsp_bd82x6x/reset.c index a2e8236dc5..b1468da64b 100644 --- a/src/southbridge/intel/fsp_bd82x6x/reset.c +++ b/src/southbridge/intel/fsp_bd82x6x/reset.c @@ -18,12 +18,12 @@ #include #include -void soft_reset(void) +void do_soft_reset(void) { outb(0x04, 0xcf9); } -void hard_reset(void) +void do_hard_reset(void) { outb(0x06, 0xcf9); } diff --git a/src/southbridge/intel/fsp_i89xx/reset.c b/src/southbridge/intel/fsp_i89xx/reset.c index a2e8236dc5..b1468da64b 100644 --- a/src/southbridge/intel/fsp_i89xx/reset.c +++ b/src/southbridge/intel/fsp_i89xx/reset.c @@ -18,12 +18,12 @@ #include #include -void soft_reset(void) +void do_soft_reset(void) { outb(0x04, 0xcf9); } -void hard_reset(void) +void do_hard_reset(void) { outb(0x06, 0xcf9); } diff --git a/src/southbridge/intel/fsp_rangeley/reset.c b/src/southbridge/intel/fsp_rangeley/reset.c index 298dbce4b0..10b82ff4e5 100644 --- a/src/southbridge/intel/fsp_rangeley/reset.c +++ b/src/southbridge/intel/fsp_rangeley/reset.c @@ -18,12 +18,12 @@ #include #include -void soft_reset(void) +void do_soft_reset(void) { hard_reset(); } -void hard_reset(void) +void do_hard_reset(void) { outb(0x02, 0xcf9); outb(0x06, 0xcf9); diff --git a/src/southbridge/intel/i3100/reset.c b/src/southbridge/intel/i3100/reset.c index 595bed3bac..af000e3e66 100644 --- a/src/southbridge/intel/i3100/reset.c +++ b/src/southbridge/intel/i3100/reset.c @@ -17,7 +17,7 @@ #include #include -void hard_reset(void) +void do_hard_reset(void) { outb(0x06, 0xcf9); } diff --git a/src/southbridge/intel/i82801ax/reset.c b/src/southbridge/intel/i82801ax/reset.c index 74be595e99..25254ca929 100644 --- a/src/southbridge/intel/i82801ax/reset.c +++ b/src/southbridge/intel/i82801ax/reset.c @@ -17,7 +17,7 @@ #include #include -void hard_reset(void) +void do_hard_reset(void) { /* Try rebooting through port 0xcf9. */ outb((1 << 2) | (1 << 1), 0xcf9); diff --git a/src/southbridge/intel/i82801bx/reset.c b/src/southbridge/intel/i82801bx/reset.c index 4a82b35863..41b99c704d 100644 --- a/src/southbridge/intel/i82801bx/reset.c +++ b/src/southbridge/intel/i82801bx/reset.c @@ -17,7 +17,7 @@ #include #include -void hard_reset(void) +void do_hard_reset(void) { /* Try rebooting through port 0xcf9. */ outb((1 << 2) | (1 << 1), 0xcf9); diff --git a/src/southbridge/intel/i82801dx/reset.c b/src/southbridge/intel/i82801dx/reset.c index a6db91c7ba..1839ad6f9a 100644 --- a/src/southbridge/intel/i82801dx/reset.c +++ b/src/southbridge/intel/i82801dx/reset.c @@ -16,7 +16,7 @@ #include #include -void hard_reset(void) +void do_hard_reset(void) { /* Try rebooting through port 0xcf9 */ outb((0 << 3) | (1 << 2) | (1 << 1), 0xcf9); diff --git a/src/southbridge/intel/i82801gx/reset.c b/src/southbridge/intel/i82801gx/reset.c index 97b82251f0..e18f3e8ddc 100644 --- a/src/southbridge/intel/i82801gx/reset.c +++ b/src/southbridge/intel/i82801gx/reset.c @@ -17,20 +17,20 @@ #include #include -void soft_reset(void) +void do_soft_reset(void) { outb(0x04, 0xcf9); } #if 0 -void hard_reset(void) +void do_hard_reset(void) { /* Try rebooting through port 0xcf9. */ outb((1 << 2) | (1 << 1), 0xcf9); } #endif -void hard_reset(void) +void do_hard_reset(void) { outb(0x02, 0xcf9); outb(0x06, 0xcf9); diff --git a/src/southbridge/intel/lynxpoint/reset.c b/src/southbridge/intel/lynxpoint/reset.c index 804fb8137c..7faadb62df 100644 --- a/src/southbridge/intel/lynxpoint/reset.c +++ b/src/southbridge/intel/lynxpoint/reset.c @@ -17,12 +17,12 @@ #include #include -void soft_reset(void) +void do_soft_reset(void) { outb(0x04, 0xcf9); } -void hard_reset(void) +void do_hard_reset(void) { outb(0x06, 0xcf9); } -- cgit v1.2.3