wok-current rev 21750

tazboot: shrink
author Pascal Bellard <pascal.bellard@slitaz.org>
date Sat Jun 15 16:18:19 2019 +0200 (2019-06-15)
parents 3d14781acd29
children 74a62a08433a
files linld/stuff/src/ISO9660.CPP linld/stuff/src/TAZBOOT.CPP linld/stuff/src/pipehole.awk
line diff
     1.1 --- a/linld/stuff/src/ISO9660.CPP	Fri Jun 14 17:38:01 2019 +0100
     1.2 +++ b/linld/stuff/src/ISO9660.CPP	Sat Jun 15 16:18:19 2019 +0200
     1.3 @@ -122,8 +122,7 @@
     1.4    next:
     1.5  	name = s;
     1.6  	do s++; while (*s != '/' && *s);
     1.7 -	c = *s;
     1.8 -	*s = 0;
     1.9 +	c = *s; *s = 0;
    1.10  	for (x->curdirsize = 0xFFFF; isoreaddir() != -1;) {
    1.11  		const char *n = name;
    1.12  #define i (x->tmp)
     2.1 --- a/linld/stuff/src/TAZBOOT.CPP	Fri Jun 14 17:38:01 2019 +0100
     2.2 +++ b/linld/stuff/src/TAZBOOT.CPP	Sat Jun 15 16:18:19 2019 +0200
     2.3 @@ -19,12 +19,12 @@
     2.4  
     2.5  static void next_chunk(struct image_himem *m)
     2.6  {
     2.7 +	if (m->state >= initrd_state.cnt) return;
     2.8  	struct initrd_info *i = &initrd_state.info[m->state];
     2.9  	m->chunk_size = 0;
    2.10 -	if (m->state >= initrd_state.cnt) return;
    2.11 -	lseekset2(m->fd,&i->ofs);
    2.12  	m->chunk_size = i->size;
    2.13  	m->state++;
    2.14 +	lseekset2(m->fd,&i->ofs);
    2.15  }
    2.16  
    2.17  static u32 isofilesize4round()
    2.18 @@ -35,9 +35,8 @@
    2.19  static void addinitrd()
    2.20  {
    2.21  	u16 *pcnt = &initrd_state.cnt;
    2.22 -	struct initrd_info *i = &initrd_state.info[*pcnt];
    2.23  	if (*pcnt >= MAXINITRD) return;
    2.24 -	++*pcnt;
    2.25 +	struct initrd_info *i = &initrd_state.info[(*pcnt)++];
    2.26  	i->size = isofilesize;
    2.27  	i->ofs = isofileofs;
    2.28  	initrd.size += isofilesize4round();
    2.29 @@ -76,7 +75,7 @@
    2.30  	skip_alloc++;
    2.31  	base_himem = memtop() /2;
    2.32  	//if (base_himem >= _64m) base_himem = _64m;
    2.33 -	if (* ((char *) &base_himem +3) >= 4) base_himem = _64m;
    2.34 +	if (* ((char *) &base_himem +3) >= 4) ((short *)&base_himem)[1] = _64m/_64k;
    2.35  	isoopen("boot") != -1 ||
    2.36  	isoopen("live") != -1 ||	// debian
    2.37  	isoopen("casper") != -1;	// ubuntu
    2.38 @@ -96,8 +95,8 @@
    2.39  			strcpy(fallback, x->filename);
    2.40  		if (strhead(x->filename, "rootfs") == -1
    2.41  			|| c > x->filename[6]) continue;
    2.42 +		c = x->filename[6];
    2.43  		strcpy(rootfs, x->filename);
    2.44 -		c = x->filename[6];
    2.45  	}
    2.46  
    2.47  	strcatb(buf_cmdline,"rw root=/dev/null autologin bootfrom=");
     3.1 --- a/linld/stuff/src/pipehole.awk	Fri Jun 14 17:38:01 2019 +0100
     3.2 +++ b/linld/stuff/src/pipehole.awk	Sat Jun 15 16:18:19 2019 +0200
     3.3 @@ -1,12 +1,20 @@
     3.4 -BEGIN { hold=0; is386=0; isload=0; isiso=0; wascall=0 }
     3.5 +BEGIN { hold=0; is386=0; isload=0; isiso=0; istazboot=0; wascall=0 }
     3.6  function isnum(n) { return match(n,/^[0-9+-]/) }
     3.7  {
     3.8  	sub(/segment word public/,"segment byte public")
     3.9  
    3.10  	if (/^@.*:$/ || /	endp$/) afterjmp=0
    3.11  	if (/dword ptr/) is386=1
    3.12 +	if (/vid_mode = vid_mode/) isload=2
    3.13 +	if (isload == 2) {  # LOAD.LST
    3.14 +		sub(/,0/,""); sub(/cmp	/,"mov	cx,")
    3.15 +		sub(/je/,"jcxz")
    3.16 +		if (/ax,word/) next
    3.17 +		sub(/,ax/,",cx")
    3.18 +		if (/version_string/) isload=0
    3.19 +	}
    3.20  	if (/heap_top = _rm_buf/) isload=1
    3.21 -	if (isload) {  # LOAD.LST
    3.22 +	if (isload == 1) {  # LOAD.LST
    3.23  		if (/mov	al,byte ptr/ && is386) {
    3.24  			print "	movzx	eax,byte ptr [si]"
    3.25  			next
    3.26 @@ -20,13 +28,13 @@
    3.27  		sub(/DGROUP:_isostate\+16/,"[si+16]")
    3.28  		if (/goto restarted/) isiso=0
    3.29  	}
    3.30 -	if (/c = \*s;/) isiso=3
    3.31 -	if (isiso == 3) { # ISO9660.LST
    3.32 +	if (/c = \*s; \*s = 0;/) isiso=3
    3.33 +	if (isiso == 3) { # ISO9660.LST, TAZBOOT.LST
    3.34  		if (/al,byte ptr/) {
    3.35  			print "	mov	al,0"
    3.36  			sub(/mov/,"xchg")
    3.37  		}
    3.38 -		if (/byte ptr \[di\],0/) {
    3.39 +		if (/byte ptr \[.*\],0/) {
    3.40  			isiso=0
    3.41  			next
    3.42  		}
    3.43 @@ -51,6 +59,77 @@
    3.44  		if (/jne	@@0$/) next
    3.45  		if (/jmp	@3@58$/) $0="	je	@3@58"
    3.46  	}
    3.47 +	if (/isoopen\(s\+7\) != -1/) isotazboot=8
    3.48 +	if (isotazboot == 8) { # TAZBOOT.LST
    3.49 +		if (/ax,si/) next
    3.50 +		sub(/ax,ax/,"si,si")
    3.51 +		if (/magic/) isotazboot=0
    3.52 +	}
    3.53 +	if (/\+\+isknoppix/) isotazboot=7
    3.54 +	if (isotazboot == 7) { # TAZBOOT.LST
    3.55 +		if (/al,byte/) sub (/al,byte ptr DGROUP:/,"bx,offset ")
    3.56 +		if (/inc/) sub (/al/,"word ptr [bx]")
    3.57 +		if (/,al/) next
    3.58 +		if (/isokernel/) isotazboot=0
    3.59 +	}
    3.60 +	if (/if \(c\) s\+\+;/) isotazboot=6
    3.61 +	if (isotazboot == 6) { # TAZBOOT.LST
    3.62 +		if (/cmp/) {
    3.63 +			$0="	cmp	al,0"
    3.64 +			isotazboot=0
    3.65 +		}
    3.66 +	}
    3.67 +	if (/initrd_state.info\[m->state\]/) isotazboot=5
    3.68 +	if (isotazboot == 5) { # TAZBOOT.LST
    3.69 +		if (/cx,ax/) $0="	xchg	ax,bx"
    3.70 +		if (/mov	ax,word ptr \[si\]/) $0="	lodsw"
    3.71 +		if (/ax,word ptr \[si\+28\]/) next
    3.72 +		if (/bx,cx/) next
    3.73 +		if (/endp/) isotazboot=0
    3.74 +	}
    3.75 +	if (/0x7FF0/) isotazboot=4
    3.76 +	if (isotazboot == 4) { # TAZBOOT.LST
    3.77 +		if (/ax,word ptr/) {
    3.78 +			print "	mov	ax,32752"
    3.79 +			sub(/mov/,"sub")
    3.80 +		}
    3.81 +		if (/bx,/ || /cx,/ || /dx,/) next
    3.82 +		sub(/,bx/,",0")
    3.83 +		sub(/,cx/,",ax")
    3.84 +		if (/short/) isotazboot=0
    3.85 +	}
    3.86 +	if (/c = x->filename/) isotazboot=3
    3.87 +	if (isotazboot == 3) { # TAZBOOT.LST
    3.88 +		if (/ax,/) $0="	xchg	ax,bx"
    3.89 +		if (/\]$/) next
    3.90 +		if (/@strcpy\$qpxzct1/) isotazboot=0
    3.91 +	}
    3.92 +	if (/memtop/) isotazboot=2
    3.93 +	if (isotazboot == 2) { # TAZBOOT.LST
    3.94 +		if (/DGROUP:_base_himem\+2,dx/) print "	mov	bx,offset _base_himem"
    3.95 +		sub(/DGROUP:_base_himem,/,"[bx],")
    3.96 +		sub(/DGROUP:_base_himem\+2,/,"[bx+2],")
    3.97 +		sub(/DGROUP:_base_himem\+3,/,"[bx+3],")
    3.98 +		if (/ax,word ptr \[bx\+2\]/ || /\[bp-4\],ax/) sub(/ax/,"bx")
    3.99 +		if (/bx,ax/) next
   3.100 +		if (/@strcmp\$qpxzct1/) isotazboot=0
   3.101 +	}
   3.102 +	if (/static void addinitrd/) isotazboot=1
   3.103 +	if (isotazboot == 1 || isotazboot == 100) { # TAZBOOT.LST
   3.104 +		if (/m->next_chunk = next_chunk/) isotazboot=100
   3.105 +		if (/load_initrd/) isotazboot=1
   3.106 +		if (/push	si/ && isotazboot == 1) next
   3.107 +		if (/pop	si/) next
   3.108 +		sub(/\[si\]/,"[bx]")
   3.109 +		sub(/si,/,"bx,")
   3.110 +		sub(/si\+/,"bx+")
   3.111 +		if (/mov	cx,ax/) $0="	xchg	ax,bx"
   3.112 +		if (/bx,cx/) next
   3.113 +		sub(/cx/,"bx")
   3.114 +		sub(/DGROUP:_imgs\+38/,"[bx+38]")
   3.115 +		sub(/DGROUP:_imgs\+40/,"[bx+40]")
   3.116 +		if (/static void bootiso/) isotazboot=0
   3.117 +	}
   3.118  	if (wascall) {
   3.119  		if (rcall != "") {
   3.120  			if (/,ax$/) 	print "	mov	" rcall ",ax"