wok-current rev 23991
syslinux: iso2exe/init loram case
author | Pascal Bellard <pascal.bellard@slitaz.org> |
---|---|
date | Sun Dec 06 10:04:52 2020 +0000 (2020-12-06) |
parents | fb34bff6cff6 |
children | 3d19917d3a03 |
files | linld/stuff/src/pipehole.awk syslinux/stuff/iso2exe/init |
line diff
1.1 --- a/linld/stuff/src/pipehole.awk Sat Dec 05 10:20:07 2020 +0000 1.2 +++ b/linld/stuff/src/pipehole.awk Sun Dec 06 10:04:52 2020 +0000 1.3 @@ -66,17 +66,15 @@ 1.4 if (ishimem == 1) { 1.5 if (/do \{/) ishimem=2 1.6 if (/byte ptr DGROUP:_vcpi,0/) print " mov bx,si" 1.7 - if (/bx,si/ || /push bp/ || /bp,sp/ || /push di/) next 1.8 + if (/bx,si/ || /push bp/ || /bp,sp/ || /push di/ || /push si/) next 1.9 if (/sp,2/) next 1.10 if (/bp\+4/) { 1.11 - print " global load_imagez:near" 1.12 - print "load_imagez:" 1.13 $0=" xchg ax,si" 1.14 } 1.15 } 1.16 if (ishimem == 2) { 1.17 if (/movzx/) print " cwde" 1.18 - if (/bp-2/ || /pop di/) next 1.19 + if (/bp-2/) next 1.20 if (/storepage.bufv/) { 1.21 print " inc ax" 1.22 print " push ax" 1.23 @@ -95,16 +93,14 @@ 1.24 if (isload == 14) { # LOAD.LST 1.25 if (/call/) { 1.26 print " xchg ax,di" 1.27 - print " pop di" 1.28 - print " extrn load_imagez" 1.29 $0=" jmp short load_imagez" 1.30 } 1.31 if (/ret/) isload=0 1.32 if (/pop/ || /ret/ || /push/) next 1.33 } 1.34 if (isload == 13) { # LOAD.LST 1.35 - sub(/push /,"mov ax,") 1.36 - if (/pop/) { isload=3; next } 1.37 + if (/pop/) isload=3 1.38 + if (/push/ || /call/ || /pop/) next 1.39 } 1.40 if (/i\+21\],513$/) isload=11 1.41 if (isload == 12) { # LOAD.LST 1.42 @@ -156,17 +152,24 @@ 1.43 sub(/dx/,"ax") 1.44 } 1.45 } 1.46 - if (/\[0\] = m-\>fallback/) isload=6 1.47 + if (/_version_string,0/) { 1.48 + print " mov ax,si" 1.49 + print " push di" 1.50 + isload=6 1.51 + } 1.52 if (isload == 6) { # LOAD.LST 1.53 - if (/si\+2/) { print " lodsw"; $0=" push di" } 1.54 + if (/si\+2/) { 1.55 + print " cmpsw" 1.56 + next 1.57 + } 1.58 if (/les/) sub(/bx,/,"di,") 1.59 - if (/bx\+4/ || /es:/) next 1.60 + if (/bx\+4/ || /es:/ || /call/ || /pop/ || /ret/) next 1.61 if (/si\+6/) { 1.62 print " movsw" 1.63 print " movsw" 1.64 print " movsw" 1.65 print " movsw" 1.66 - print " pop di" 1.67 + print "load_imagez:" 1.68 next 1.69 } 1.70 } 1.71 @@ -193,14 +196,15 @@ 1.72 } 1.73 if (/void load_initrd\(\)/) isload=3 1.74 if (isload == 3) { # LOAD.LST 1.75 - if(/jmp/) next 1.76 + if (/short @2@198/) sub(/@2@198/,"load_initrd_ret") 1.77 + if( /jmp/) { 1.78 + print "load_initrd_ret:" 1.79 + print " pop si" 1.80 + print " ret" 1.81 + next 1.82 + } 1.83 sub(/\[di/,"[bx") 1.84 sub(/\di,/,"bx,") 1.85 - if (/@puts\$qpxzc/) { 1.86 - if (hold == 3) { print s; hold=0 } 1.87 - print " pop si" 1.88 - sub(/call/,"jmp") 1.89 - } 1.90 } 1.91 if (/vid_mode = vid_mode/) isload=2 1.92 if (isload == 2) { # LOAD.LST
2.1 --- a/syslinux/stuff/iso2exe/init Sat Dec 05 10:20:07 2020 +0000 2.2 +++ b/syslinux/stuff/iso2exe/init Sun Dec 06 10:04:52 2020 +0000 2.3 @@ -123,6 +123,7 @@ 2.4 xhascustomconf=false 2.5 text() 2.6 { 2.7 + [ -d /etc/skel ] || $uncpio $(ls -r $media/boot/rootfs?*.* | sed q) 2.8 init= 2.9 cmdline="$(cat /proc/cmdline)" 2.10 if $xhascustomconf 2> /dev/null; then