|
@@ -19,8 +19,8 @@ cpuid(unsigned int op, unsigned int *a, unsigned int *b, unsigned int *c,
|
|
|
: "a" (op));
|
|
|
}
|
|
|
|
|
|
-int
|
|
|
-get_cpuid(char *buffer, size_t sz)
|
|
|
+static int
|
|
|
+__get_cpuid(char *buffer, size_t sz, const char *fmt)
|
|
|
{
|
|
|
unsigned int a, b, c, d, lvl;
|
|
|
int family = -1, model = -1, step = -1;
|
|
@@ -48,7 +48,7 @@ get_cpuid(char *buffer, size_t sz)
|
|
|
if (family >= 0x6)
|
|
|
model += ((a >> 16) & 0xf) << 4;
|
|
|
}
|
|
|
- nb = scnprintf(buffer, sz, "%s,%u,%u,%u$", vendor, family, model, step);
|
|
|
+ nb = scnprintf(buffer, sz, fmt, vendor, family, model, step);
|
|
|
|
|
|
/* look for end marker to ensure the entire data fit */
|
|
|
if (strchr(buffer, '$')) {
|
|
@@ -57,3 +57,21 @@ get_cpuid(char *buffer, size_t sz)
|
|
|
}
|
|
|
return -1;
|
|
|
}
|
|
|
+
|
|
|
+int
|
|
|
+get_cpuid(char *buffer, size_t sz)
|
|
|
+{
|
|
|
+ return __get_cpuid(buffer, sz, "%s,%u,%u,%u$");
|
|
|
+}
|
|
|
+
|
|
|
+char *
|
|
|
+get_cpuid_str(void)
|
|
|
+{
|
|
|
+ char *buf = malloc(128);
|
|
|
+
|
|
|
+ if (__get_cpuid(buf, 128, "%s-%u-%X$") < 0) {
|
|
|
+ free(buf);
|
|
|
+ return NULL;
|
|
|
+ }
|
|
|
+ return buf;
|
|
|
+}
|