diff options
author | Brad Smith <brad@cvs.openbsd.org> | 2005-11-18 17:11:58 +0000 |
---|---|---|
committer | Brad Smith <brad@cvs.openbsd.org> | 2005-11-18 17:11:58 +0000 |
commit | 4e684501c9e0dd1a3a446a3b01e54aabedab487b (patch) | |
tree | acb4895af10946d3c5ccbb75e19d2cdd27b3776a /sys/arch/i386 | |
parent | 9fe5761cf3af8fa29166e171f553a20e61c17203 (diff) |
add some comments explaining the general CPU reset code and the AMD Geode
SC1100 specific reset code.
From NetBSD
ok mickey@
Diffstat (limited to 'sys/arch/i386')
-rw-r--r-- | sys/arch/i386/i386/machdep.c | 25 |
1 files changed, 21 insertions, 4 deletions
diff --git a/sys/arch/i386/i386/machdep.c b/sys/arch/i386/i386/machdep.c index f7c4f8196e9..6923d56d28f 100644 --- a/sys/arch/i386/i386/machdep.c +++ b/sys/arch/i386/i386/machdep.c @@ -1,4 +1,4 @@ -/* $OpenBSD: machdep.c,v 1.331 2005/11/13 17:24:31 martin Exp $ */ +/* $OpenBSD: machdep.c,v 1.332 2005/11/18 17:11:57 brad Exp $ */ /* $NetBSD: machdep.c,v 1.214 1996/11/10 03:16:17 thorpej Exp $ */ /*- @@ -1312,9 +1312,22 @@ void natsem6x86_cpureset(void); void natsem6x86_cpureset(void) { - /* reset control SC1100 (datasheet page 170) */ + /* + * Reset AMD Geode SC1100. + * + * 1) Write PCI Configuration Address Register (0xcf8) to + * select Function 0, Register 0x44: Bridge Configuration, + * GPIO and LPC Configuration Register Space, Reset + * Control Register. + * + * 2) Write 0xf to PCI Configuration Data Register (0xcfc) + * to reset IDE controller, IDE bus, and PCI bus, and + * to trigger a system-wide reset. + * + * See AMD Geode SC1100 Processor Data Book, Revision 2.0, + * sections 6.3.1, 6.3.2, and 6.4.1. + */ outl(0xCF8, 0x80009044UL); - /* system wide reset */ outb(0xCFC, 0x0F); } #endif @@ -3103,7 +3116,11 @@ cpu_reset() if (cpuresetfn) (*cpuresetfn)(); - /* Toggle the hardware reset line on the keyboard controller. */ + /* + * The keyboard controller has 4 random output pins, one of which is + * connected to the RESET pin on the CPU in many PCs. We tell the + * keyboard controller to pulse this line a couple of times. + */ outb(IO_KBD + KBCMDP, KBC_PULSE0); delay(100000); outb(IO_KBD + KBCMDP, KBC_PULSE0); |