This repository has been archived by the owner on Jul 6, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 2
/
AppleI386CPU.cpp
96 lines (76 loc) · 2.86 KB
/
AppleI386CPU.cpp
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
90
91
92
93
94
95
96
/*
* Portions Copyright (c) 1999-2003 Apple Computer, Inc. All Rights
* Reserved.
*
* This file contains Original Code and/or Modifications of Original Code
* as defined in and that are subject to the Apple Public Source License
* Version 2.0 (the 'License'). You may not use this file except in
* compliance with the License. Please obtain a copy of the License at
* http://www.opensource.apple.com/apsl/ and read it before using this
* file.
*
* The Original Code and all software distributed under the License are
* distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
* EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
* INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
* Please see the License for the specific language governing rights and
* limitations under the License.
*
* This file was modified by William Kent in 2017 to support the PureDarwin
* project. This notice is included in support of clause 2.2(b) of the License.
*/
#include "AppleI386CPU.h"
#undef super
#define super IOCPU
OSDefineMetaClassAndStructors(AppleI386CPU, IOCPU);
IOService *AppleI386CPU::probe(IOService *provider, SInt32 *score) {
return this;
}
bool AppleI386CPU::startCommon() {
if (startCommonCompleted) return true;
cpuIC = new AppleI386CPUInterruptController;
if (cpuIC == 0) return false;
if (cpuIC->initCPUInterruptController(1) != kIOReturnSuccess) return false;
cpuIC->attach(this);
cpuIC->registerCPUInterruptController();
setCPUState(kIOCPUStateUninitalized);
initCPU(true);
registerService();
startCommonCompleted = true;
return true;
}
bool AppleI386CPU::start(IOService *provider) {
if (!super::start(provider)) return false;
return startCommon();
}
void AppleI386CPU::initCPU(bool boot) {
cpuIC->enableCPUInterrupt(this);
setCPUState(kIOCPUStateRunning);
}
void AppleI386CPU::quiesceCPU() {
// Not required.
}
kern_return_t AppleI386CPU::startCPU(vm_offset_t start_paddr, vm_offset_t arg_paddr) {
// Not implemented.
return KERN_FAILURE;
}
void AppleI386CPU::haltCPU() {
// Not required.
}
const OSSymbol *AppleI386CPU::getCPUName() {
return OSSymbol::withCStringNoCopy("Primary0");
}
#pragma mark -
#undef super
#define super IOCPUInterruptController
OSDefineMetaClassAndStructors(AppleI386CPUInterruptController, IOCPUInterruptController);
IOReturn AppleI386CPUInterruptController::handleInterrupt(void *refCon, IOService *nub, int source) {
// Override the implementation in IOCPUInterruptController to
// dispatch interrupts the old way. The source argument is ignored;
// the first IOCPUInterruptController in the vector array is always used.
IOInterruptVector *vector = &vectors[0];
if (!vector->interruptRegistered) return kIOReturnInvalid;
vector->handler(vector->target, refCon, vector->nub, source);
return kIOReturnSuccess;
}