Loading arch/mips/sgi-ip22/ip22-reset.c +25 −27 Original line number Diff line number Diff line Loading @@ -3,8 +3,9 @@ * License. See the file "COPYING" in the main directory of this archive * for more details. * * Copyright (C) 1997, 1998, 2001, 2003 by Ralf Baechle * Copyright (C) 1997, 1998, 2001, 03, 05 by Ralf Baechle */ #include <linux/linkage.h> #include <linux/init.h> #include <linux/ds1286.h> #include <linux/module.h> Loading Loading @@ -41,28 +42,10 @@ static struct timer_list power_timer, blink_timer, debounce_timer, volume_timer; #define MACHINE_PANICED 1 #define MACHINE_SHUTTING_DOWN 2 static int machine_state = 0; static void sgi_machine_restart(char *command) __attribute__((noreturn)); static void sgi_machine_halt(void) __attribute__((noreturn)); static void sgi_machine_power_off(void) __attribute__((noreturn)); static int machine_state; static void sgi_machine_restart(char *command) { if (machine_state & MACHINE_SHUTTING_DOWN) sgi_machine_power_off(); sgimc->cpuctrl0 |= SGIMC_CCTRL0_SYSINIT; while (1); } static void sgi_machine_halt(void) { if (machine_state & MACHINE_SHUTTING_DOWN) sgi_machine_power_off(); ArcEnterInteractiveMode(); } static void sgi_machine_power_off(void) static void ATTRIB_NORET sgi_machine_power_off(void) { unsigned int tmp; Loading @@ -84,6 +67,21 @@ static void sgi_machine_power_off(void) } } static void ATTRIB_NORET sgi_machine_restart(char *command) { if (machine_state & MACHINE_SHUTTING_DOWN) sgi_machine_power_off(); sgimc->cpuctrl0 |= SGIMC_CCTRL0_SYSINIT; while (1); } static void ATTRIB_NORET sgi_machine_halt(void) { if (machine_state & MACHINE_SHUTTING_DOWN) sgi_machine_power_off(); ArcEnterInteractiveMode(); } static void power_timeout(unsigned long data) { sgi_machine_power_off(); Loading @@ -103,7 +101,7 @@ static void debounce(unsigned long data) del_timer(&debounce_timer); if (sgint->istat1 & SGINT_ISTAT1_PWR) { /* Interrupt still being sent. */ debounce_timer.expires = jiffies + 5; /* 0.05s */ debounce_timer.expires = jiffies + (HZ / 20); /* 0.05s */ add_timer(&debounce_timer); sgioc->panel = SGIOC_PANEL_POWERON | SGIOC_PANEL_POWERINTR | Loading Loading @@ -151,7 +149,7 @@ static inline void volume_up_button(unsigned long data) indy_volume_button(1); if (sgint->istat1 & SGINT_ISTAT1_PWR) { volume_timer.expires = jiffies + 1; volume_timer.expires = jiffies + (HZ / 100); add_timer(&volume_timer); } } Loading @@ -164,7 +162,7 @@ static inline void volume_down_button(unsigned long data) indy_volume_button(-1); if (sgint->istat1 & SGINT_ISTAT1_PWR) { volume_timer.expires = jiffies + 1; volume_timer.expires = jiffies + (HZ / 100); add_timer(&volume_timer); } } Loading Loading @@ -199,14 +197,14 @@ static irqreturn_t panel_int(int irq, void *dev_id, struct pt_regs *regs) if (!(buttons & SGIOC_PANEL_VOLUPINTR)) { init_timer(&volume_timer); volume_timer.function = volume_up_button; volume_timer.expires = jiffies + 1; volume_timer.expires = jiffies + (HZ / 100); add_timer(&volume_timer); } /* Volume down button was pressed */ if (!(buttons & SGIOC_PANEL_VOLDNINTR)) { init_timer(&volume_timer); volume_timer.function = volume_down_button; volume_timer.expires = jiffies + 1; volume_timer.expires = jiffies + (HZ / 100); add_timer(&volume_timer); } Loading Loading
arch/mips/sgi-ip22/ip22-reset.c +25 −27 Original line number Diff line number Diff line Loading @@ -3,8 +3,9 @@ * License. See the file "COPYING" in the main directory of this archive * for more details. * * Copyright (C) 1997, 1998, 2001, 2003 by Ralf Baechle * Copyright (C) 1997, 1998, 2001, 03, 05 by Ralf Baechle */ #include <linux/linkage.h> #include <linux/init.h> #include <linux/ds1286.h> #include <linux/module.h> Loading Loading @@ -41,28 +42,10 @@ static struct timer_list power_timer, blink_timer, debounce_timer, volume_timer; #define MACHINE_PANICED 1 #define MACHINE_SHUTTING_DOWN 2 static int machine_state = 0; static void sgi_machine_restart(char *command) __attribute__((noreturn)); static void sgi_machine_halt(void) __attribute__((noreturn)); static void sgi_machine_power_off(void) __attribute__((noreturn)); static int machine_state; static void sgi_machine_restart(char *command) { if (machine_state & MACHINE_SHUTTING_DOWN) sgi_machine_power_off(); sgimc->cpuctrl0 |= SGIMC_CCTRL0_SYSINIT; while (1); } static void sgi_machine_halt(void) { if (machine_state & MACHINE_SHUTTING_DOWN) sgi_machine_power_off(); ArcEnterInteractiveMode(); } static void sgi_machine_power_off(void) static void ATTRIB_NORET sgi_machine_power_off(void) { unsigned int tmp; Loading @@ -84,6 +67,21 @@ static void sgi_machine_power_off(void) } } static void ATTRIB_NORET sgi_machine_restart(char *command) { if (machine_state & MACHINE_SHUTTING_DOWN) sgi_machine_power_off(); sgimc->cpuctrl0 |= SGIMC_CCTRL0_SYSINIT; while (1); } static void ATTRIB_NORET sgi_machine_halt(void) { if (machine_state & MACHINE_SHUTTING_DOWN) sgi_machine_power_off(); ArcEnterInteractiveMode(); } static void power_timeout(unsigned long data) { sgi_machine_power_off(); Loading @@ -103,7 +101,7 @@ static void debounce(unsigned long data) del_timer(&debounce_timer); if (sgint->istat1 & SGINT_ISTAT1_PWR) { /* Interrupt still being sent. */ debounce_timer.expires = jiffies + 5; /* 0.05s */ debounce_timer.expires = jiffies + (HZ / 20); /* 0.05s */ add_timer(&debounce_timer); sgioc->panel = SGIOC_PANEL_POWERON | SGIOC_PANEL_POWERINTR | Loading Loading @@ -151,7 +149,7 @@ static inline void volume_up_button(unsigned long data) indy_volume_button(1); if (sgint->istat1 & SGINT_ISTAT1_PWR) { volume_timer.expires = jiffies + 1; volume_timer.expires = jiffies + (HZ / 100); add_timer(&volume_timer); } } Loading @@ -164,7 +162,7 @@ static inline void volume_down_button(unsigned long data) indy_volume_button(-1); if (sgint->istat1 & SGINT_ISTAT1_PWR) { volume_timer.expires = jiffies + 1; volume_timer.expires = jiffies + (HZ / 100); add_timer(&volume_timer); } } Loading Loading @@ -199,14 +197,14 @@ static irqreturn_t panel_int(int irq, void *dev_id, struct pt_regs *regs) if (!(buttons & SGIOC_PANEL_VOLUPINTR)) { init_timer(&volume_timer); volume_timer.function = volume_up_button; volume_timer.expires = jiffies + 1; volume_timer.expires = jiffies + (HZ / 100); add_timer(&volume_timer); } /* Volume down button was pressed */ if (!(buttons & SGIOC_PANEL_VOLDNINTR)) { init_timer(&volume_timer); volume_timer.function = volume_down_button; volume_timer.expires = jiffies + 1; volume_timer.expires = jiffies + (HZ / 100); add_timer(&volume_timer); } Loading