276 lines
5.6 KiB
C
276 lines
5.6 KiB
C
|
/*++
|
||
|
|
||
|
Copyright (c) 2000 Microsoft Corporation
|
||
|
|
||
|
Module Name:
|
||
|
|
||
|
p3.h
|
||
|
|
||
|
Abstract:
|
||
|
|
||
|
This is included by every file in p3.sys
|
||
|
|
||
|
Author:
|
||
|
|
||
|
Jake Oshins (3/21/00) - create file
|
||
|
|
||
|
Environment:
|
||
|
|
||
|
Kernel mode
|
||
|
|
||
|
Notes:
|
||
|
|
||
|
Revision History:
|
||
|
|
||
|
--*/
|
||
|
|
||
|
#ifndef _P3_H_
|
||
|
#define _P3_H_
|
||
|
|
||
|
#include "..\lib\processor.h"
|
||
|
#include "..\eventmsg.h"
|
||
|
|
||
|
//
|
||
|
// Time defined in 100ns intervals
|
||
|
//
|
||
|
|
||
|
#define MICROSECOND 10
|
||
|
#define MILLISECOND (MICROSECOND * 1000)
|
||
|
#define SECOND (MILLISECOND * 1000)
|
||
|
#define MINUTE (SECOND * 60)
|
||
|
|
||
|
#define STATUS_PERF_TRANSITIONS_UNAVAILABLE MAXULONG
|
||
|
#define MAX_RETRY_TIMEOUT 1800 // 30 minutes
|
||
|
#define MIN_RETRY_TIMEOUT 1 // 1 second
|
||
|
#define DEFAULT_RETRY_TIMEOUT 60 // 1 minute
|
||
|
|
||
|
//
|
||
|
// Registry location for p3.sys's parameters regkey
|
||
|
//
|
||
|
|
||
|
#define P3_PARAMETERS_KEY L"\\Registry\\Machine\\System\\CurrentControlSet\\Services\\P3\\Parameters"
|
||
|
#define ENABLE_LEGACY_SPEEDSTEP_INTERFACE 0x1
|
||
|
#define INTEL_APPLET_REMOVED_ON_UPGRADE 0x2
|
||
|
#define ENABLE_HIGH_SPEED_ON_BATTERY 0x4
|
||
|
|
||
|
|
||
|
//
|
||
|
// Geyserville defintions
|
||
|
//
|
||
|
|
||
|
#define MAX_GEYSERVILLE_STATES 2
|
||
|
|
||
|
#define BIT0 0x1
|
||
|
#define BIT1 0x2
|
||
|
#define BIT2 0x4
|
||
|
#define BIT3 0x8
|
||
|
#define BIT4 0x10
|
||
|
|
||
|
#define MSR_17 0x17
|
||
|
#define MSR_17_HIGH_MOBILE_PROCESSOR 0x40000 // bit 18
|
||
|
#define MSR_17_PLATFORM_ID_OFFSET 19
|
||
|
#define MSR_17_IST_FIELD_OFFSET 24
|
||
|
|
||
|
#define MSR_20 0x20
|
||
|
#define MSR_20_STRIDE_BIT_OFFSET 15
|
||
|
#define MSR_20_STRIDE_BIT (1 << MSR_20_STRIDE_BIT_OFFSET)
|
||
|
|
||
|
#define MSR_2A 0x2A
|
||
|
#define MSR_2A_BUS_SPEED_OFFSET 18
|
||
|
#define MSR_2A_BUS_RATIO_OFFSET 22
|
||
|
#define MSR_2A_BUS_RATIO_MSB_BIT 0x8000000 // bit 27
|
||
|
|
||
|
|
||
|
#define MSR_119 0x119
|
||
|
|
||
|
|
||
|
extern LEGACY_GEYSERVILLE_INT15 LegacyInterface;
|
||
|
|
||
|
//
|
||
|
// Array index is the Bus Ratio
|
||
|
//
|
||
|
|
||
|
#define PROC_STATE_INFO_SIZE 32
|
||
|
|
||
|
//
|
||
|
// State Flags
|
||
|
//
|
||
|
|
||
|
#define COPPERMINE_PROCESSOR 0x1
|
||
|
#define TUALATINE_PROCESSOR 0x2
|
||
|
#define BUS_133MHZ 0x4
|
||
|
#define EXTENDED_BUS_RATIO 0x8
|
||
|
|
||
|
|
||
|
//
|
||
|
// From the Geyserville BIOS Writer's guide, Chapter 2.
|
||
|
// The input is MSR2A[25:22] and MSR2A[27] in a Mobile PentiumIII.
|
||
|
// The output is the core frequency for a 100MHz front-side bus.
|
||
|
//
|
||
|
|
||
|
#define HIGHEST_KNOWN_COPPERMINE_CPUID 0x68A
|
||
|
#define HIGHEST_KNOWN_TUALATIN_CPUID 0x6B1
|
||
|
|
||
|
#define FAMILYMODEL_MASK 0x0FF0 // Mask for family/model codes.
|
||
|
#define FAMILYMODEL_COPPERMINE 0x0680 // Coppermine family/mode code.
|
||
|
#define FAMILYMODEL_TUALATIN 0x06B0 // Tualatin family/mode code.
|
||
|
#define EXTENDED_INFO_TYPE 0x0686 // CPUID of extended bus ratio support
|
||
|
#define EXTENDED_BIN_TYPE 0x068A // CPUID of extended bin support
|
||
|
|
||
|
|
||
|
//
|
||
|
// This is put in ebx before a call.
|
||
|
//
|
||
|
|
||
|
typedef enum {
|
||
|
GeyservilleControl,
|
||
|
GetGeyservilleStatus,
|
||
|
SetGeyservilleState,
|
||
|
SetGeyservilleSetup
|
||
|
} LEGACY_GEYSERVILLE_CONTROL_CODES;
|
||
|
|
||
|
typedef enum {
|
||
|
GeyservilleControlEnableApp,
|
||
|
GeyservilleControlReserved,
|
||
|
GeyservilleControlDisableApp
|
||
|
} LEGACY_GEYSERVILLE_CONTROL_SUBCODES;
|
||
|
|
||
|
typedef enum {
|
||
|
GeyservilleControlSuccessful,
|
||
|
GeyservilleDisabledInSetup,
|
||
|
GeyservilleSystemNotCapable,
|
||
|
GeyservilleDisabledByOS,
|
||
|
GeyservilleInvalidSignature,
|
||
|
GeyservilleUnknownError
|
||
|
} LEGACY_GEYSERVILLE_CONTROL_RETURN_CODES;
|
||
|
|
||
|
typedef enum {
|
||
|
GeyservilleSetSuccessful,
|
||
|
GeyservilleStateUnavailable,
|
||
|
GeyservilleUnsuccessfulTransition,
|
||
|
GeyservilleAbortCritical,
|
||
|
GeyservilleSetUnknownError,
|
||
|
GeyservilleTransitionUnavailable
|
||
|
} LEGACY_GEYSERVILLE_SET_RETURN_CODES;
|
||
|
|
||
|
|
||
|
typedef struct _LEGACY_GEYSERVILLE_INTERFACE_INFO {
|
||
|
|
||
|
ULONG CurrentState;
|
||
|
UCHAR InterfaceMajorRev;
|
||
|
USHORT InterfaceMinorRev;
|
||
|
UCHAR InterfaceReserved;
|
||
|
UCHAR MaxSupportedStates;
|
||
|
UCHAR CurrentlyAvailableStates;
|
||
|
USHORT CurrentBiosSettings;
|
||
|
|
||
|
} LEGACY_GEYSERVILLE_INTERFACE_INFO, *PLEGACY_GEYSERVILLE_INTERFACE_INFO;
|
||
|
|
||
|
|
||
|
typedef struct _P3_GLOBALS {
|
||
|
|
||
|
ULONG HackFlags;
|
||
|
BOOLEAN KnownCPUID;
|
||
|
LEGACY_GEYSERVILLE_INTERFACE_INFO LegacyInterfaceInfo;
|
||
|
ULONG MaxLevelAc;
|
||
|
ULONG MaxLevelDc;
|
||
|
ULONG IstField;
|
||
|
BOOLEAN TransitionsUnavailable;
|
||
|
KDPC Dpc;
|
||
|
KTIMER Timer;
|
||
|
LARGE_INTEGER TimeOut;
|
||
|
|
||
|
} P3_GLOBALS;
|
||
|
|
||
|
|
||
|
typedef struct _PROCESSOR_STATE_INFO {
|
||
|
|
||
|
ULONG BinValue;
|
||
|
ULONG Frequency;
|
||
|
ULONG Power;
|
||
|
|
||
|
} PROCESSOR_STATE_INFO, *PPROCESSOR_STATE_INFO;
|
||
|
|
||
|
|
||
|
|
||
|
//
|
||
|
// bios.c
|
||
|
//
|
||
|
|
||
|
NTSTATUS
|
||
|
InitializeLegacyInterface (
|
||
|
PLEGACY_GEYSERVILLE_INTERFACE_INFO Info,
|
||
|
PFDO_DATA DeviceExtension
|
||
|
);
|
||
|
|
||
|
NTSTATUS
|
||
|
FindLegacyGeyservilleInterface(
|
||
|
VOID
|
||
|
);
|
||
|
|
||
|
NTSTATUS
|
||
|
GetCurrentStateSmm(
|
||
|
PLEGACY_GEYSERVILLE_INTERFACE_INFO Info
|
||
|
);
|
||
|
|
||
|
NTSTATUS
|
||
|
SetCurrentStateSmm(
|
||
|
ULONG NewState
|
||
|
);
|
||
|
|
||
|
NTSTATUS
|
||
|
SetCurrentSetupSmm(
|
||
|
ULONG NewState
|
||
|
);
|
||
|
|
||
|
NTSTATUS
|
||
|
InitializeSmmInterface(
|
||
|
VOID
|
||
|
);
|
||
|
|
||
|
NTSTATUS
|
||
|
GetCurrentProcFrequency (
|
||
|
IN ULONG State,
|
||
|
OUT PULONG CpuSpeed
|
||
|
);
|
||
|
|
||
|
NTSTATUS
|
||
|
CollectProcessorInfomation (
|
||
|
VOID
|
||
|
);
|
||
|
|
||
|
ULONG
|
||
|
FindCpuSpeedByBinValue (
|
||
|
ULONG BinValue,
|
||
|
PPROCESSOR_STATE_INFO Table
|
||
|
);
|
||
|
|
||
|
NTSTATUS
|
||
|
AdjustLegacyProcessorPerformanceStates(
|
||
|
IN OUT PACPI_PSS_PACKAGE PssPackage
|
||
|
);
|
||
|
|
||
|
NTSTATUS
|
||
|
ProcessSleepStateNotification (
|
||
|
IN POWER_STATE_HANDLER_TYPE State,
|
||
|
IN PVOID Context,
|
||
|
IN BOOLEAN Entering
|
||
|
);
|
||
|
|
||
|
|
||
|
VOID
|
||
|
DumpStateFlags (
|
||
|
ULONG StateFlags
|
||
|
);
|
||
|
|
||
|
|
||
|
VOID
|
||
|
P3TimerDpcHandler (
|
||
|
IN PKDPC Dpc,
|
||
|
IN PVOID DeferredContext,
|
||
|
IN PVOID SystemArgument1,
|
||
|
IN PVOID SystemArgument2
|
||
|
);
|
||
|
|
||
|
|
||
|
#endif
|