RFR: Out-of-bounds access in cpu_family_description()
Jinke Fan
fanjinke51 at yeah.net
Fri Apr 12 06:51:56 UTC 2019
On 2019/4/12 14:20, David Holmes wrote:
> Hi,
>
> Was there a reason you had to move the existing arrays before extending
> the amd one with the missing values?
Yes, because the addition uses sizeof to control the boundary access.
If the arrays's defined were behind the sizeof,it causes a compilation
error: "error: invalid application of 'sizeof’ to incomplete type"
Best Regards!
Fanjinke
>
> Thanks,
> David
>
> On 12/04/2019 3:47 pm, Jinke Fan wrote:
>> Hi David,
>> In VM_Version_Ext::cpu_family_description has out-of-bounds
>> access on AMD 17h (EPYC) processor.
>>
>> const char* VM_Version_Ext::cpu_family_description(void) {
>>
>> On AMD 17h (EPYC) processor extended_cpu_family() will return 23,
>> but array _family_id_amd only has 17 members.
>>
>> int cpu_family_id = extended_cpu_family();
>> if (is_amd()) {
>> return _family_id_amd[cpu_family_id];
>> }
>> ...
>> }
>>
>> Result of testcase TestCPUInformation.java on AMD Zen:
>> ----------System.out:(15/1615)----------
>> ...
>> Family: 386 (0x17), Model: <unknown> (0x1), Stepping: 0x1
>> Ext. family: 0x8, Ext. model: 0x0, Type: 0x0, Signature: 0x00800f11
>> ...
>> }
>>
>> The “386” string is incorrectly and comes from Illegal access.
>>
>> The patch is based on the original repository:
>> hg.openjdk.java.net/jdk/jdk
>>
>> changeset: 54520:f48312257bc6
>> tag: tip
>> user: vromero
>> date: Thu Apr 11 22:56:11 2019 -0400
>> summary: 8222151: refactoring: enhancements to
>> java.lang.Class::methodToString and java.lang.Class::getTypeName
>>
>> *Patch
>> The out of hg diff -g:
>> diff --git a/src/hotspot/cpu/x86/vm_version_ext_x86.cpp
>> b/src/hotspot/cpu/x86/vm_version_ext_x86.cpp
>> --- a/src/hotspot/cpu/x86/vm_version_ext_x86.cpp
>> +++ b/src/hotspot/cpu/x86/vm_version_ext_x86.cpp
>> @@ -262,6 +262,52 @@
>> int VM_Version_Ext::_no_of_cores = 0;
>> int VM_Version_Ext::_no_of_packages = 0;
>>
>> +const char* const VM_Version_Ext::_family_id_intel[] = {
>> + "8086/8088",
>> + "",
>> + "286",
>> + "386",
>> + "486",
>> + "Pentium",
>> + "Pentium Pro", //or Pentium-M/Woodcrest depeding on model
>> + "",
>> + "",
>> + "",
>> + "",
>> + "",
>> + "",
>> + "",
>> + "",
>> + "Pentium 4"
>> +};
>> +
>> +const char* const VM_Version_Ext::_family_id_amd[] = {
>> + "",
>> + "",
>> + "",
>> + "",
>> + "5x86",
>> + "K5/K6",
>> + "Athlon/AthlonXP",
>> + "",
>> + "",
>> + "",
>> + "",
>> + "",
>> + "",
>> + "",
>> + "",
>> + "Opteron/Athlon64",
>> + "Opteron QC/Phenom", // Barcelona et.al.
>> + "",
>> + "",
>> + "",
>> + "",
>> + "",
>> + "",
>> + "Zen"
>> +};
>> +
>> void VM_Version_Ext::initialize(void) {
>> ResourceMark rm;
>>
>> @@ -401,15 +447,19 @@
>> }
>>
>> const char* VM_Version_Ext::cpu_family_description(void) {
>> - int cpu_family_id = extended_cpu_family();
>> + uint32_t cpu_family_id = extended_cpu_family();
>> if (is_amd()) {
>> - return _family_id_amd[cpu_family_id];
>> + if (cpu_family_id <
>> sizeof(_family_id_amd)/sizeof(_family_id_amd[0])) {
>> + return _family_id_amd[cpu_family_id];
>> + }
>> }
>> if (is_intel()) {
>> if (cpu_family_id == CPU_FAMILY_PENTIUMPRO) {
>> return cpu_model_description();
>> }
>> - return _family_id_intel[cpu_family_id];
>> + if (cpu_family_id <
>> sizeof(_family_id_intel)/sizeof(_family_id_intel[0])) {
>> + return _family_id_intel[cpu_family_id];
>> + }
>> }
>> if (is_hygon()) {
>> return "Dhyana";
>> @@ -705,44 +755,6 @@
>> return _max_qualified_cpu_frequency;
>> }
>>
>> -const char* const VM_Version_Ext::_family_id_intel[] = {
>> - "8086/8088",
>> - "",
>> - "286",
>> - "386",
>> - "486",
>> - "Pentium",
>> - "Pentium Pro", //or Pentium-M/Woodcrest depeding on model
>> - "",
>> - "",
>> - "",
>> - "",
>> - "",
>> - "",
>> - "",
>> - "",
>> - "Pentium 4"
>> -};
>> -
>> -const char* const VM_Version_Ext::_family_id_amd[] = {
>> - "",
>> - "",
>> - "",
>> - "",
>> - "5x86",
>> - "K5/K6",
>> - "Athlon/AthlonXP",
>> - "",
>> - "",
>> - "",
>> - "",
>> - "",
>> - "",
>> - "",
>> - "",
>> - "Opteron/Athlon64",
>> - "Opteron QC/Phenom" // Barcelona et.al.
>> -};
>> // Partially from Intel 64 and IA-32 Architecture Software
>> Developer's Manual,
>> // September 2013, Vol 3C Table 35-1
>> const char* const VM_Version_Ext::_model_id_pentium_pro[] = {
>>
>> *Test:
>> After patched,result of testcase TestCPUInformation.java on AMD Zen:
>> ----------System.out:(15/1615)----------
>> Event: jdk.CPUInformation {
>> ...
>> Family: Zen (0x17), Model: <unknown> (0x1), Stepping: 0x1
>> Ext. family: 0x8, Ext. model: 0x0, Type: 0x0, Signature: 0x00800f11
>> Features: ebx: 0x4f400800, ecx: 0x7ed8320b, edx: 0x178bfbff
>> ...
>> }
>>
>> Is there anything incorrectly?
>> Please let me know your comments.
>>
>> Best Regards!
>> Fanjinke
>>
>
More information about the hotspot-dev
mailing list