[clang] [CIR][X86] Add support for `cpuid`/`cpuidex` (PR #173197)

Sirui Mu via cfe-commits cfe-commits at lists.llvm.org
Wed Dec 24 04:50:08 PST 2025


================
@@ -5819,4 +5762,31 @@ def CIR_BlockAddressOp : CIR_Op<"block_address", [Pure]> {
   }];
 }
 
+//===----------------------------------------------------------------------===//
+// CpuIdOp
+//===----------------------------------------------------------------------===//
+
+def CIR_CpuIdOp : CIR_Op<"cpuid"> {
+  let summary = "Get information about the CPU";
+  let description = [{
+    The `cir.cpuid` operation takes a base pointer to an array of 4 integers, a
+    function ID and a sub-function ID. The array of 4 integers is filled with
+    different information about the processor.
----------------
Lancern wrote:

Please add a verifier that ensures the input pointer is indeed a `!cir.ptr<!cir.array<4 x !s32i>>`.

https://github.com/llvm/llvm-project/pull/173197


More information about the cfe-commits mailing list