[PATCH] D97504: [llvm-exegesis] Disable the LBR check on AMD

Michał Górny via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Tue Mar 2 13:14:12 PST 2021


mgorny added inline comments.


================
Comment at: llvm/tools/llvm-exegesis/lib/X86/Target.cpp:735
+    // be confuse and think the AMD machine actually has LBR support.
+    if (state.getSubtargetInfo().getCPU().compare_lower("amd") != 0)
+      // If the kernel supports it, the hardware still may not have it.
----------------
oontvoo wrote:
> ondrasej wrote:
> > mgorny wrote:
> > > I wonder if it wouldn't be better to explicitly check for Intel here, or maybe even for Intel family new enough for LBR. I'm going to guess that Cyrix/VIA processors don't have it either.
> > +1. The perf counters are vendor specific (in particular, we have some Intel-specific magic numbers in the code), so it would make more sense to allow only Intel rather than reject only AMD. We can allow more architectures as soon as we can verify the LBR support on them.
> Good point. 
> So ideally we want to say abort if we see anything that's not Intel, but looking at `llvm::Triple::VendorType`, I don't see `Intel` listed as a vendor.
> A bit surprised... Does anyone know why?
Probably because nobody lists CPU vendor in the vendor field. It's usually `pc` or `unknown`.

IIRC the code is going to run on host, so you probably want to look at CPUID for the CPU vendor. `sys::getHostCPUName` has some logic to check for Intel/AMD but doesn't seem to return that usefully. Maybe you should copy the part of that logic, i.e. something like:

```
if (getX86CpuIDAndInfo(0, &MaxLeaf, &Vendor, &ECX, &EDX) || MaxLeaf < 1 || Vendor != 0x756e6547)
  return; // not intel
```


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D97504/new/

https://reviews.llvm.org/D97504



More information about the llvm-commits mailing list