cpu: convert CPU type enum to sequential

This commit is contained in:
David Hrdlička
2020-12-16 20:33:24 +01:00
parent 53144ed8ec
commit 7e6df1f45c
2 changed files with 58 additions and 58 deletions

View File

@@ -375,40 +375,40 @@ cpu_is_eligible(const cpu_family_t *cpu_family, int cpu, int machine)
if (cpu_s->cpu_flags & CPU_FIXED_MULTIPLIER) { if (cpu_s->cpu_flags & CPU_FIXED_MULTIPLIER) {
return 1; /* don't care about multiplier compatibility on fixed multiplier CPUs */ return 1; /* don't care about multiplier compatibility on fixed multiplier CPUs */
} else if (cpu_family->package & CPU_PKG_SOCKET5_7) { } else if (cpu_family->package & CPU_PKG_SOCKET5_7) {
if ((multi == 1.5) && (cpu_s->cpu_type & CPU_5K86) && (machine_s->cpu_min_multi > 1.5)) /* K5 5k86 */ if ((multi == 1.5) && (cpu_s->cpu_type == CPU_5K86) && (machine_s->cpu_min_multi > 1.5)) /* K5 5k86 */
multi = 2.0; multi = 2.0;
else if (multi == 1.75) /* K5 5k86 */ else if (multi == 1.75) /* K5 5k86 */
multi = 2.5; multi = 2.5;
else if (multi == 2.0) { else if (multi == 2.0) {
if (cpu_s->cpu_type & CPU_5K86) /* K5 5k86 */ if (cpu_s->cpu_type == CPU_5K86) /* K5 5k86 */
multi = 3.0; multi = 3.0;
else if (cpu_s->cpu_type & (CPU_K6_2P | CPU_K6_3P)) /* K6-2+ / K6-3+ */ else if (cpu_s->cpu_type == CPU_K6_2P || cpu_s->cpu_type == CPU_K6_3P) /* K6-2+ / K6-3+ */
multi = 2.5; multi = 2.5;
else if ((cpu_s->cpu_type & (CPU_WINCHIP | CPU_WINCHIP2)) && (machine_s->cpu_min_multi > 2.0)) /* WinChip (2) */ else if ((cpu_s->cpu_type == CPU_WINCHIP || cpu_s->cpu_type == CPU_WINCHIP2) && (machine_s->cpu_min_multi > 2.0)) /* WinChip (2) */
multi = 2.5; multi = 2.5;
} }
else if (multi == (7.0 / 3.0)) /* WinChip 2A - 2.33x */ else if (multi == (7.0 / 3.0)) /* WinChip 2A - 2.33x */
multi = 5.0; multi = 5.0;
else if (multi == (8.0 / 3.0)) /* WinChip 2A - 2.66x */ else if (multi == (8.0 / 3.0)) /* WinChip 2A - 2.66x */
multi = 5.5; multi = 5.5;
else if ((multi == 3.0) && (cpu_s->cpu_type & (CPU_Cx6x86 | CPU_Cx6x86L))) /* 6x86(L) */ else if ((multi == 3.0) && (cpu_s->cpu_type == CPU_Cx6x86 || cpu_s->cpu_type == CPU_Cx6x86L)) /* 6x86(L) */
multi = 1.5; multi = 1.5;
else if (multi == (10.0 / 3.0)) /* WinChip 2A - 3.33x */ else if (multi == (10.0 / 3.0)) /* WinChip 2A - 3.33x */
multi = 2.0; multi = 2.0;
else if ((multi == 3.5) && (machine_s->cpu_min_multi < 3.5)) /* standard set by the Pentium MMX */ else if ((multi == 3.5) && (machine_s->cpu_min_multi < 3.5)) /* standard set by the Pentium MMX */
multi = 1.5; multi = 1.5;
else if (multi == 4.0) { else if (multi == 4.0) {
if (cpu_s->cpu_type & (CPU_WINCHIP | CPU_WINCHIP2)) { /* WinChip (2) */ if (cpu_s->cpu_type == CPU_WINCHIP || cpu_s->cpu_type == CPU_WINCHIP2) { /* WinChip (2) */
if (machine_s->cpu_min_multi >= 1.5) if (machine_s->cpu_min_multi >= 1.5)
multi = 1.5; multi = 1.5;
else if (machine_s->cpu_min_multi >= 3.5) else if (machine_s->cpu_min_multi >= 3.5)
multi = 3.5; multi = 3.5;
else if (machine_s->cpu_min_multi >= 4.5) else if (machine_s->cpu_min_multi >= 4.5)
multi = 4.5; multi = 4.5;
} else if (cpu_s->cpu_type & (CPU_Cx6x86 | CPU_Cx6x86L)) /* 6x86(L) */ } else if (cpu_s->cpu_type == CPU_Cx6x86 || cpu_s->cpu_type == CPU_Cx6x86L) /* 6x86(L) */
multi = 3.0; multi = 3.0;
} }
else if ((multi == 5.0) && (cpu_s->cpu_type & (CPU_WINCHIP | CPU_WINCHIP2)) && (machine_s->cpu_min_multi > 5.0)) /* WinChip (2) */ else if ((multi == 5.0) && (cpu_s->cpu_type == CPU_WINCHIP || cpu_s->cpu_type == CPU_WINCHIP2) && (machine_s->cpu_min_multi > 5.0)) /* WinChip (2) */
multi = 5.5; multi = 5.5;
else if ((multi == 6.0) && (machine_s->cpu_max_multi < 6.0)) /* K6-2(+) / K6-3(+) */ else if ((multi == 6.0) && (machine_s->cpu_max_multi < 6.0)) /* K6-2(+) / K6-3(+) */
multi = 2.0; multi = 2.0;

View File

@@ -32,58 +32,58 @@ enum {
}; };
enum { enum {
CPU_8088 = (1ULL << 0), /* 808x class CPUs */ CPU_8088, /* 808x class CPUs */
CPU_8086 = (1ULL << 1), CPU_8086,
#ifdef USE_NEC_808X #ifdef USE_NEC_808X
CPU_V20 = (1ULL << 2), /* NEC 808x class CPUs - future proofing */ CPU_V20, /* NEC 808x class CPUs - future proofing */
CPU_V30 = (1ULL << 3), CPU_V30,
#endif #endif
CPU_286 = (1ULL << 4), /* 286 class CPUs */ CPU_286, /* 286 class CPUs */
CPU_386SX = (1ULL << 5), /* 386 class CPUs */ CPU_386SX, /* 386 class CPUs */
CPU_386DX = (1ULL << 6), CPU_386DX,
CPU_IBM386SLC = (1ULL << 7), CPU_IBM386SLC,
CPU_IBM486SLC = (1ULL << 8), CPU_IBM486SLC,
CPU_IBM486BL = (1ULL << 9), CPU_IBM486BL,
CPU_RAPIDCAD = (1ULL << 10), CPU_RAPIDCAD,
CPU_486SLC = (1ULL << 11), CPU_486SLC,
CPU_486DLC = (1ULL << 12), CPU_486DLC,
CPU_i486SX = (1ULL << 13), /* 486 class CPUs */ CPU_i486SX, /* 486 class CPUs */
CPU_Am486SX = (1ULL << 14), CPU_Am486SX,
CPU_Cx486S = (1ULL << 15), CPU_Cx486S,
CPU_i486SX2 = (1ULL << 16), CPU_i486SX2,
CPU_Am486SX2 = (1ULL << 17), CPU_Am486SX2,
CPU_i486DX = (1ULL << 18), CPU_i486DX,
CPU_i486DX2 = (1ULL << 19), CPU_i486DX2,
CPU_Am486DX = (1ULL << 20), CPU_Am486DX,
CPU_Am486DX2 = (1ULL << 21), CPU_Am486DX2,
CPU_Cx486DX = (1ULL << 22), CPU_Cx486DX,
CPU_Cx486DX2 = (1ULL << 23), CPU_Cx486DX2,
CPU_iDX4 = (1ULL << 24), CPU_iDX4,
CPU_Am486DX4 = (1ULL << 25), CPU_Am486DX4,
CPU_Cx486DX4 = (1ULL << 26), CPU_Cx486DX4,
CPU_Am5x86 = (1ULL << 27), CPU_Am5x86,
CPU_Cx5x86 = (1ULL << 28), CPU_Cx5x86,
CPU_P24T = (1ULL << 29), CPU_P24T,
CPU_WINCHIP = (1ULL << 30), /* 586 class CPUs */ CPU_WINCHIP, /* 586 class CPUs */
CPU_WINCHIP2 = (1ULL << 31), CPU_WINCHIP2,
CPU_PENTIUM = (1ULL << 32), CPU_PENTIUM,
CPU_PENTIUMMMX = (1ULL << 33), CPU_PENTIUMMMX,
CPU_Cx6x86 = (1ULL << 34), CPU_Cx6x86,
CPU_Cx6x86MX = (1ULL << 35), CPU_Cx6x86MX,
CPU_Cx6x86L = (1ULL << 36), CPU_Cx6x86L,
CPU_CxGX1 = (1ULL << 37), CPU_CxGX1,
CPU_K5 = (1ULL << 38), CPU_K5,
CPU_5K86 = (1ULL << 39), CPU_5K86,
CPU_K6 = (1ULL << 40), CPU_K6,
CPU_K6_2 = (1ULL << 41), CPU_K6_2,
CPU_K6_2C = (1ULL << 42), CPU_K6_2C,
CPU_K6_3 = (1ULL << 43), CPU_K6_3,
CPU_K6_2P = (1ULL << 44), CPU_K6_2P,
CPU_K6_3P = (1ULL << 45), CPU_K6_3P,
CPU_CYRIX3S = (1ULL << 46), CPU_CYRIX3S,
CPU_PENTIUMPRO = (1ULL << 47), /* 686 class CPUs */ CPU_PENTIUMPRO, /* 686 class CPUs */
CPU_PENTIUM2 = (1ULL << 48), CPU_PENTIUM2,
CPU_PENTIUM2D = (1ULL << 49) CPU_PENTIUM2D
}; };
enum { enum {