wok rev 24067
linld: add cpu detection
author | Pascal Bellard <pascal.bellard@slitaz.org> |
---|---|
date | Mon Jul 05 15:05:16 2021 +0000 (2021-07-05) |
parents | 68cf96abc146 |
children | ef1efd2c8811 |
files | linld/stuff/src/COMMON.H linld/stuff/src/CRTL.ASM linld/stuff/src/JUMP.ASM linld/stuff/src/LINLD.CPP linld/stuff/src/VCPI.ASM linld/stuff/src/_BEG.ASM linld/stuff/src/pipehole.awk |
line diff
1.1 --- a/linld/stuff/src/COMMON.H Mon Jul 05 15:00:07 2021 +0000 1.2 +++ b/linld/stuff/src/COMMON.H Mon Jul 05 15:05:16 2021 +0000 1.3 @@ -16,6 +16,7 @@ 1.4 #define LINUX001 linux 0.01 support 1.5 #define ELKS elks support 1.6 #define IPXE ipxe support 1.7 +#define CPUTYPE detect cpu family and model 1.8 /* End of the optional features */ 1.9 1.10 #ifdef ISOHOOK 1.11 @@ -108,12 +109,21 @@ 1.12 #define vid_mode (cmdnum[1]) // -3 = ask, -2 = Extended VGA, -1 = Normal VGA, n = as "n" was pressed 1.13 #define topmem (cmdnum[2]) 1.14 #define base_himem (cmdnum[3]) 1.15 +#ifdef CPUTYPE 1.16 +#define skip_alloc (* (char *) &cmdnum[5]) 1.17 +#define mincpu (* (short *) &cmdnum[6]) 1.18 +extern unsigned cputype; 1.19 +#else 1.20 #define skip_alloc (* (char *) &cmdnum[4]) 1.21 +#endif 1.22 +extern u32 cmdnum[5 1.23 +#ifdef CPUTYPE 1.24 + +1 1.25 +#endif 1.26 #ifdef QUICK_BOOT 1.27 -extern u32 cmdnum[7]; 1.28 -#else 1.29 -extern u32 cmdnum[5]; 1.30 + +2 1.31 #endif 1.32 + ]; 1.33 1.34 extern _fastcall void memcpy_image_kernel(); 1.35 extern _fastcall void memcpy_image_initrd();
2.1 --- a/linld/stuff/src/CRTL.ASM Mon Jul 05 15:00:07 2021 +0000 2.2 +++ b/linld/stuff/src/CRTL.ASM Mon Jul 05 15:05:16 2021 +0000 2.3 @@ -952,8 +952,8 @@ 2.4 dec bx 2.5 sub di,dx 2.6 @@loop: 2.7 + add di,dx 2.8 mov si,cx ; s 2.9 - add di,dx 2.10 @@match: 2.11 lodsb ; *s++ 2.12 or al,20h ; locase 2.13 @@ -969,12 +969,13 @@ 2.14 cmp [byte bx],'|' 2.15 je @@testal 2.16 jl @@notsw ; } ~ <del> 2.17 + ;mov dl,1 2.18 cmp al,20h ; EOS or 20h 2.19 jne @@loop ; assume [bx] = '|' 2.20 @@notsw: 2.21 mov al,-1 2.22 jne @@notopt 2.23 - jmp @@setnum 2.24 + jmp @@setnum2 2.25 @@testal: 2.26 cmp al,-1 2.27 jz @@loop 2.28 @@ -1044,10 +1045,11 @@ 2.29 endif 2.30 @@end: 2.31 @@setnum: 2.32 + mov [di+2],dx 2.33 +@@setnum2: 2.34 xchg ax,si 2.35 - mov [di+2],dx 2.36 @@done: 2.37 - mov [di],si 2.38 + or [di],si 2.39 xchg ax,di 2.40 @@nokeyword: 2.41 pop di si bx
3.1 --- a/linld/stuff/src/JUMP.ASM Mon Jul 05 15:00:07 2021 +0000 3.2 +++ b/linld/stuff/src/JUMP.ASM Mon Jul 05 15:05:16 2021 +0000 3.3 @@ -25,36 +25,40 @@ 3.4 ;*************************************************************** 3.5 3.6 macro dos_shutdown 3.7 - xor si,si 3.8 + xor bx,bx 3.9 ifdef QUICK_BOOT 3.10 extrn _cmdnum:dword 3.11 -quickboot = (word _cmdnum+20) 3.12 - cmp si,[quickboot] 3.13 - mov ds,si 3.14 + ifdef CPUTYPE 3.15 +quickboot = (byte _cmdnum+24) 3.16 + else 3.17 +quickboot = (byte _cmdnum+20) 3.18 + endif 3.19 + cmp bl,[quickboot] 3.20 + mov ds,bx 3.21 jne skip_shutdown 3.22 else 3.23 - mov ds,si 3.24 + mov ds,bx 3.25 endif 3.26 ifndef NO386 3.27 - push [dword si+4] ; save step 3.28 - mov [word si+4],offset step19 3.29 + push [dword bx+4] ; save step 3.30 + mov [word bx+4],offset step19 3.31 else 3.32 mov ax,offset step19 3.33 - xchg ax,[word si+4] 3.34 - push [word si+6] 3.35 + xchg ax,[word bx+4] 3.36 + push [word bx+6] 3.37 push ax ; save step 3.38 endif 3.39 mov [word cs:sssp],sp 3.40 - ;cmp [byte si+7],0F0h 3.41 + ;cmp [byte bx+7],0F0h 3.42 ;jnc notdos 3.43 - mov [si+6],cs 3.44 + mov [bx+6],cs 3.45 pushf 3.46 pushf 3.47 pop ax 3.48 inc ah ; set TF 3.49 push ax 3.50 popf 3.51 - call [dword si+4*19h] 3.52 + call [dword bx+4*19h] 3.53 notdos: 3.54 ifndef NO386 3.55 lss sp,[dword cs:sssp]
4.1 --- a/linld/stuff/src/LINLD.CPP Mon Jul 05 15:00:07 2021 +0000 4.2 +++ b/linld/stuff/src/LINLD.CPP Mon Jul 05 15:05:16 2021 +0000 4.3 @@ -8,11 +8,6 @@ 4.4 4.5 extern char bzimagestr[]; 4.6 const char* cmdstr[4] = {"auto",bzimagestr,NULL,NULL}; 4.7 -#ifdef QUICK_BOOT 4.8 -extern u32 cmdnum[7]; 4.9 -#else 4.10 -extern u32 cmdnum[5]; 4.11 -#endif 4.12 4.13 inline void syntax() { 4.14 die("Syntax:" NL 4.15 @@ -22,8 +17,8 @@ 4.16 #endif 4.17 "..." NL 4.18 "vga mode: ask,extended,normal or dec/oct/hex number" NL 4.19 -#ifdef CPU32 4.20 - "-32 for 386+" NL 4.21 +#ifdef CPUTYPE 4.22 + "-m mincpu family*256+model" NL 4.23 #endif 4.24 #ifdef CPU64 4.25 "-64 for cpu64 only" NL 4.26 @@ -40,6 +35,9 @@ 4.27 NL NL "Examples:" NL 4.28 "\tLINLD " 4.29 "-b 64m " 4.30 +#ifdef CPUTYPE 4.31 + "-m 0x600 " 4.32 +#endif 4.33 "initrd=rootfs4.gz,rootfs3.gz,rootfs2.gz,rootfs1.gz " 4.34 "\"cl=root=/dev/null video=-32\"" 4.35 NL "\tLINLD memtest" 4.36 @@ -58,12 +56,6 @@ 4.37 if (!*++argv) syntax(); 4.38 const char **clp = &cmdline; 4.39 do { 4.40 -#ifdef CPU32 4.41 - if ((*(u16 *)*argv|2) == 0x332F) { // -32 /32 4.42 - extrn char cpu386; 4.43 - if (cpu386 == 0) exit(); 4.44 - } 4.45 -#endif 4.46 #ifdef CPU64 4.47 if ((*(u16 *)*argv|2) == 0x362F) { // -64 /64 4.48 if (cpuhaslm() == 0) exit(); 4.49 @@ -74,11 +66,15 @@ 4.50 #else 4.51 if (argstr(*argv,"cl|image|initrd",clp) == (int) clp) continue; 4.52 #endif 4.53 + if (argnum(*argv,"root|vga|mem|-b|" 4.54 +#ifdef CPUTYPE 4.55 + "-m|" 4.56 +#endif 4.57 + "-f~" 4.58 #ifdef QUICK_BOOT 4.59 - if (argnum(*argv,"root|vga|mem|-b|-f~-q~-v~",&root_dev) >= (int) &base_himem) continue; 4.60 -#else 4.61 - if (argnum(*argv,"root|vga|mem|-b|-f~",&root_dev) >= (int) &base_himem) continue; 4.62 + "-q~-v~" 4.63 #endif 4.64 + ,&root_dev) >= (int) &base_himem) continue; 4.65 if (fileexist(*argv) != -1) { 4.66 kernel_name=*argv; 4.67 continue; 4.68 @@ -86,6 +82,9 @@ 4.69 *clp = (const char *) heap_top +1; 4.70 strcatb((const char *) heap_top,*argv); 4.71 } while (*++argv); 4.72 +#ifdef CPUTYPE 4.73 + if (mincpu > cputype) exit(); 4.74 +#endif 4.75 puts(*clp); 4.76 asm{ 4.77 xchg ax,bx
5.1 --- a/linld/stuff/src/VCPI.ASM Mon Jul 05 15:00:07 2021 +0000 5.2 +++ b/linld/stuff/src/VCPI.ASM Mon Jul 05 15:05:16 2021 +0000 5.3 @@ -351,7 +351,11 @@ 5.4 ;mov [bx+2],ss 5.5 ifdef QUICK_BOOT 5.6 extrn _cmdnum:dword 5.7 + ifdef CPUTYPE 5.8 +v86boot = (byte _cmdnum+28) 5.9 + else 5.10 v86boot = (byte _cmdnum+24) 5.11 + endif 5.12 test [v86boot],bh 5.13 jnz @vm2rm_ret 5.14 endif
6.1 --- a/linld/stuff/src/_BEG.ASM Mon Jul 05 15:00:07 2021 +0000 6.2 +++ b/linld/stuff/src/_BEG.ASM Mon Jul 05 15:05:16 2021 +0000 6.3 @@ -11,10 +11,12 @@ 6.4 include "himem.inc" 6.5 include "isostate.inc" 6.6 6.7 +CMDNUMCNT = 5 6.8 + ifdef CPUTYPE 6.9 +CMDNUMCNT = CMDNUMCNT+1 6.10 + endif 6.11 ifdef QUICK_BOOT 6.12 -CMDNUMCNT = 7 6.13 - else 6.14 -CMDNUMCNT = 5 6.15 +CMDNUMCNT = CMDNUMCNT+2 6.16 endif 6.17 6.18 macro alloc_isostate 6.19 @@ -78,6 +80,10 @@ 6.20 ;global _bss_start:byte 6.21 label _bss_start byte 6.22 global stktop:byte 6.23 + ifdef CPUTYPE 6.24 + global _cputype:word 6.25 +_cputype dw ? 6.26 + endif 6.27 global _cpu386:byte 6.28 _cpu386 db ? 6.29 ifdef CPU64 6.30 @@ -133,6 +139,13 @@ 6.31 ;*************************************************************** 6.32 6.33 ; Check for oldies 6.34 + ifndef NO386 6.35 + ifdef CPUTYPE 6.36 + mov ax,100h 6.37 + mov cl,32 ; 186+ masks with 31 6.38 + shr ax,cl 6.39 + endif 6.40 + endif 6.41 push bx ; < 286 : flags[12..15] are forced 1 6.42 popf ; = 286 : flags[12..15] are forced 0, cld, cli 6.43 pushf ; > 286 : only flags[15] is forced 0 6.44 @@ -142,8 +155,15 @@ 6.45 mov bx,offset msg_badcpu 6.46 js godie ;it is not a 386+, die 6.47 else 6.48 + ifdef CPUTYPE 6.49 + jc not286 6.50 + mov ah,2 6.51 +not286: 6.52 + js jmp_endcpu86 ;it is not a 386+, try ELKS & co 6.53 + else 6.54 js endcpu86 ;it is not a 386+, try ELKS & co 6.55 endif 6.56 + endif 6.57 p386 6.58 ifdef VCPI 6.59 mov edx,cs 6.60 @@ -176,6 +196,7 @@ 6.61 godie: 6.62 call near die 6.63 else 6.64 +jmp_endcpu86: 6.65 jmp endcpu86 6.66 endif 6.67 6.68 @@ -219,7 +240,11 @@ 6.69 pushfd 6.70 pop dx 6.71 pop ax 6.72 + ifdef CPUTYPE 6.73 + xor al,24h ; toggle CPUID feature bit & AC bit 6.74 + else 6.75 xor al,20h ; toggle CPUID feature bit 21 (=> pentium+) 6.76 + endif 6.77 push ax ; (toggle AC: bit 18 => 486+) 6.78 push dx 6.79 popfd 6.80 @@ -227,9 +252,47 @@ 6.81 pop dx 6.82 pop dx 6.83 xor al,dl ; clear C 6.84 + ifdef CPUTYPE 6.85 + cmp al,20h 6.86 + mov ax,0400h 6.87 + je is486 6.88 + mov ah,3 6.89 +is486: 6.90 + jae set_cputype 6.91 + xor eax,eax 6.92 + inc ax 6.93 + cpuid ; Basic cpuid (late 486 or Pentium) 6.94 + xor eax,eax 6.95 + inc ax 6.96 + cpuid ; again cause of Nasty EMM386s 6.97 + push eax 6.98 + bt edx,26 ; sse2 bit 6.99 + jnc baseInfo 6.100 + else 6.101 jne @@no_cpuid ; CPUID feature bit changed ? 6.102 - mov eax,80000001h ; Extended Processor Info and Feature Bits 6.103 - cpuid 6.104 + endif 6.105 + mov eax,80000001h ; Extended Processor Info and Feature Bits (Pentium 4 or newer) 6.106 + cpuid ; Extended cpuid (Pentium 4) 6.107 + ifdef CPUTYPE 6.108 +baseInfo: 6.109 + pop ax ; base IDs 6.110 + and ax,0FF0h ; keep FamilyID & ModelID 6.111 + pop cx ; extended IDs 6.112 + mov bx,cx 6.113 + shr bx,4 ; extended FamilyID in bl 6.114 + shr al,4 ; set base ModelID 6.115 + cmp ah,0Fh 6.116 + jz SetModelID 6.117 + cmp ah,06h 6.118 + jnz ModelIDset 6.119 + db 3Dh ; cmp ax,0DC00h 6.120 +SetModelID: 6.121 + add ah,bl ; use extended FamilyID 6.122 + shl cl,4 6.123 + or al,cl ; use extended ModelID 6.124 +ModelIDset: 6.125 +set_cputype: 6.126 + endif 6.127 mov dl,-1 ; set 386 flag 6.128 ifdef NO386 6.129 db 66h ; mov [_cpu_features],edx 6.130 @@ -243,6 +306,9 @@ 6.131 dec [_cpu386] 6.132 endif 6.133 endcpu86: 6.134 + ifdef CPUTYPE 6.135 + mov [_cputype],ax ; _cputype: FFMM or 0[1-4]00=80[1-4]86 or 0000=8086/8088 6.136 + endif 6.137 p8086 6.138 6.139 ;***************************************************************
7.1 --- a/linld/stuff/src/pipehole.awk Mon Jul 05 15:00:07 2021 +0000 7.2 +++ b/linld/stuff/src/pipehole.awk Mon Jul 05 15:05:16 2021 +0000 7.3 @@ -17,6 +17,12 @@ 7.4 if (/add di,2/) $0=" scasw ; " $0 7.5 if (/bx,di/ || /\[bp-2\]/) next 7.6 sub(/\[bx\],0/,"[di],0") 7.7 + if (/ptr @exit\$qv/) { 7.8 + if (gotexit) next 7.9 + print "call_exit:" 7.10 + gotexit=1 7.11 + } 7.12 + if (/short @1@422/ && gotexit) $0=" ja call_exit" 7.13 if (islinld==1) { 7.14 if (/,word.*/) islinld=0 7.15 print "; " $0 7.16 @@ -33,7 +39,7 @@ 7.17 print " mov ax,word ptr [di]" 7.18 next 7.19 } 7.20 - if (/ax,word ptr/) next 7.21 + if (/ax,word ptr \[/) next 7.22 } 7.23 if (/buf_cmdline\+1/) { 7.24 islinld=5