In gdb/nat/linux-btrace.c:btrace_this_cpu() we initialize the cpu
structure given to the libipt btrace decoder.
We only consider the extended model field for family 0x6 and forget about
family 0xf and we don't consider the extended family field. Fix it.
cpu.vendor = CV_INTEL;
cpu.family = (cpuid >> 8) & 0xf;
- cpu.model = (cpuid >> 4) & 0xf;
+ if (cpu.family == 0xf)
+ cpu.family += (cpuid >> 20) & 0xff;
- if (cpu.family == 0x6)
+ cpu.model = (cpuid >> 4) & 0xf;
+ if ((cpu.family == 0x6) || ((cpu.family & 0xf) == 0xf))
cpu.model += (cpuid >> 12) & 0xf0;
}
}