X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fvppinfra%2Fcpu.c;h=9ed8e8025f8e6b13164ea434f86dbba14aa8acba;hb=38e0413b2a7bf39a18045e6c6f528655f8354652;hp=c1ff7dd27b38f6098d637c419d83f602bc032f10;hpb=c9122f97398b11f8be0256901a0cbd83dc3b6511;p=vpp.git diff --git a/src/vppinfra/cpu.c b/src/vppinfra/cpu.c index c1ff7dd27b3..9ed8e8025f8 100644 --- a/src/vppinfra/cpu.c +++ b/src/vppinfra/cpu.c @@ -20,7 +20,15 @@ #define foreach_x86_cpu_uarch \ _(0x06, 0x9e, "Kaby Lake", "Kaby Lake DT/H/S/X") \ _(0x06, 0x8e, "Kaby Lake", "Kaby Lake Y/U") \ + _(0x06, 0x8c, "Tiger Lake", "Tiger Lake U") \ + _(0x06, 0x86, "Tremont", "Elkhart Lake") \ _(0x06, 0x85, "Knights Mill", "Knights Mill") \ + _(0x06, 0x7e, "Ice Lake", "Ice Lake U") \ + _(0x06, 0x7d, "Ice Lake", "Ice Lake Y") \ + _(0x06, 0x7a, "Goldmont Plus", "Gemini Lake") \ + _(0x06, 0x6c, "Ice Lake", "Ice Lake SP") \ + _(0x06, 0x6a, "Ice Lake", "Ice Lake DE") \ + _(0x06, 0x66, "Cannon Lake", "Cannon Lake U") \ _(0x06, 0x5f, "Goldmont", "Denverton") \ _(0x06, 0x5e, "Skylake", "Skylake DT/H/S") \ _(0x06, 0x5c, "Goldmont", "Apollo Lake") \ @@ -183,12 +191,10 @@ format_cpu_model_name (u8 * s, va_list * args) static inline char const * -flag_skip_prefix (char const *flag) +flag_skip_prefix (char const *flag, const char *pfx, int len) { - if (memcmp (flag, "x86_", sizeof ("x86_") - 1) == 0) - return flag + sizeof ("x86_") - 1; - if (memcmp (flag, "aarch64_", sizeof ("aarch64_") - 1) == 0) - return flag + sizeof ("aarch64_") - 1; + if (0 == strncmp (flag, pfx, len - 1)) + return flag + len - 1; return flag; } @@ -198,13 +204,13 @@ format_cpu_flags (u8 * s, va_list * args) #if defined(__x86_64__) #define _(flag, func, reg, bit) \ if (clib_cpu_supports_ ## flag()) \ - s = format (s, "%s ", flag_skip_prefix(#flag)); + s = format (s, "%s ", flag_skip_prefix(#flag, "x86_", sizeof("x86_"))); foreach_x86_64_flags return s; #undef _ #elif defined(__aarch64__) #define _(flag, bit) \ if (clib_cpu_supports_ ## flag()) \ - s = format (s, "%s ", flag_skip_prefix(#flag)); + s = format (s, "%s ", flag_skip_prefix(#flag, "aarch64_", sizeof("aarch64_"))); foreach_aarch64_flags return s; #undef _ #else /* ! ! __x86_64__ && ! __aarch64__ */