mirror of
https://github.com/anrieff/libcpuid
synced 2025-01-23 20:06:41 +00:00
check-consistency: fix processor definitions checks
Processor definitions checks were not working due to old harcoded values. The tool pointed a typo in codename for "Athlon 64 (Sherman/512K)".
This commit is contained in:
parent
1ac6898da0
commit
0dae8b8d92
3 changed files with 13 additions and 6 deletions
|
@ -147,6 +147,9 @@ cache_exp = re.compile(".*([\(/ ][0-9]+K).*")
|
|||
# Check whether CPU codenames for consistency:
|
||||
# - Codenames should not exceed 31 characters
|
||||
# - Check for common typos
|
||||
definitions = 0
|
||||
match_entry_fields = 12 # this number needs to change if the definition of match_entry_t ever changes
|
||||
codename_str_max = 64-1 # this number needs to change if the value of CODENAME_STR_MAX ever changes
|
||||
common_cache_sizes = ["8", "16", "32", "64", "128", "256", "512", "1024", "2048", "3072", "4096", "6144", "8192", "12288", "16384"]
|
||||
for fn in glob.glob("%s/*.c" % sys.argv[1]):
|
||||
bfn = os.path.basename(fn)
|
||||
|
@ -167,18 +170,18 @@ for fn in glob.glob("%s/*.c" % sys.argv[1]):
|
|||
continue
|
||||
inner = line[i+1:j]
|
||||
parts = inner.split(",")
|
||||
if len(parts) == 11: #this number needs to change if the definition of match_entry_t ever changes
|
||||
if len(parts) == match_entry_fields:
|
||||
cdefs += 1
|
||||
s = parts[10].strip()
|
||||
s = parts[match_entry_fields-1].strip()
|
||||
if s[0] != '"' or s[-1] != '"':
|
||||
err += 1
|
||||
print("..Warning, %s:%d - cannot correctly handle the cpu codename" % (bfn, nline))
|
||||
allok = False
|
||||
continue
|
||||
s = s[1:-1]
|
||||
if len(s) > 31:
|
||||
if len(s) > codename_str_max:
|
||||
err += 1
|
||||
print("..%s:%d - codename (%s) is longer than 31 characters!" % (bfn, nline, s))
|
||||
print("..%s:%d - codename (%s) is longer than %d characters!" % (bfn, nline, s, codename_str_max))
|
||||
allok = False
|
||||
if cache_exp.match(s):
|
||||
cache_size = cache_exp.findall(s)[0][1:-1]
|
||||
|
@ -187,11 +190,15 @@ for fn in glob.glob("%s/*.c" % sys.argv[1]):
|
|||
print("..Warning, %s:%d - suspicious cache size in codename [%s] (%s)" % (bfn, nline, s, cache_size))
|
||||
allok = False
|
||||
if cdefs:
|
||||
definitions += 1
|
||||
print(" %s: %d processor definitions," % (bfn, cdefs), end=' ')
|
||||
if allok:
|
||||
print("all OK")
|
||||
else:
|
||||
print("some errors/warnings")
|
||||
f.close()
|
||||
if definitions == 0:
|
||||
err += 1
|
||||
print("..Warning, no processor definitions found")
|
||||
|
||||
sys.exit(err)
|
||||
|
|
|
@ -176,7 +176,7 @@ const struct match_entry_t cpudb_amd[] = {
|
|||
{ 15, -1, -1, 15, 0x5f, 1, 256, -1, NC, SEMPRON_ , 0, "Sempron 64 (Manila/256K)" },
|
||||
{ 15, -1, -1, 15, 0x6b, 2, 256, -1, NC, SEMPRON_ , 0, "Sempron 64 Dual (Sherman/256K)"},
|
||||
{ 15, -1, -1, 15, 0x6b, 2, 512, -1, NC, SEMPRON_ , 0, "Sempron 64 Dual (Sherman/512K)"},
|
||||
{ 15, -1, -1, 15, 0x7c, 1, 512, -1, NC, ATHLON_ , 0, "Athlon 64 (Sherman/515K)" },
|
||||
{ 15, -1, -1, 15, 0x7c, 1, 512, -1, NC, ATHLON_ , 0, "Athlon 64 (Sherman/512K)" },
|
||||
{ 15, -1, -1, 15, 0x7f, 1, 256, -1, NC, SEMPRON_ , 0, "Sempron 64 (Sparta/256K)" },
|
||||
{ 15, -1, -1, 15, 0x7f, 1, 512, -1, NC, SEMPRON_ , 0, "Sempron 64 (Sparta/512K)" },
|
||||
{ 15, -1, -1, 15, 0x4c, 1, 256, -1, NC, MOBILE_| SEMPRON_ , 0, "Mobile Sempron 64 (Keene/256K)"},
|
||||
|
|
|
@ -110,5 +110,5 @@ general
|
|||
-1
|
||||
-1
|
||||
64 (non-authoritative)
|
||||
Athlon 64 (Sherman/515K)
|
||||
Athlon 64 (Sherman/512K)
|
||||
fpu vme de pse tsc msr pae mce cx8 apic mtrr sep pge mca cmov pat pse36 clflush mmx fxsr sse sse2 pni cx16 syscall mmxext 3dnow 3dnowext nx fxsr_opt rdtscp lm lahf_lm svm 3dnowprefetch ts fid vid ttp tm_amd stc 100mhzsteps
|
||||
|
|
Loading…
Reference in a new issue