summaryrefslogtreecommitdiff
path: root/include/asm-x86/mach-default/mach_reboot.h
blob: e23fd9fbebb3a5b024a9c8c2e155ea02ae51c8a9 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
/*
 *  arch/i386/mach-generic/mach_reboot.h
 *
 *  Machine specific reboot functions for generic.
 *  Split out from reboot.c by Osamu Tomita <tomita@cinet.co.jp>
 */
#ifndef _MACH_REBOOT_H
#define _MACH_REBOOT_H

static inline void kb_wait(void)
{
	int i;

	for (i = 0; i < 0x10000; i++)
		if ((inb_p(0x64) & 0x02) == 0)
			break;
}

static inline void mach_reboot(void)
{
	int i;

	/* old method, works on most machines */
	for (i = 0; i < 10; i++) {
		kb_wait();
		udelay(50);
		outb(0xfe, 0x64);	/* pulse reset low */
		udelay(50);
	}

	/* New method: sets the "System flag" which, when set, indicates
	 * successful completion of the keyboard controller self-test (Basic
	 * Assurance Test, BAT).  This is needed for some machines with no
	 * keyboard plugged in.  This read-modify-write sequence sets only the
	 * system flag
	 */
	for (i = 0; i < 10; i++) {
		int cmd;

		outb(0x20, 0x64);	/* read Controller Command Byte */
		udelay(50);
		kb_wait();
		udelay(50);
		cmd = inb(0x60);
		udelay(50);
		kb_wait();
		udelay(50);
		outb(0x60, 0x64);	/* write Controller Command Byte */
		udelay(50);
		kb_wait();
		udelay(50);
		outb(cmd | 0x04, 0x60);	/* set "System flag" */
		udelay(50);
		kb_wait();
		udelay(50);
		outb(0xfe, 0x64);	/* pulse reset low */
		udelay(50);
	}
}

#endif /* !_MACH_REBOOT_H */