--- /dev/null
+/*
+ * Copyright (c) 2006 Apple Computer, Inc. All rights reserved.
+ *
+ * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
+ *
+ * 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. The rights granted to you under the License
+ * may not be used to create, or enable the creation or redistribution of,
+ * unlawful or unlicensed copies of an Apple operating system, or to
+ * circumvent, violate, or enable the circumvention or violation of, any
+ * terms of an Apple operating system software license agreement.
+ *
+ * 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.
+ *
+ * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
+ */
+#ifdef KERNEL_PRIVATE
+#ifndef _I386_PMCPU_H_
+#define _I386_PMCPU_H_
+
+#include <kern/pms.h>
+
+#ifndef ASSEMBLER
+
+typedef enum { C1, C2, C3, C4, Hlt, C3Res, All, Cnum } pm_Cstate_t;
+typedef struct pmStats {
+ uint64_t pmNapCnt[Cnum]; /* Total nap calls for states */
+ uint64_t pmNapTime[Cnum]; /* Total nap time for states */
+ uint64_t pmNapC2HPET; /* Total nap time for C2 using HPET for stats */
+ uint64_t pmNapC4HPET; /* Total nap time for C4 using HPET for stats */
+ uint64_t pmNapHPETPops; /* Number of times we detect HPET popping */
+ uint64_t pmHPETRupt; /* Number of HPET interruptions */
+ uint32_t pmCurC3Res; /* Current value of the C3 residency timer */
+ uint32_t pmLastApic; /* Last value of apic timer */
+ uint32_t pmNewApic; /* New value of apic timer */
+ uint64_t pmHpetTim; /* Time to next interrupt in HPET ticks */
+ uint64_t pmHpetCmp; /* HPET comparator */
+ uint64_t pmHpetCfg; /* HPET configuration */
+ uint64_t pmLSNs; /* (TEST) Last set nanotime */
+ uint64_t pmLLHpet; /* (TEST) Last loaded HPET */
+} pmStats_t;
+
+#define MAX_PSTATES 32 /* architectural limit */
+
+typedef enum { Cn1, Cn2, Cn3, Cn4, Cnmax } Cstate_number_t;
+typedef struct {
+ Cstate_number_t number;
+ uint32_t hint;
+} Cstate_hint_t;
+
+
+struct pmData {
+ uint8_t pad[93];
+};
+typedef struct pmData pmData_t;
+
+#define pmNapHalt 0x00000010
+#define pmNapC1 0x00000008
+#define pmNapC2 0x00000004
+#define pmNapC3 0x00000002
+#define pmNapC4 0x00000001
+#define pmNapMask 0x000000FF
+
+#define cfgAdr 0xCF8
+#define cfgDat 0xCFC
+#define lpcCfg (0x80000000 | (0 << 16) | (31 << 11) | (0 << 8))
+
+/*
+ * Dispatch table for functions that get installed when the power
+ * management KEXT loads.
+ */
+typedef struct
+{
+ /*
+ * The following are the stepper table interfaces.
+ */
+ void (*pmsCPUMachineInit)(void);
+ void (*pmsCPUInit)(void);
+ void (*pmsCPUSet)(uint32_t sel);
+ void (*pmsCPUConf)(void);
+ void (*pmsCPURun)(uint32_t nstep);
+ uint32_t (*pmsCPUQuery)(void);
+ uint32_t (*pmsCPUPackageQuery)(void);
+ void (*pmsCPUYellowFlag)(void);
+ void (*pmsCPUGreenFlag)(void);
+ kern_return_t (*pmsCPULoadVIDTable)(uint16_t *tablep, int nstates);
+ kern_return_t (*pmsCPUSetPStateLimit)(uint32_t limit);
+
+ /*
+ * The following are the 'C' State interfaces.
+ */
+ void (*cstateInit)(void);
+ void (*cstateMachineIdle)(uint32_t napCtl);
+ kern_return_t (*cstateTableSet)(Cstate_hint_t *tablep, unsigned int nstates);
+ uint32_t (*cstateNapPolicy)(uint32_t forcenap, uint32_t napCtl);
+} pmDispatch_t;
+
+typedef struct {
+ uint32_t PState;
+ uint32_t PLimit;
+ uint16_t VIDTable[MAX_PSTATES];
+ uint32_t VIDTableCount;
+ Cstate_hint_t CStates[Cnmax];
+ uint32_t CStatesCount;
+} pmInitState_t;
+
+typedef struct {
+ void (*Park)(void);
+ void (*Run)(uint32_t nstep);
+ void (*RunLocal)(uint32_t nstep);
+ void (*SetStep)(uint32_t nstep, int dir);
+ void (*NapPolicy)(void);
+ kern_return_t (*Build)(pmsDef *pd, uint32_t pdsize, pmsSetFunc_t *functab, uint32_t platformData, pmsQueryFunc_t queryFunc);
+ pmStats_t *(*Stats)(void);
+ pmsd *(*StepperData)(void);
+ uint64_t *(*HPETAddr)(void);
+ pmInitState_t *InitState;
+ void (*resetPop)(void);
+} pmCallBacks_t;
+
+extern pmDispatch_t *pmDispatch;
+
+extern uint32_t maxBusDelay;
+extern uint32_t C4C2SnoopDelay;
+extern uint32_t forcenap;
+
+void power_management_init(void);
+void machine_nap_policy(void);
+kern_return_t Cstate_table_set(Cstate_hint_t *tablep, unsigned int nstates);
+void machine_idle_cstate(void);
+void pmRegister(pmDispatch_t *cpuFuncs, pmCallBacks_t *callbacks);
+void pmUnRegister(pmDispatch_t *cpuFuncs);
+
+#endif /* ASSEMBLER */
+#endif /* _I386_PMCPU_H_ */
+#endif /* KERNEL_PRIVATE */