| /* SPDX-License-Identifier: GPL-2.0-only */ |
| |
| #include <arch/io.h> |
| #include <arch/cache.h> |
| #include <cf9_reset.h> |
| #include <console/console.h> |
| #include <halt.h> |
| |
| /* |
| * A system reset in terms of the CF9 register asserts the INIT# |
| * signal to reset the CPU along the PLTRST# signal to reset other |
| * board components. It is usually the hardest reset type that |
| * does not power cycle the board. Thus, it could be called a |
| * "warm reset". |
| */ |
| void do_system_reset(void) |
| { |
| dcache_clean_all(); |
| outb(SYS_RST, RST_CNT); |
| outb(RST_CPU | SYS_RST, RST_CNT); |
| } |
| |
| /* |
| * A full reset in terms of the CF9 register triggers a power cycle |
| * (i.e. S0 -> S5 -> S0 transition). Thus, it could be called a |
| * "cold reset". |
| * Note: Not all x86 implementations comply with this definition, |
| * some may require additional configuration to power cycle. |
| */ |
| void do_full_reset(void) |
| { |
| dcache_clean_all(); |
| outb(FULL_RST | SYS_RST, RST_CNT); |
| outb(FULL_RST | RST_CPU | SYS_RST, RST_CNT); |
| } |
| |
| void system_reset(void) |
| { |
| printk(BIOS_INFO, "%s() called!\n", __func__); |
| cf9_reset_prepare(); |
| do_system_reset(); |
| halt(); |
| } |
| |
| void full_reset(void) |
| { |
| printk(BIOS_INFO, "%s() called!\n", __func__); |
| cf9_reset_prepare(); |
| do_full_reset(); |
| halt(); |
| } |