[Openmp-commits] [openmp] [OpenMP] Remove unused logical/physical CPUID information (PR #83298)
Jonathan Peyton via Openmp-commits
openmp-commits at lists.llvm.org
Wed Feb 28 09:21:09 PST 2024
https://github.com/jpeyton52 created https://github.com/llvm/llvm-project/pull/83298
None
>From 77cbcb072ad9f0caf569a05a545c5ec08f271a02 Mon Sep 17 00:00:00 2001
From: Jonathan Peyton <jonathan.l.peyton at intel.com>
Date: Tue, 27 Feb 2024 15:47:45 -0600
Subject: [PATCH] [OpenMP] Remove unused logical/physical CPUID information
---
openmp/runtime/src/kmp.h | 2 -
openmp/runtime/src/kmp_utility.cpp | 68 +-----------------------------
2 files changed, 1 insertion(+), 69 deletions(-)
diff --git a/openmp/runtime/src/kmp.h b/openmp/runtime/src/kmp.h
index 259c57b5afbca5..1d9a951f8a6339 100644
--- a/openmp/runtime/src/kmp.h
+++ b/openmp/runtime/src/kmp.h
@@ -1391,8 +1391,6 @@ typedef struct kmp_cpuinfo {
int stepping; // CPUID(1).EAX[3:0] ( Stepping )
kmp_cpuinfo_flags_t flags;
int apic_id;
- int physical_id;
- int logical_id;
kmp_uint64 frequency; // Nominal CPU frequency in Hz.
char name[3 * sizeof(kmp_cpuid_t)]; // CPUID(0x80000002,0x80000003,0x80000004)
} kmp_cpuinfo_t;
diff --git a/openmp/runtime/src/kmp_utility.cpp b/openmp/runtime/src/kmp_utility.cpp
index f901eaca92f4d1..bfa450c9ced26a 100644
--- a/openmp/runtime/src/kmp_utility.cpp
+++ b/openmp/runtime/src/kmp_utility.cpp
@@ -28,68 +28,6 @@ static const char *unknown = "unknown";
static int trace_level = 5;
#endif
-/* LOG_ID_BITS = ( 1 + floor( log_2( max( log_per_phy - 1, 1 ))))
- * APIC_ID = (PHY_ID << LOG_ID_BITS) | LOG_ID
- * PHY_ID = APIC_ID >> LOG_ID_BITS
- */
-int __kmp_get_physical_id(int log_per_phy, int apic_id) {
- int index_lsb, index_msb, temp;
-
- if (log_per_phy > 1) {
- index_lsb = 0;
- index_msb = 31;
-
- temp = log_per_phy;
- while ((temp & 1) == 0) {
- temp >>= 1;
- index_lsb++;
- }
-
- temp = log_per_phy;
- while ((temp & 0x80000000) == 0) {
- temp <<= 1;
- index_msb--;
- }
-
- /* If >1 bits were set in log_per_phy, choose next higher power of 2 */
- if (index_lsb != index_msb)
- index_msb++;
-
- return ((int)(apic_id >> index_msb));
- }
-
- return apic_id;
-}
-
-/*
- * LOG_ID_BITS = ( 1 + floor( log_2( max( log_per_phy - 1, 1 ))))
- * APIC_ID = (PHY_ID << LOG_ID_BITS) | LOG_ID
- * LOG_ID = APIC_ID & (( 1 << LOG_ID_BITS ) - 1 )
- */
-int __kmp_get_logical_id(int log_per_phy, int apic_id) {
- unsigned current_bit;
- int bits_seen;
-
- if (log_per_phy <= 1)
- return (0);
-
- bits_seen = 0;
-
- for (current_bit = 1; log_per_phy != 0; current_bit <<= 1) {
- if (log_per_phy & current_bit) {
- log_per_phy &= ~current_bit;
- bits_seen++;
- }
- }
-
- /* If exactly 1 bit was set in log_per_phy, choose next lower power of 2 */
- if (bits_seen == 1) {
- current_bit >>= 1;
- }
-
- return ((int)((current_bit - 1) & apic_id));
-}
-
static kmp_uint64 __kmp_parse_frequency( // R: Frequency in Hz.
char const *frequency // I: Float number and unit: MHz, GHz, or TGz.
) {
@@ -122,7 +60,6 @@ static kmp_uint64 __kmp_parse_frequency( // R: Frequency in Hz.
void __kmp_query_cpuid(kmp_cpuinfo_t *p) {
struct kmp_cpuid buf;
int max_arg;
- int log_per_phy;
#ifdef KMP_DEBUG
int cflush_size;
#endif
@@ -227,11 +164,8 @@ void __kmp_query_cpuid(kmp_cpuinfo_t *p) {
if ((buf.edx >> 28) & 1) {
/* Bits 23-16: Logical Processors per Physical Processor (1 for P4) */
- log_per_phy = data[2];
p->apic_id = data[3]; /* Bits 31-24: Processor Initial APIC ID (X) */
- KA_TRACE(trace_level, (" HT(%d TPUs)", log_per_phy));
- p->physical_id = __kmp_get_physical_id(log_per_phy, p->apic_id);
- p->logical_id = __kmp_get_logical_id(log_per_phy, p->apic_id);
+ KA_TRACE(trace_level, (" HT(%d TPUs)", data[2]));
}
#ifdef KMP_DEBUG
if ((buf.edx >> 29) & 1) {
More information about the Openmp-commits
mailing list