59586e5a26
machine_restart, machine_halt and machine_power_off are machine specific hooks deep into the reboot logic, that modules have no business messing with. Usually code should be calling kernel_restart, kernel_halt, kernel_power_off, or emergency_restart. So don't export machine_restart, machine_halt, and machine_power_off so we can catch buggy users. Signed-off-by: Eric W. Biederman <ebiederm@xmission.com> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
48 lines
877 B
C
48 lines
877 B
C
#include <linux/module.h>
|
|
#include <linux/smp.h>
|
|
#include <linux/delay.h>
|
|
#include <linux/platform.h>
|
|
|
|
#include <asm/io.h>
|
|
#include "piix4.h"
|
|
|
|
void (*pm_power_off)(void);
|
|
EXPORT_SYMBOL(pm_power_off);
|
|
|
|
void machine_restart(char * __unused)
|
|
{
|
|
#ifdef CONFIG_SMP
|
|
smp_send_stop();
|
|
#endif
|
|
|
|
/*
|
|
* Visual Workstations restart after this
|
|
* register is poked on the PIIX4
|
|
*/
|
|
outb(PIIX4_RESET_VAL, PIIX4_RESET_PORT);
|
|
}
|
|
|
|
void machine_power_off(void)
|
|
{
|
|
unsigned short pm_status;
|
|
extern unsigned int pci_bus0;
|
|
|
|
while ((pm_status = inw(PMSTS_PORT)) & 0x100)
|
|
outw(pm_status, PMSTS_PORT);
|
|
|
|
outw(PM_SUSPEND_ENABLE, PMCNTRL_PORT);
|
|
|
|
mdelay(10);
|
|
|
|
#define PCI_CONF1_ADDRESS(bus, devfn, reg) \
|
|
(0x80000000 | (bus << 16) | (devfn << 8) | (reg & ~3))
|
|
|
|
outl(PCI_CONF1_ADDRESS(pci_bus0, SPECIAL_DEV, SPECIAL_REG), 0xCF8);
|
|
outl(PIIX_SPECIAL_STOP, 0xCFC);
|
|
}
|
|
|
|
void machine_halt(void)
|
|
{
|
|
}
|
|
|