blob: 3ca52b325c705b2c32475740f29e6140415377d2 (
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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
|
/*++
Copyright (c) 1991 Microsoft Corporation
Module Name:
jxreturn.c
Abstract:
This module implements the HAL return to firmware function.
Author:
David N. Cutler (davec) 21-Aug-1991
Revision History:
--*/
#include "halp.h"
#include "eisa.h"
VOID
HalReturnToFirmware(
IN FIRMWARE_REENTRY Routine
)
/*++
Routine Description:
This function returns control to the specified firmware routine.
In most cases it generates a soft reset by asserting the reset line
trough the keyboard controller.
The Keyboard controller is mapped using the same virtual address
and the same fixed entry as the DMA.
Arguments:
Routine - Supplies a value indicating which firmware routine to invoke.
Return Value:
Does not return.
--*/
{
KIRQL OldIrql;
//
// Disable Interrupts.
//
KeRaiseIrql(HIGH_LEVEL, &OldIrql);
//
// Case on the type of return.
//
switch (Routine) {
case HalHaltRoutine:
//
// Hang looping.
//
for (;;) {
}
case HalPowerDownRoutine:
case HalRestartRoutine:
case HalRebootRoutine:
case HalInteractiveModeRoutine:
if (HalpResetDisplayParameters != NULL) {
(HalpResetDisplayParameters)(80,25);
}
HalpResetX86DisplayAdapter();
ArcReboot();
for (;;) {
}
default:
KdPrint(("HalReturnToFirmware invalid argument\n"));
KeLowerIrql(OldIrql);
DbgBreakPoint();
}
}
|