gallium/u_cpu_detect: fix parsing the CPU family
authorMarek Olšák <marek.olsak@amd.com>
Thu, 6 Sep 2018 00:11:34 +0000 (20:11 -0400)
committerMarek Olšák <marek.olsak@amd.com>
Fri, 7 Sep 2018 19:48:31 +0000 (15:48 -0400)
According to:
https://support.amd.com/TechDocs/54945_PPR_Family_17h_Models_00h-0Fh.pdf

Also Intel:
https://www.microbe.cz/docs/CPUID.pdf

Reviewed-by: Brian Paul <brianp@vmware.com>
src/gallium/auxiliary/util/u_cpu_detect.c

index 93cf58011db3dde1f7f37941f8e394d36bcf4709..29f4ce982034bfa0c0057b1073ebc7f306d69280 100644 (file)
@@ -420,8 +420,9 @@ util_cpu_detect_once(void)
          cpuid (0x00000001, regs2);
 
          util_cpu_caps.x86_cpu_type = (regs2[0] >> 8) & 0xf;
+         /* Add "extended family". */
          if (util_cpu_caps.x86_cpu_type == 0xf)
-             util_cpu_caps.x86_cpu_type = 8 + ((regs2[0] >> 20) & 255); /* use extended family (P4, IA64) */
+             util_cpu_caps.x86_cpu_type += ((regs2[0] >> 20) & 0xff);
 
          /* general feature flags */
          util_cpu_caps.has_tsc    = (regs2[3] >>  4) & 1; /* 0x0000010 */