-
Notifications
You must be signed in to change notification settings - Fork 0
/
Core99CPU.h
82 lines (71 loc) · 2.7 KB
/
Core99CPU.h
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
/*
* Copyright (c) 1998-2000 Apple Computer, Inc. All rights reserved.
*
* @APPLE_LICENSE_HEADER_START@
*
* The contents of this file constitute Original Code as defined in and
* are subject to the Apple Public Source License Version 1.1 (the
* "License"). You may not use this file except in compliance with the
* License. Please obtain a copy of the License at
* http://www.apple.com/publicsource and read it before using this file.
*
* This 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 OR NON-INFRINGEMENT. Please see the
* License for the specific language governing rights and limitations
* under the License.
*
* @APPLE_LICENSE_HEADER_END@
*/
/*
* Copyright (c) 1999-2000 Apple Computer, Inc. All rights reserved.
*
* DRI: Josh de Cesare
*
*/
#ifndef _IOKIT_CORE99CPU_H
#define _IOKIT_CORE99CPU_H
#include <IOKit/IOCPU.h>
#include "Core99.h"
class Core99CPUInterruptController;
class Core99CPU : public IOCPU
{
OSDeclareDefaultStructors(Core99CPU);
private:
bool bootCPU;
bool flushOnLock;
UInt32 l2crValue;
Core99PE *core99PE;
IOPCI2PCIBridge *decBridge;
UInt32 numCPUs;
bool rememberNap;
IOService *mpic;
IOService *keyLargo;
IOService *pmu;
virtual void ipiHandler(void *refCon, void *nub, int source);
// callPlatformFunction symbols
const OSSymbol *mpic_dispatchIPI;
const OSSymbol *mpic_getProvider;
const OSSymbol *mpic_getIPIVector;
const OSSymbol *mpic_setCurrentTaskPriority;
const OSSymbol *mpic_setUpForSleep;
const OSSymbol *keyLargo_restoreRegisterState;
const OSSymbol *keyLargo_syncTimeBase;
const OSSymbol *keyLargo_saveRegisterState;
const OSSymbol *keyLargo_turnOffIO;
const OSSymbol *keyLargo_writeRegUInt8;
public:
virtual const OSSymbol *getCPUName(void);
virtual bool start(IOService *provider);
virtual IOReturn powerStateWillChangeTo (IOPMPowerFlags, unsigned long, IOService*);
virtual void initCPU(bool boot);
virtual void quiesceCPU(void);
virtual kern_return_t startCPU(vm_offset_t start_paddr,
vm_offset_t arg_paddr);
virtual void haltCPU(void);
virtual void signalCPU(IOCPU *target);
virtual void enableCPUTimeBase(bool enable);
};
#endif /* ! _IOKIT_CORE99CPU_H */