Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
btwise
OpenCorePKG_MOD
提交
98ef0653
O
OpenCorePKG_MOD
项目概览
btwise
/
OpenCorePKG_MOD
通知
26
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
O
OpenCorePKG_MOD
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
98ef0653
编写于
6月 07, 2019
作者:
V
vit9696
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
OcAppleKernelLib: Debug kernel cpuid patches
上级
585a88eb
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
117 addition
and
24 deletion
+117
-24
Include/Library/OcCpuLib.h
Include/Library/OcCpuLib.h
+1
-1
Library/OcAppleKernelLib/CommonPatches.c
Library/OcAppleKernelLib/CommonPatches.c
+112
-16
Library/OcCpuLib/OcCpuLib.c
Library/OcCpuLib/OcCpuLib.c
+4
-7
未找到文件。
Include/Library/OcCpuLib.h
浏览文件 @
98ef0653
...
...
@@ -105,7 +105,7 @@ OcCpuCorrectFlexRatio (
**/
UINT32
OcCpuModelToAppleFamily
(
IN
UINT32
VersionEax
IN
CPUID_VERSION_INFO_EAX
VersionEax
);
#endif // OC_CPU_LIB_H_
Library/OcAppleKernelLib/CommonPatches.c
浏览文件 @
98ef0653
...
...
@@ -537,11 +537,66 @@ mKernelCpuIdFindRelOld[] = {
STATIC
CONST
UINT8
mKernelCpuidFindMcRel
[]
=
{
0xB9
,
0x8B
,
0x00
,
0x00
,
0x00
,
0x00
,
0x0F
,
0x32
0xB9
,
0x8B
,
0x00
,
0x00
,
0x00
,
0x0F
,
0x32
};
/**
cpu->cpuid_signature = 0x11111111;
cpu->cpuid_stepping = 0x22;
cpu->cpuid_model = 0x33;
cpu->cpuid_family = 0x44;
cpu->cpuid_type = 0x55555555;
cpu->cpuid_extmodel = 0x66;
cpu->cpuid_extfamily = 0x77;
cpu->cpuid_features = 0x8888888888888888;
cpu->cpuid_logical_per_package = 0x99999999;
cpu->cpuid_cpufamily = 0xAAAAAAAA;
return 0xAAAAAAAA;
**/
STATIC
CONST
UINT8
mKernelCpuidReplaceDbg
[]
=
{
0xC7
,
0x47
,
0x68
,
0x11
,
0x11
,
0x11
,
0x11
,
///< mov dword ptr [rdi+68h], 11111111h
0xC6
,
0x47
,
0x50
,
0x22
,
///< mov byte ptr [rdi+50h], 22h
0x48
,
0xB8
,
0x55
,
0x55
,
0x55
,
0x55
,
0x44
,
0x33
,
0x66
,
0x77
,
///< mov rax, 7766334455555555h
0x48
,
0x89
,
0x47
,
0x48
,
///< mov [rdi+48h], rax
0x48
,
0xB8
,
0x88
,
0x88
,
0x88
,
0x88
,
0x88
,
0x88
,
0x88
,
0x88
,
///< mov rax, 8888888888888888h
0x48
,
0x89
,
0x47
,
0x58
,
///< mov [rdi+58h], rax
0xC7
,
0x87
,
0xCC
,
0x00
,
0x00
,
0x00
,
0x99
,
0x99
,
0x99
,
0x99
,
///< mov dword ptr [rdi+0CCh], 99999999h
0xC7
,
0x87
,
0x88
,
0x01
,
0x00
,
0x00
,
0xAA
,
0xAA
,
0xAA
,
0xAA
,
///< mov dword ptr [rdi+188h], 0AAAAAAAAh
0xB8
,
0xAA
,
0xAA
,
0xAA
,
0xAA
,
///< mov eax, 0AAAAAAAAh
0xC3
///< retn
};
#pragma pack(push, 1)
typedef
struct
{
UINT8
Code1
[
3
];
UINT32
Signature
;
UINT8
Code2
[
3
];
UINT8
Stepping
;
UINT8
Code3
[
2
];
UINT32
Type
;
UINT8
Family
;
UINT8
Model
;
UINT8
ExtModel
;
UINT8
ExtFamily
;
UINT8
Code4
[
6
];
UINT64
Features
;
UINT8
Code5
[
10
];
UINT32
LogicalPerPkg
;
UINT8
Code6
[
6
];
UINT32
AppleFamily1
;
UINT8
Code7
;
UINT32
AppleFamily2
;
UINT8
Code8
;
}
INTERNAL_CPUID_FN_PATCH
;
OC_GLOBAL_STATIC_ASSERT
(
sizeof
(
INTERNAL_CPUID_FN_PATCH
)
==
sizeof
(
mKernelCpuidReplaceDbg
),
"Check your CPUID patch layout"
);
typedef
struct
{
UINT8
EaxCmd
;
UINT32
EaxVal
;
...
...
@@ -575,16 +630,21 @@ PatchKernelCpuId (
UINT32
FoundSize
;
INTERNAL_CPUID_PATCH
*
CpuidPatch
;
INTERNAL_MICROCODE_PATCH
*
McPatch
;
INTERNAL_CPUID_FN_PATCH
*
FnPatch
;
CPUID_VERSION_INFO_EAX
Eax
;
CPUID_VERSION_INFO_EBX
Ebx
;
CPUID_VERSION_INFO_ECX
Ecx
;
CPUID_VERSION_INFO_EDX
Edx
;
OC_INLINE_STATIC_ASSERT
(
sizeof
(
mKernelCpuIdFindRelNew
)
>
sizeof
(
mKernelCpuIdFindRelOld
),
"Kernel CPUID patch seems wrong"
);
ASSERT
(
mKernelCpuIdFindRelNew
[
0
]
==
mKernelCpuIdFindRelOld
[
1
]
&&
mKernelCpuIdFindRelNew
[
1
]
==
mKernelCpuIdFindRelOld
[
2
]
&&
mKernelCpuIdFindRelNew
[
2
]
==
mKernelCpuIdFindRelOld
[
3
]
&&
mKernelCpuIdFindRelNew
[
3
]
==
mKernelCpuIdFindRelOld
[
4
]
ASSERT
(
mKernelCpuIdFindRelNew
[
0
]
==
mKernelCpuIdFindRelOld
[
0
]
&&
mKernelCpuIdFindRelNew
[
1
]
==
mKernelCpuIdFindRelOld
[
1
]
&&
mKernelCpuIdFindRelNew
[
2
]
==
mKernelCpuIdFindRelOld
[
2
]
&&
mKernelCpuIdFindRelNew
[
3
]
==
mKernelCpuIdFindRelOld
[
3
]
);
Last
=
((
UINT8
*
)
MachoGetMachHeader64
(
&
Patcher
->
MachContext
)
...
...
@@ -614,17 +674,26 @@ PatchKernelCpuId (
}
}
Eax
.
Uint32
=
(
Data
[
0
]
&
DataMask
[
0
])
|
(
CpuInfo
->
CpuidVerEax
.
Uint32
&
~
DataMask
[
0
]);
Ebx
.
Uint32
=
(
Data
[
1
]
&
DataMask
[
1
])
|
(
CpuInfo
->
CpuidVerEbx
.
Uint32
&
~
DataMask
[
1
]);
Ecx
.
Uint32
=
(
Data
[
2
]
&
DataMask
[
2
])
|
(
CpuInfo
->
CpuidVerEcx
.
Uint32
&
~
DataMask
[
2
]);
Edx
.
Uint32
=
(
Data
[
3
]
&
DataMask
[
3
])
|
(
CpuInfo
->
CpuidVerEdx
.
Uint32
&
~
DataMask
[
3
]);
if
(
FoundSize
>
0
)
{
CpuidPatch
=
(
INTERNAL_CPUID_PATCH
*
)
Record
;
CpuidPatch
->
EaxCmd
=
0xB8
;
CpuidPatch
->
EaxVal
=
(
Data
[
0
]
&
DataMask
[
0
])
|
(
CpuInfo
->
CpuidVerEax
.
Uint32
&
~
DataMask
[
0
]);
CpuidPatch
->
EbxCmd
=
0xBB
;
CpuidPatch
->
EbxVal
=
(
Data
[
1
]
&
DataMask
[
1
])
|
(
CpuInfo
->
CpuidVerEbx
.
Uint32
&
~
DataMask
[
1
]);
CpuidPatch
->
EcxCmd
=
0xB9
;
CpuidPatch
->
EcxVal
=
(
Data
[
2
]
&
DataMask
[
2
])
|
(
CpuInfo
->
CpuidVerEcx
.
Uint32
&
~
DataMask
[
2
]);
CpuidPatch
->
EdxCmd
=
0xBA
;
CpuidPatch
->
EdxVal
=
(
Data
[
3
]
&
DataMask
[
3
])
|
(
CpuInfo
->
CpuidVerEdx
.
Uint32
&
~
DataMask
[
3
]);
SetMem
(
Record
+
sizeof
(
INTERNAL_CPUID_PATCH
),
FoundSize
-
sizeof
(
INTERNAL_CPUID_PATCH
),
0x90
);
CpuidPatch
=
(
INTERNAL_CPUID_PATCH
*
)
Record
;
CpuidPatch
->
EaxCmd
=
0xB8
;
CpuidPatch
->
EaxVal
=
Eax
.
Uint32
;
CpuidPatch
->
EbxCmd
=
0xBB
;
CpuidPatch
->
EbxVal
=
Ebx
.
Uint32
;
CpuidPatch
->
EcxCmd
=
0xB9
;
CpuidPatch
->
EcxVal
=
Ecx
.
Uint32
;
CpuidPatch
->
EdxCmd
=
0xBA
;
CpuidPatch
->
EdxVal
=
Edx
.
Uint32
;
SetMem
(
Record
+
sizeof
(
INTERNAL_CPUID_PATCH
),
FoundSize
-
sizeof
(
INTERNAL_CPUID_PATCH
),
0x90
);
Record
+=
FoundSize
;
for
(
Index
=
0
;
Index
<
EFI_PAGE_SIZE
-
sizeof
(
mKernelCpuidFindMcRel
);
++
Index
,
++
Record
)
{
...
...
@@ -642,9 +711,36 @@ PatchKernelCpuId (
}
}
else
{
//
//
TODO: Implement debug kernel support
.
//
Handle debug kernel here..
.
//
Status
=
PatcherGetSymbolAddress
(
Patcher
,
"_cpuid_set_cpufamily"
,
(
UINT8
**
)
&
Record
);
if
(
RETURN_ERROR
(
Status
)
||
Record
>=
Last
)
{
DEBUG
((
DEBUG_WARN
,
"Failed to locate _cpuid_set_cpufamily (%p) - %r
\n
"
,
Record
,
Status
));
return
EFI_NOT_FOUND
;
}
CopyMem
(
Record
,
mKernelCpuidReplaceDbg
,
sizeof
(
mKernelCpuidReplaceDbg
));
FnPatch
=
(
INTERNAL_CPUID_FN_PATCH
*
)
Record
;
FnPatch
->
Signature
=
Eax
.
Uint32
;
FnPatch
->
Stepping
=
(
UINT8
)
Eax
.
Bits
.
SteppingId
;
FnPatch
->
ExtModel
=
(
UINT8
)
Eax
.
Bits
.
ExtendedModelId
;
FnPatch
->
Model
=
Eax
.
Bits
.
Model
|
(
UINT8
)
(
Eax
.
Bits
.
ExtendedModelId
<<
4U
);
FnPatch
->
Family
=
(
UINT8
)
Eax
.
Bits
.
FamilyId
;
FnPatch
->
Type
=
(
UINT8
)
Eax
.
Bits
.
ProcessorType
;
FnPatch
->
ExtFamily
=
(
UINT8
)
Eax
.
Bits
.
ExtendedFamilyId
;
FnPatch
->
Features
=
((
UINT64
)
Ecx
.
Uint32
<<
32ULL
)
|
(
UINT64
)
Edx
.
Uint32
;
if
(
FnPatch
->
Features
&
CPUID_FEATURE_HTT
)
{
FnPatch
->
LogicalPerPkg
=
(
UINT16
)
Ebx
.
Bits
.
MaximumAddressableIdsForLogicalProcessors
;
}
else
{
FnPatch
->
LogicalPerPkg
=
1
;
}
FnPatch
->
AppleFamily1
=
FnPatch
->
AppleFamily2
=
OcCpuModelToAppleFamily
(
Eax
);
return
EFI_SUCCESS
;
}
DEBUG
((
DEBUG_WARN
,
"Failed to find either CPUID patch (%u)
\n
"
,
FoundSize
));
return
RETURN_UNSUPPORTED
;
}
Library/OcCpuLib/OcCpuLib.c
浏览文件 @
98ef0653
...
...
@@ -904,7 +904,7 @@ OcCpuScanProcessor (
Cpu
->
MicrocodeRevision
=
AsmReadMsr32
(
MSR_IA32_BIOS_SIGN_ID
);
}
Cpu
->
Signature
=
(
UINT8
)
Cpu
->
CpuidVerEax
.
Uint32
;
Cpu
->
Signature
=
Cpu
->
CpuidVerEax
.
Uint32
;
Cpu
->
Stepping
=
(
UINT8
)
Cpu
->
CpuidVerEax
.
Bits
.
SteppingId
;
Cpu
->
ExtModel
=
(
UINT8
)
Cpu
->
CpuidVerEax
.
Bits
.
ExtendedModelId
;
Cpu
->
Model
=
(
UINT8
)
Cpu
->
CpuidVerEax
.
Bits
.
Model
|
(
UINT8
)
(
Cpu
->
CpuidVerEax
.
Bits
.
ExtendedModelId
<<
4U
);
...
...
@@ -1004,15 +1004,12 @@ OcCpuCorrectFlexRatio (
UINT32
OcCpuModelToAppleFamily
(
IN
UINT32
VersionEax
IN
CPUID_VERSION_INFO_EAX
VersionEax
)
{
CPUID_VERSION_INFO_EAX
Eax
;
UINT8
Model
;
Eax
.
Uint32
=
VersionEax
;
if
(
Eax
.
Bits
.
FamilyId
!=
6
)
{
if
(
VersionEax
.
Bits
.
FamilyId
!=
6
)
{
return
CPUFAMILY_UNKNOWN
;
}
...
...
@@ -1020,7 +1017,7 @@ OcCpuModelToAppleFamily (
// This MUST be 1 to 1 with Apple XNU kernel implemenation.
//
Model
=
(
UINT8
)
Eax
.
Bits
.
Model
|
(
UINT8
)
(
Eax
.
Bits
.
ExtendedModelId
<<
4U
);
Model
=
(
UINT8
)
VersionEax
.
Bits
.
Model
|
(
UINT8
)
(
Version
Eax
.
Bits
.
ExtendedModelId
<<
4U
);
switch
(
Model
)
{
case
CPU_MODEL_PENRYN
:
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录