@@ -165,9 +165,13 @@ struct feature_entry {
if (maxleaf < feat->leaf)
return 0;
+#ifndef RTE_TOOLCHAIN_MSVC
__cpuid_count(feat->leaf, feat->subleaf,
regs[RTE_REG_EAX], regs[RTE_REG_EBX],
regs[RTE_REG_ECX], regs[RTE_REG_EDX]);
+#else
+ __cpuidex(regs, feat->leaf, feat->subleaf);
+#endif
/* check if the feature is enabled */
return (regs[feat->reg] >> feat->bit) & 1;
@@ -5,7 +5,9 @@
#ifndef RTE_CPUID_H
#define RTE_CPUID_H
+#ifndef RTE_TOOLCHAIN_MSVC
#include <cpuid.h>
+#endif
enum cpu_register_t {
RTE_REG_EAX = 0,
@@ -16,4 +18,9 @@ enum cpu_register_t {
typedef uint32_t cpuid_registers_t[4];
+#ifdef RTE_TOOLCHAIN_MSVC
+int
+__get_cpuid_max(unsigned int e, unsigned int *s);
+#endif
+
#endif /* RTE_CPUID_H */
@@ -4,7 +4,11 @@
#include <fcntl.h>
#include <unistd.h>
+#ifndef RTE_TOOLCHAIN_MSVC
#include <cpuid.h>
+#else
+#define bit_AVX (1 << 28)
+#endif
#include "eal_private.h"
@@ -82,9 +86,25 @@
return 0;
}
+#ifdef RTE_TOOLCHAIN_MSVC
+int
+__get_cpuid_max(unsigned int e, unsigned int *s)
+{
+ uint32_t cpuinfo[4];
+
+ __cpuid(cpuinfo, e);
+ if (s)
+ *s = cpuinfo[1];
+ return cpuinfo[0];
+}
+#endif
+
uint64_t
get_tsc_freq_arch(void)
{
+#ifdef RTE_TOOLCHAIN_MSVC
+ int cpuinfo[4];
+#endif
uint64_t tsc_hz = 0;
uint32_t a, b, c, d, maxleaf;
uint8_t mult, model;
@@ -97,14 +117,30 @@
maxleaf = __get_cpuid_max(0, NULL);
if (maxleaf >= 0x15) {
+#ifndef RTE_TOOLCHAIN_MSVC
__cpuid(0x15, a, b, c, d);
+#else
+ __cpuid(cpuinfo, 0x15);
+ a = cpuinfo[0];
+ b = cpuinfo[1];
+ c = cpuinfo[2];
+ d = cpuinfo[3];
+#endif
/* EBX : TSC/Crystal ratio, ECX : Crystal Hz */
if (b && c)
return c * (b / a);
}
+#ifndef RTE_TOOLCHAIN_MSVC
__cpuid(0x1, a, b, c, d);
+#else
+ __cpuid(cpuinfo, 0x1);
+ a = cpuinfo[0];
+ b = cpuinfo[1];
+ c = cpuinfo[2];
+ d = cpuinfo[3];
+#endif
model = rte_cpu_get_model(a);
if (check_model_wsm_nhm(model))
@@ -23,9 +23,13 @@ enum rte_hypervisor
if (!rte_cpu_get_flag_enabled(RTE_CPUFLAG_HYPERVISOR))
return RTE_HYPERVISOR_NONE;
+#ifndef RTE_TOOLCHAIN_MSVC
__cpuid(HYPERVISOR_INFO_LEAF,
regs[RTE_REG_EAX], regs[RTE_REG_EBX],
regs[RTE_REG_ECX], regs[RTE_REG_EDX]);
+#else
+ __cpuid(regs, HYPERVISOR_INFO_LEAF);
+#endif
for (reg = 1; reg < 4; reg++)
memcpy(name + (reg - 1) * 4, ®s[reg], 4);
name[12] = '\0';