wok-current rev 23863

syslinux/isoboot.s: accept user args
author Pascal Bellard <pascal.bellard@slitaz.org>
date Fri Jun 19 15:46:21 2020 +0000 (2020-06-19)
parents f17d3e9b8ddc
children 06b9d6e33bee
files linld/stuff/src/!COMPILE.BAT linld/stuff/src/ISO9660.CPP linld/stuff/src/ISOCRTL.ASM linld/stuff/src/_ISOBEG.ASM linld/stuff/src/pipehole.awk syslinux/stuff/iso2exe/bootiso.S syslinux/stuff/iso2exe/iso2exe.sh
line diff
     1.1 --- a/linld/stuff/src/!COMPILE.BAT	Fri Jun 19 11:08:54 2020 -0400
     1.2 +++ b/linld/stuff/src/!COMPILE.BAT	Fri Jun 19 15:46:21 2020 +0000
     1.3 @@ -3,16 +3,12 @@
     1.4  tasm /h > helptasm.log
     1.5  bcc > helpbcc.log
     1.6  tlink > helptlink.log
     1.7 -bcc @bccopt.opt -S -mt -DISOHOOK -DMOVE_SETUP -DUSE_ARGSTR -DLARGE_IMAGES *.cpp > cpp.log
     1.8 +bcc @bccopt.opt -S -mt -DMOVE_SETUP -DUSE_ARGSTR -DLARGE_IMAGES *.cpp > cpp.log
     1.9  ren LINLD.ASM LINLD.ASO
    1.10  ren LOAD.ASM LOAD.ASO
    1.11  ren HIMEM.ASM HIMEM.ASO
    1.12 -ren ISO9660.ASM ISO9660.ASO
    1.13  mawk -f pipehole.awk LINLD.ASO > LINLD.ASM
    1.14  mawk -f pipehole.awk LOAD.ASO > LOAD.ASM
    1.15  mawk -f pipehole.awk HIMEM.ASO > HIMEM.ASM
    1.16 -mawk -f pipehole.awk ISO9660.ASO > ISO9660.ASM
    1.17 -tasm /la /m /dISOHOOK /dMOVE_SETUP /dUSE_ARGSTR /dNO386 /dLARGE_IMAGES /dLONG_FILENAME *.asm > asm.log
    1.18 +tasm /la /m /dMOVE_SETUP /dUSE_ARGSTR /dNO386 /dLARGE_IMAGES /dLONG_FILENAME *.asm > asm.log
    1.19  tlink /m /s /t @link.cmd > lnk.log
    1.20 -tlink /m /s /t @link2.cmd > lnk2.log
    1.21 -tlink /m /s /t @header.cmd > header.log
     2.1 --- a/linld/stuff/src/ISO9660.CPP	Fri Jun 19 11:08:54 2020 -0400
     2.2 +++ b/linld/stuff/src/ISO9660.CPP	Fri Jun 19 15:46:21 2020 +0000
     2.3 @@ -11,17 +11,26 @@
     2.4  #define cpydirofs(to,from)	((to) = (from))
     2.5  #endif
     2.6  
     2.7 +#ifdef ISOHOOK
     2.8 +void isoroot(void)
     2.9 +#else
    2.10  int isoroot(void)
    2.11 +#endif
    2.12  {
    2.13  	static const unsigned long root = 16UL * 2048;
    2.14 -	struct isostate *x=&isostate;
    2.15 -	if (isoreadsector(&root) == -1 || strhead(x->buffer+1,"CD001") == -1) {
    2.16 -		//close(x->fd);
    2.17 +#ifdef ISOHOOK
    2.18 +	isoreadsector(&root);
    2.19 +	setdirofs(isostate.dirofs, (* (unsigned long *) (isostate.buffer + 0x9E)));
    2.20 +	isostate.dirsize = filesize2dirsize(* (unsigned long *) (isostate.buffer + 0xA6));
    2.21 +#else
    2.22 +	if (isoreadsector(&root) == -1 || strhead(isostate.buffer+1,"CD001") == -1) {
    2.23 +		//close(isostate.fd);
    2.24  		return -1;
    2.25  	}
    2.26 -	setdirofs(x->dirofs, (* (unsigned long *) (isostate.buffer + 0x9E)));
    2.27 -	x->dirsize = filesize2dirsize(* (unsigned long *) (isostate.buffer + 0xA6));
    2.28 +	setdirofs(isostate.dirofs, (* (unsigned long *) (isostate.buffer + 0x9E)));
    2.29 +	isostate.dirsize = filesize2dirsize(* (unsigned long *) (isostate.buffer + 0xA6));
    2.30  	return 0;
    2.31 +#endif
    2.32  }
    2.33  
    2.34  int isoreaddir(void)
    2.35 @@ -121,6 +130,15 @@
    2.36  	_64bits = cpuhaslm();
    2.37  #endif
    2.38      do {
    2.39 +#ifdef ISOHOOK
    2.40 +	s = (char *) x->filename2open;
    2.41 +	if (*s == '/') {
    2.42 +		s++;
    2.43 +		isoroot();
    2.44 +	}
    2.45 +	name = s;
    2.46 +	while (*++s);
    2.47 +#else
    2.48  	for (s = (char *) x->filename2open; *s == '/' ; s++) {
    2.49  		isoroot();
    2.50  	}
    2.51 @@ -128,6 +146,7 @@
    2.52  	name = s;
    2.53  	do s++; while (*s && *s != '/');
    2.54  	c = *s; *s = 0;
    2.55 +#endif
    2.56  	for (x->curdirsize = 0xFFFF; isoreaddir() != -1;) {
    2.57  		const char *n = name;
    2.58  #define i (x->tmp)
    2.59 @@ -138,11 +157,15 @@
    2.60  			i += s - name; // strlen(name);
    2.61  		}
    2.62  		if (strcmp(i, n)) continue;
    2.63 +#ifndef ISOHOOK
    2.64  		*s++ = c;
    2.65 +#endif
    2.66  		if (IS_DIR(x->filemod)) {
    2.67  			cpydirofs(x->dirofs, x->fileofs);
    2.68  			x->dirsize = filesize2dirsize(x->filesize);
    2.69 +#ifndef ISOHOOK
    2.70  			if (c) goto next;
    2.71 +#endif
    2.72  		}
    2.73  		isolseek(&x->fileofs);
    2.74  		return 0;
     3.1 --- a/linld/stuff/src/ISOCRTL.ASM	Fri Jun 19 11:08:54 2020 -0400
     3.2 +++ b/linld/stuff/src/ISOCRTL.ASM	Fri Jun 19 15:46:21 2020 +0000
     3.3 @@ -23,7 +23,7 @@
     3.4  
     3.5  		public	_isostate
     3.6  _isostate	isostate	<?>
     3.7 -		org	$-7
     3.8 +;		org	$-7
     3.9  
    3.10          ends    _BSS
    3.11  
    3.12 @@ -31,9 +31,14 @@
    3.13  
    3.14  		global	fold:near
    3.15  fold:
    3.16 -		org	0F000h
    3.17 +		org	0EF00h
    3.18  		global	unfold:near
    3.19  unfold:
    3.20 +		jmp	iso_open
    3.21 +		extrn	@isoreaddir$qv
    3.22 +		dw	@isoreaddir$qv
    3.23 +		jmp	@readmenu$qv
    3.24 +
    3.25  		push	dx
    3.26  		call	readfd
    3.27  		push	ds
    3.28 @@ -65,11 +70,8 @@
    3.29  iso_open:
    3.30  		mov	[_isostate.filename2open],ax
    3.31  		call	@_isoopen$qv
    3.32 -		inc	ax
    3.33 -		jnz	open_ok
    3.34 -		dec	ax
    3.35 -		stc
    3.36 -open_ok:
    3.37 +		cmp	ax,1
    3.38 +		cmc
    3.39  		push	bx
    3.40  iso_close_hack:
    3.41  		pop	bx
    3.42 @@ -91,74 +93,12 @@
    3.43  		pop	cx
    3.44  	endm
    3.45  
    3.46 -iso_read_hack:
    3.47 -	ifdef	NO386
    3.48 -		push	dx
    3.49 -		curseek
    3.50 -		mov	bx,[word _isostate.filesize]
    3.51 -		sub	bx,ax
    3.52 -		mov	ax,[(word _isostate.filesize)+2]
    3.53 -		sbb	ax,dx
    3.54 -		ja	@@cxok
    3.55 -		je	@@rem
    3.56 -		xor	cx,cx
    3.57 -@@rem:
    3.58 -		cmp	bx,cx
    3.59 -		ja	@@cxok
    3.60 -		mov	cx,bx
    3.61 -@@cxok:
    3.62 -		pop	dx
    3.63 -	else
    3.64 -                p386
    3.65 -		push	edx
    3.66 -		curseek
    3.67 -		mov	edx,[_isostate.filesize]
    3.68 -		sub	edx,eax
    3.69 -		jnb	@@rem
    3.70 -		xor	cx,cx
    3.71 -@@rem:
    3.72 -		movzx	eax,cx
    3.73 -		cmp	edx,eax
    3.74 -		ja	@@cxok
    3.75 -		mov	cx,dx
    3.76 -@@cxok:
    3.77 -		pop	edx
    3.78 -	endif
    3.79 -		or	cx,cx
    3.80 -		pop	bx
    3.81 -		jmp	readfd
    3.82 +;***************************************************************
    3.83 +;_fastcall void readmenu(void);
    3.84 +;***************************************************************
    3.85 +	global	@readmenu$qv:near
    3.86 +	proc	@readmenu$qv near
    3.87  
    3.88 -iso_lseek_hack:
    3.89 -		xchg	ax,bx
    3.90 -		pop	bx
    3.91 -	ifdef	SEEK_CUR
    3.92 -		cmp	al,1	; current
    3.93 -		jne	@@nocurrent
    3.94 -		call	dosfd		; lseek(,0L,SEEK_CUR)
    3.95 -		jmp	@doseek2
    3.96 -@nocurrent:
    3.97 -	endif
    3.98 -		add	dx,[word _isostate.fileofs]
    3.99 -		adc	cx,[(word _isostate.fileofs)+2]
   3.100 -		cmp	al,0	; start
   3.101 -		je	@@doseek
   3.102 -		add	dx,[word _isostate.filesize]
   3.103 -		adc	cx,[(word _isostate.filesize)+2]
   3.104 -@@doseek:
   3.105 -		call	lseekset	; lseek(,0L,SEEK_SET)
   3.106 -@doseek2:
   3.107 -		sub	ax,[word _isostate.fileofs]
   3.108 -		sbb	dx,[(word _isostate.fileofs)+2]
   3.109 -		ret
   3.110 -
   3.111 -iso_cleanup_hack:
   3.112 -		mov	ah,3Eh		; close file
   3.113 -		jmp	dosfd
   3.114 -
   3.115 -
   3.116 -
   3.117 -		global	@readmenu$qv:near
   3.118 -@readmenu$qv:
   3.119  		mov	dx,18
   3.120  		xor	cx,cx
   3.121  		call	lseekset
   3.122 @@ -167,13 +107,16 @@
   3.123  		call	readfd ; // read x->filemod + x->fileofs & x->filesize
   3.124  		mov	bx,offset _isostate.fileofs
   3.125  		; x->fileofs = 0x7FF0 - (x->filesize &= 0xFFFF);
   3.126 -		and	[word bx+6],0
   3.127  		mov	ax,7FF0h
   3.128 +		cwd
   3.129 +		mov	[word bx+6],dx
   3.130  		sub	ax,[bx+4]
   3.131 -		and	[word bx+2],0
   3.132 +		mov	[word bx+2],dx
   3.133  		mov	[bx],ax
   3.134  		; //magic = x->filemod;
   3.135  
   3.136 +	endp	@readmenu$qv
   3.137 +
   3.138  ;***************************************************************
   3.139  ;_fastcall void isolseek(bx:const unsigned long *offset);
   3.140  ;***************************************************************
   3.141 @@ -260,6 +203,69 @@
   3.142  
   3.143          endp    @strcmp$qpxzct1
   3.144  
   3.145 +iso_read_hack:
   3.146 +	ifdef	NO386
   3.147 +		push	dx
   3.148 +		curseek
   3.149 +		mov	bx,[word _isostate.filesize]
   3.150 +		sub	bx,ax
   3.151 +		mov	ax,[(word _isostate.filesize)+2]
   3.152 +		sbb	ax,dx
   3.153 +		ja	@@cxok
   3.154 +		je	@@rem
   3.155 +		xor	cx,cx
   3.156 +@@rem:
   3.157 +		cmp	bx,cx
   3.158 +		ja	@@cxok
   3.159 +		mov	cx,bx
   3.160 +@@cxok:
   3.161 +		pop	dx
   3.162 +	else
   3.163 +                p386
   3.164 +		push	edx
   3.165 +		curseek
   3.166 +		mov	edx,[_isostate.filesize]
   3.167 +		sub	edx,eax
   3.168 +		jnb	@@rem
   3.169 +		xor	cx,cx
   3.170 +@@rem:
   3.171 +		movzx	eax,cx
   3.172 +		cmp	edx,eax
   3.173 +		ja	@@cxok
   3.174 +		mov	cx,dx
   3.175 +@@cxok:
   3.176 +		pop	edx
   3.177 +	endif
   3.178 +		or	cx,cx
   3.179 +		pop	bx
   3.180 +		jmp	readfd
   3.181 +
   3.182 +iso_lseek_hack:
   3.183 +		xchg	ax,bx
   3.184 +		pop	bx
   3.185 +	ifdef	SEEK_CUR
   3.186 +		cmp	al,1	; current
   3.187 +		jne	@@nocurrent
   3.188 +		call	dosfd		; lseek(,0L,SEEK_CUR)
   3.189 +		jmp	@doseek2
   3.190 +@nocurrent:
   3.191 +	endif
   3.192 +		add	dx,[word _isostate.fileofs]
   3.193 +		adc	cx,[(word _isostate.fileofs)+2]
   3.194 +		cmp	al,0	; start
   3.195 +		je	@@doseek
   3.196 +		add	dx,[word _isostate.filesize]
   3.197 +		adc	cx,[(word _isostate.filesize)+2]
   3.198 +@@doseek:
   3.199 +		call	lseekset	; lseek(,0L,SEEK_SET)
   3.200 +@doseek2:
   3.201 +		sub	ax,[word _isostate.fileofs]
   3.202 +		sbb	dx,[(word _isostate.fileofs)+2]
   3.203 +		ret
   3.204 +
   3.205 +iso_cleanup_hack:
   3.206 +		mov	ah,3Eh		; close file
   3.207 +		jmp	dosfd
   3.208  	ifdef	NO386
   3.209          global  N_LXLSH@ES:near
   3.210  N_LXLSH@ES:
     4.1 --- a/linld/stuff/src/_ISOBEG.ASM	Fri Jun 19 11:08:54 2020 -0400
     4.2 +++ b/linld/stuff/src/_ISOBEG.ASM	Fri Jun 19 15:46:21 2020 +0000
     4.3 @@ -20,15 +20,8 @@
     4.4          ends    _DATA
     4.5  
     4.6          segment _BSS byte public use16 'BSS'
     4.7 -
     4.8          global  _bss_start:byte
     4.9          label   _bss_start byte
    4.10 -utoabuf		db	6 dup(?)
    4.11 -
    4.12 -		include	"isostate.inc"
    4.13 -
    4.14 -		extrn	_isostate:isostate
    4.15 -
    4.16          ends    _BSS
    4.17  
    4.18          segment _TEXT byte public use16 'CODE'
    4.19 @@ -37,205 +30,8 @@
    4.20          global  _text_start:byte
    4.21          label   _text_start byte
    4.22  
    4.23 -		extrn	fold
    4.24 -		extrn	unfold
    4.25 -		mov	si,offset fold
    4.26 -		mov	di,offset unfold
    4.27 -		mov	ch,4
    4.28 -		cld
    4.29 -		rep
    4.30 -		  movsw
    4.31 -
    4.32 -;***************************************************************
    4.33 -; clear bss
    4.34 -;***************************************************************
    4.35 -
    4.36 -		mov	si,offset _bss_start
    4.37 -clearbss:
    4.38 -		mov	[byte si],cl	; clear bss + heap
    4.39 -		inc	si
    4.40 -		jne	clearbss
    4.41 -
    4.42 -;***************************************************************
    4.43 -; build arg
    4.44 -;***************************************************************
    4.45 -
    4.46 -		mov	si,80h
    4.47 -		lodsb
    4.48 -		cbw
    4.49 -		xchg	ax,bx
    4.50 -		mov	[bx+si],bh		; set EOS
    4.51 -searchStart:
    4.52 -		lodsb
    4.53 -		cmp	al,0
    4.54 -		je	_abort
    4.55 -		cmp	al,' '
    4.56 -		je	searchStart
    4.57 -		dec	si
    4.58 -		mov	di,offset filename
    4.59 -		push	di
    4.60 -		mov	ah,60h			; canonicalize filename
    4.61 -                int	21h
    4.62 -		jc	_abort
    4.63 -	ifdef	WITH_LONG_FILENAME
    4.64 -		pop	si
    4.65 -		mov	ax,716Ch
    4.66 -		xor	bx,bx			; R/O
    4.67 -		;xor	cx,cx			; attributes
    4.68 -		cwd				; action = open
    4.69 -		stc
    4.70 -                int	21h
    4.71 -                jnc	opened
    4.72 -                mov	dx,si
    4.73 -	else
    4.74 -		pop	dx
    4.75 -	endif
    4.76 -                mov	ax,3d00h		; read-only+compatibility
    4.77 -		;mov	cl,0			; attribute mask
    4.78 -                int	21h
    4.79 -                jnc	opened
    4.80 -
    4.81 -_abort:
    4.82 -		mov	dx,offset stopmsg
    4.83 -		mov	ah,9
    4.84 -		int	21h
    4.85 -		int	20h
    4.86 -opened:
    4.87 -		mov	[_isostate.fd],ax
    4.88 -		mov	ax,offset bootdir
    4.89 -		extrn	iso_open:near
    4.90 -		call	iso_open
    4.91 -jc_abort:
    4.92 -		jc	_abort
    4.93 -
    4.94 -; patch magic
    4.95 -;***************************************************************
    4.96 -
    4.97 -		extrn	@readmenu$qv:near
    4.98 -		call	@readmenu$qv
    4.99 -		mov	ax,[_isostate.filemod]
   4.100 -		mov	bx,10
   4.101 -		xor	cx,cx
   4.102 -@@loop1:
   4.103 -		xor	dx,dx
   4.104 -		div	bx		; DX:AX = n%10:n/10
   4.105 -		push	dx		; DL = n%10
   4.106 -		inc	cx
   4.107 -		or	ax,ax
   4.108 -		jnz	@@loop1
   4.109 -		push	ds
   4.110 -		pop	es
   4.111 -		mov	di,offset magic
   4.112 -@@loop2:
   4.113 -		pop	ax
   4.114 -		add	al,'0'
   4.115 -		stosb
   4.116 -		loop	@@loop2
   4.117 -
   4.118 -; patch initrd
   4.119 -;***************************************************************
   4.120 -		cwd
   4.121 -		or	[_isostate.curdirsize],-1
   4.122 -		jmp	patchtest
   4.123 -found:
   4.124 -		inc	dh
   4.125 -patchtest:
   4.126 -		push	dx
   4.127 -		extrn	@isoreaddir$qv:near
   4.128 -		call	@isoreaddir$qv
   4.129 -		pop	dx
   4.130 -		push	ds
   4.131 -		pop	es
   4.132 -		inc	ax
   4.133 -		jne	patchlp
   4.134 -		cmp	dx,100h
   4.135 -		je	initrddone
   4.136 -		mov	di,offset dotgz
   4.137 -		or	dh,dh
   4.138 -		je	modify
   4.139 -		add	di,4
   4.140 -		mov	si,offset rootfs
   4.141 -		mov	cx,3
   4.142 -		rep
   4.143 -		  movsw
   4.144 -modify:
   4.145 -		xchg	ax,dx
   4.146 -		mov	ah,'.'
   4.147 -		stosw
   4.148 -		mov	ax,'zg'
   4.149 -		stosw
   4.150 -		mov	ax,'!,'
   4.151 -		stosw
   4.152 -initrddone:
   4.153 -
   4.154 -;***************************************************************
   4.155 -
   4.156 -		mov	si, offset cmdline
   4.157 -		mov	di, 82h
   4.158 -copy:
   4.159 -		mov	ah,al
   4.160 -		lodsb
   4.161 -		cmp	al,' '
   4.162 -		jne	docopy
   4.163 -		cmp	al,ah
   4.164 -		je	copy
   4.165 -docopy:
   4.166 -		stosb
   4.167 -		cmp	al,0
   4.168 -		jnz	copy
   4.169 -		xchg	di,ax
   4.170 -		sub	al, 82h
   4.171 -		mov	[80h],al
   4.172 -
   4.173 -		mov	ax,offset linld
   4.174 -		call	iso_open
   4.175 -		jc	jc_abort
   4.176 -		mov	cx,[word _isostate.filesize]
   4.177 -		mov	dx,100h
   4.178 -		jmp	near unfold
   4.179 -
   4.180 -patchlp:
   4.181 -		mov	si,[_isostate.filename]
   4.182 -		mov	di,offset rootfs
   4.183 -		mov	cx,9
   4.184 -		rep
   4.185 -		  cmpsb
   4.186 -		jcxz	found
   4.187 -		cmp	cl,3
   4.188 -		ja	patchtest
   4.189 -		dec	si
   4.190 -		cmp	dl,[si]
   4.191 -		ja	patchtest
   4.192 -		mov	dl,[si]
   4.193 -		jmp	patchtest
   4.194 -
   4.195 -stopmsg:
   4.196 -		db	 "This program cannot be run in DOS mode$"
   4.197 -bootdir:
   4.198 -		db	"/boot",0
   4.199 -linld:
   4.200 -		db	"linld.com",0
   4.201 -cmdline:
   4.202 -		db	"-f "
   4.203 -		;db	"image=\boot\"
   4.204 -		;db	"bzImage "
   4.205 -		db	"initrd="
   4.206 -rootfs:
   4.207 -		db	"rootfs"
   4.208 -dotgz:
   4.209 -		db	".gz,!            "
   4.210 -		; 	".gz,rootfs4.gz,! "
   4.211 -		;db	"rw "
   4.212 -		db	"autologin rdinit=/init.exe "
   4.213 -		;db	"mode=menu "
   4.214 -		db	"magic="
   4.215 -magic:
   4.216 -		db	"0     bootfrom="
   4.217 -		;	"65535 bootfrom="
   4.218 -filename:
   4.219 -
   4.220 -
   4.221 -;***************************************************************
   4.222 +		extrn	_isostate
   4.223 +		dw	_isostate
   4.224  
   4.225          ends    _TEXT
   4.226  
     5.1 --- a/linld/stuff/src/pipehole.awk	Fri Jun 19 11:08:54 2020 -0400
     5.2 +++ b/linld/stuff/src/pipehole.awk	Fri Jun 19 15:46:21 2020 +0000
     5.3 @@ -203,6 +203,19 @@
     5.4  	}
     5.5  	 } # file == "load.cpp"
     5.6  	 if (file == "iso9660.cpp") {
     5.7 +	if (/curpos >= SECT/) isiso=10
     5.8 +	if (isiso == 10) { # ISO9660.LST
     5.9 +		if (/cmp/) {
    5.10 +			sub(/cmp	/,"mov	bx,")
    5.11 +			sub(/i.*/,"i]")
    5.12 +			print
    5.13 +			$0="	cmp	bh,2048/256"
    5.14 +		}
    5.15 +		if (/mov/) {
    5.16 +			isiso=0
    5.17 +			next
    5.18 +		}
    5.19 +	}
    5.20  	if (/<< SECTORBITS/) isiso=9
    5.21  	if (isiso == 9) { # ISO9660.LST
    5.22  		if (/dx,/) next
     6.1 --- a/syslinux/stuff/iso2exe/bootiso.S	Fri Jun 19 11:08:54 2020 -0400
     6.2 +++ b/syslinux/stuff/iso2exe/bootiso.S	Fri Jun 19 15:46:21 2020 +0000
     6.3 @@ -77,7 +77,7 @@
     6.4  	call	readsectorX		// read isolinux boot sector
     6.5  	cmpw	(%bx), %cx
     6.6  	jnc	puts			// read fail or no isohydrid boot sector
     6.7 -	movw	$patch,%si
     6.8 +	call	bootpartition		// assume DS=SS SI=BX=7C00 CX=0100 DL=<drive> DI=table+66
     6.9  	popw	%es
    6.10  	popw	%di			// isolinux boot needs %es:%di and %dx
    6.11  putsret:
    6.12 @@ -102,10 +102,37 @@
    6.13  nobsmsg:
    6.14  	.asciz	"No isolinux."
    6.15  
    6.16 -	.org	0x0080
    6.17 +	.org	0x0080,0xEE
    6.18  ////////////////////////////// EXE/PE header //////////////////////////////////
    6.19 +	.org	0x0178,0xFF
    6.20 +////////////////////////// partition boot code ////////////////////////////////
    6.21 +// assume DS=SS SI=BX=7C00 CX=0100 DL=<drive> DI=table+66
    6.22  
    6.23 -	.org	0x01A0
    6.24 +bootpartition:
    6.25 +	movw	$4,%cx
    6.26 +	movw	$16,%ax
    6.27 +next:
    6.28 +	subw	%ax,%di
    6.29 +	cmpb	%ch,-2(%di)		// boot flag ?
    6.30 +	loope	next
    6.31 +	cmpw	$63,2-2(%di)		// empty or isolinux partition ?
    6.32 +	jbe	default
    6.33 +	.arch	i486
    6.34 +	pushl	$0
    6.35 +	pushl	8-2(%di)
    6.36 +	pushw	%cs
    6.37 +	pushw	%bx
    6.38 +	pushw	$1
    6.39 +	pushw	%ax
    6.40 +	movw	%sp,%si			// assume %ds = %ss
    6.41 +	movb	$0x42,%ah
    6.42 +	int	$0x13
    6.43 +	add	$16,%sp
    6.44 +	.arch	i8086
    6.45 +default:
    6.46 +	ret
    6.47 +
    6.48 +	.org	0x01A0,0xFF
    6.49  readsectorX:				// read isolinux boot sector
    6.50  	movb	$0xA5, %cl		// patched by installer
    6.51  readsector1:
    6.52 @@ -120,182 +147,239 @@
    6.53  	movw	$0x0100, %cx
    6.54  	movb	$nobsmsg, %al
    6.55  	ret
    6.56 -	.org	0x01B8
    6.57 +	.org	0x01B8,0xEE		// partition table
    6.58  
    6.59 -////////////////////////// partition boot code ////////////////////////////////
    6.60 -// assume DS=SS BX=7C00 CH=01 DL=<drive> SI=7DBE
    6.61 +	.org	0x0270,0xFF
    6.62  
    6.63 -	.org	0x7C00
    6.64 -	jmp	bootpartition
    6.65 -	.org	0x7C03
    6.66 -	.org	0x7DBE
    6.67 -table	=	moved+0x1BE
    6.68 -patch:
    6.69 -	.byte	0,0,0			// head of original bs
    6.70 -partcode:
    6.71 -	popw	%si
    6.72 -	xchgw	%si,%di
    6.73 -	call	movepartition
    6.74 -	pushw	%cx
    6.75 -	pushw	%cx
    6.76 -	decw	%di
    6.77 -	decw	%di
    6.78 -	movb	$4,%cl
    6.79 -	movw	$16,%ax
    6.80 -next:
    6.81 -	subw	%ax,%di
    6.82 -	cmpb	%ch,(%di)		// boot flag ?
    6.83 -	loope	next
    6.84 -	pushw	10(%di)
    6.85 -	pushw	8(%di)
    6.86 -	pushw	%cs
    6.87 -	pushw	%bx
    6.88 -	movb	$1,%cl
    6.89 -	pushw	%cx
    6.90 -	pushw	%ax
    6.91 -	movw	%sp,%si			// assume %ds = %ss
    6.92 -	pushw	%bx
    6.93 -	cmpw	$63,2(%di)		// empty or isolinux partition ?
    6.94 -	jbe	default
    6.95 -	movb	$0x42,%ah
    6.96 -	int	$0x13
    6.97 -default:
    6.98 -	ret
    6.99 -	.org	0x7DF0
   6.100 -bootpartition:
   6.101 -	pushw	%ds
   6.102 -	popw	%es
   6.103 -	pushw	%si
   6.104 -	movw	%bx,%di
   6.105 -	movsw
   6.106 -	movsb
   6.107 -	movw	$table-0x142,%di
   6.108 -	pushw	%di
   6.109 -movepartition:
   6.110 -	movb	$66,%cl			// 0142 and 0042
   6.111 -	rep
   6.112 -	  movsb
   6.113 -	ret
   6.114 -	.org	0x7E00
   6.115 -	.org	0x7F40
   6.116  ////////////////////////////// DOS EXE code ///////////////////////////////////
   6.117  
   6.118 +bootdir:
   6.119 +	.asciz	"/boot"
   6.120 +linld:
   6.121 +	.asciz	"linld.com"
   6.122 +cmdline:
   6.123 +	.ascii	"-f "
   6.124 +//	.ascii	"image=\boot\"
   6.125 +//	.ascii	"bzImage "
   6.126 +	.ascii	"initrd="
   6.127 +rootfs:
   6.128 +	.ascii	"rootfs"
   6.129 +dotgz:
   6.130 +	.ascii	".gz,!            "
   6.131 +//	.ascii	".gz,rootfs4.gz,! "
   6.132 +args:
   6.133 +//	.ascii	" rw "
   6.134 +//	.ascii	" mode=menu"
   6.135 +	.ascii	" autologin rdinit=/init.exe magic="
   6.136 +magicstr:
   6.137 +	.ascii	"0     bootfrom="
   6.138 +//	.ascii	"65535 bootfrom="
   6.139 +filename:
   6.140  exestart:
   6.141 -	movw	129, %ax
   6.142 -	cmpb	$0x2F, %al
   6.143 -	je	ishelp
   6.144 -	cmpw	$0x2F20, %ax
   6.145 -ishelp:
   6.146 -	movw	$0x3000+EXESTR(help), %ax
   6.147 -	cwd				// clear dx
   6.148 -	pushw	%dx			// dos exit()
   6.149 -	je	abort
   6.150 -	int	$0x21			// get DOS version
   6.151 -	addb	$-3, %al
   6.152 -	movb	$EXESTR(noDOS3), %al
   6.153 -	movw	$0x100, %di
   6.154 -	jc	tst386
   6.155 -abort:
   6.156 -goputs:
   6.157 -	mov	$EXEADRS(puts), %si
   6.158 -	jmp	*%si
   6.159 +	movb	$0x30,%ah		// get DOS version
   6.160 +	int	$0x21
   6.161 +	cmpb	$3,%al
   6.162 +	jc	goabort
   6.163  
   6.164 -tst386:
   6.165 -	pushw	%sp
   6.166 -	popw	%ax
   6.167 -	xorw	%sp, %ax		// clear C
   6.168 -	movb	$EXESTR(vm86modemsg), %al
   6.169 -	jnz	is86			// 86/186 not a 286+
   6.170 -	.arch	i486
   6.171 -is386:
   6.172 -	smsww	%bx			// not privileged
   6.173 -	andb	$1, %bl			// clear C
   6.174 -	jne	isvm86
   6.175 -	movl	%cr0, %ebx		// privileged
   6.176 -	incl	%ebx
   6.177 -	.arch	i8086
   6.178 -	movb	$EXESTR(rmPaging), %al
   6.179 -	js	abort
   6.180 -is86:
   6.181 -	incw	%ax
   6.182 -	//movb	$EXESTR(realmodemsg), %al
   6.183 -isvm86:
   6.184 -	call	goputs
   6.185 -//----------
   6.186 -	pushw	%di
   6.187 -//------------- insert argv[0] in cmdline -----------------------
   6.188 -	xchgw	%ax,%dx			// %ax = 0
   6.189 +	cld
   6.190 +	movw	EXEADRS(comstart),%si
   6.191 +	movw	$0xF000,%di
   6.192 +	movb	$4,%ch			// 2k min
   6.193 +	rep
   6.194 +	  movsw				// helper
   6.195 +	movw	$129,%si
   6.196 +	leaw	args-cmdline(%si),%di
   6.197 +	movb	-1(%si),%cl
   6.198 +	pushw	%si
   6.199 +	rep
   6.200 +	  movsb				// user args
   6.201 +	xchgw	%ax,%di
   6.202 +	popw	%di
   6.203 +	movw	$EXEADRS(cmdline),%si
   6.204 +	movb	$args-cmdline,%cl
   6.205 +	rep
   6.206 +	  movsb				// files
   6.207 +	xchgw	%ax,%di
   6.208 +	movb	$filename-args,%cl
   6.209 +	rep
   6.210 +	  movsb				// end
   6.211 +	pushw	%di			// filename
   6.212 +
   6.213 +#define ISOSTATE	0xF000
   6.214 +#define ISO_OPEN	iso_open
   6.215 +#define ISO_READDIR	*0xF004
   6.216 +#define ISO_READMENU 	iso_readmenu
   6.217 +#define RUN_LINLD	run_linld
   6.218 +	movw	ISOSTATE,%bp
   6.219 +	xorw	%ax,%ax
   6.220 +	movw	%bp,%di
   6.221 +	movb	$64,%cl
   6.222 +	rep
   6.223 +	  stosb				// clear BSS
   6.224 +
   6.225  	movw	%ax,%di
   6.226  	movw	0x2C(%di),%es
   6.227 -	movw	%sp,%cx			// big enough
   6.228 +	decw	%cx
   6.229  scalp:
   6.230  	repne
   6.231  	  scasb
   6.232  	scasb
   6.233  	jne	scalp
   6.234 -	incw	%di
   6.235 -	movw	%di,%bx
   6.236 -	incw	%di
   6.237 -	pushw	%di			// %es:%di = programme pathname
   6.238 -	repne
   6.239 -	  scasb
   6.240 -	subw	%di,%bx
   6.241 -	notw	%bx
   6.242 -	movw	$128,%si
   6.243 -	addw	%bx,(%si)
   6.244 -	lodsb	
   6.245 -	xchgw	%ax,%cx
   6.246 +	scasw
   6.247 +	movw	%di,%si			// %es:%di = programme pathname
   6.248 +
   6.249 +	pushw	%es
   6.250 +	pushw	%ds
   6.251 +	popw	%es
   6.252 +	popw	%ds
   6.253 +	popw	%di			// filename
   6.254 +	pushw	%di
   6.255 +	movb	$0x60,%ah		// canonicalize filename
   6.256 +	int	$0x21
   6.257 +	pushw	%es
   6.258 +	popw	%ds
   6.259 +#define LONG_FILENAME
   6.260 +#ifdef LONG_FILENAME
   6.261 +	popw	%si
   6.262 +	pushw	%si
   6.263 +	movw	$0x716C,%ax
   6.264 +	xorw	%bx,%bx			// R/O
   6.265 +	xorw	%cx,%cx			// attributes
   6.266 +	cwd				// action = open
   6.267 +	stc
   6.268 +	int	$0x21
   6.269 +	jnc	opened
   6.270 +#endif
   6.271 +	popw	%dx
   6.272 +	pushw	%dx
   6.273 +	movw	$0x3D00,%ax
   6.274 +//	movb	$0,%cl
   6.275 +	int	$0x21
   6.276 +goabort:
   6.277 +	jc	abort
   6.278 +opened:
   6.279 +	movw	%ax,4(%bp)		// fd
   6.280 +
   6.281 +	call	ISO_READMENU
   6.282 +	movw	6(%bp),%ax		// magic = filemod
   6.283 +	popw	%bx
   6.284 +	leaw	magicstr-filename(%bx),%di
   6.285 +	movb	$10,%bl
   6.286 +	xorw	%cx,%cx
   6.287 +lp1:
   6.288 +	xorw	%dx,%dx
   6.289 +	divw	%bx
   6.290 +	pushw	%dx
   6.291  	incw	%cx
   6.292 +	orw	%ax,%ax
   6.293 +	jnz	lp1
   6.294 +lp2:
   6.295 +	popw	%ax
   6.296 +	addb	$'0',%al
   6.297 +	stosb				// store magic
   6.298 +	loop	lp2
   6.299 +
   6.300 +	movw	$EXEADRS(bootdir),%ax
   6.301 +	call	ISO_OPEN
   6.302 +	orw	$-1,18(%bp)		// curdirsize = -1
   6.303 +	xorw	%ax,%ax
   6.304 +found:
   6.305 +	incb	%ah
   6.306 +patchtest:
   6.307 +	pushw	%ax
   6.308 +	call	ISO_READDIR
   6.309 +	pushw	%ds
   6.310 +	popw	%es
   6.311 +	incw	%ax
   6.312 +	popw	%ax
   6.313 +	movw	$EXEADRS(rootfs),%si
   6.314 +	je	dopatch
   6.315 +	movw	%si,%di
   6.316 +	movw	16(%bp),%si		// filename
   6.317 +	movw	$9,%cx
   6.318 +	rep
   6.319 +	  cmpsb
   6.320 +	jcxz	found
   6.321 +	cmpb	$3,%cl
   6.322 +	ja	patchtest
   6.323 +	decw	%si
   6.324 +	cmpb	(%si),%al
   6.325 +	ja	patchtest
   6.326 +	lodsb
   6.327 +	jmp	patchtest
   6.328 +done:
   6.329 +	movw	$128,%ax
   6.330 +	subw	%ax,%si
   6.331 +	xchgw	%ax,%si
   6.332 +	decw	%ax
   6.333 +	movb	%al,(%si)		// cmdline length
   6.334 +
   6.335 +	movw	$EXEADRS(linld),%ax
   6.336 +	call	ISO_OPEN
   6.337 +	jc	abort
   6.338 +	movw	12(%bp),%cx		// filesize
   6.339 +	movw	$0x100,%dx
   6.340 +	call	RUN_LINLD
   6.341 +abort:
   6.342 +	movw	$EXEADRS(stopmsg),%dx
   6.343 +	movb	$9,%ah
   6.344 +	int	$0x21
   6.345 +	int	$0x20
   6.346 +dopatch:
   6.347  	pushw	%si
   6.348 -p2lp:
   6.349 +	cmpw	$0x200,%ax
   6.350 +	je	initrddone
   6.351 +	movw	$EXEADRS(dotgz),%di
   6.352 +	decb	%ah
   6.353 +	je	modify
   6.354 +	scasw
   6.355 +	scasw				// addw	$4,%di
   6.356 +	movsw
   6.357 +	movsw
   6.358 +	movsw
   6.359 +modify:
   6.360 +	stosb
   6.361 +	movw	$129+dotgz-cmdline,%si
   6.362 +	movsb
   6.363 +	movsw
   6.364 +	movsw
   6.365 +initrddone:
   6.366 +	movw	$129+rootfs-cmdline,%di
   6.367 +	popw	%si
   6.368 +	movw	$args-rootfs,%cx
   6.369 +	rep
   6.370 +	  movsb
   6.371 +
   6.372 +shrink0:
   6.373 +	movw	$129,%si
   6.374 +shrink:
   6.375 +	movw	%si,%di
   6.376  	lodsb
   6.377 -	movb	%al,-2(%bx,%si)
   6.378 -	loop	p2lp
   6.379 -	popw	%si
   6.380 -	popw	%bx
   6.381 -	movb	$0x20,%al
   6.382 -p1lp:
   6.383 -	movb	%al,(%si)
   6.384 -	incw	%si
   6.385 -	movb	%es:(%bx),%al
   6.386 -	incw	%bx
   6.387 -	cmpw	%bx,%di
   6.388 -	ja	p1lp
   6.389 -//----------
   6.390 -	popw	%di
   6.391 -	pushw	%cs
   6.392 -	popw	%es
   6.393 -//----------
   6.394 -	movw	comstart-end_header(%di), %si		// .com address
   6.395 -	pushw	%di
   6.396 -	movb	$0x7C/2, %ch		// 31K-31.5K, > com length
   6.397 -	movb	$0x80, %bh
   6.398 -	movw	$0xA5F3, (%bx)		// rep movsw
   6.399 -	movb	$0xC3, 2(%bx)		// ret
   6.400 -	jmp	*%bx
   6.401 +	cmpb	$0,%al
   6.402 +	je	done
   6.403 +	cmpb	$' ',%al
   6.404 +	jne	shrink
   6.405 +	cmpb	(%si),%al
   6.406 +	jne	shrink
   6.407 +pack:
   6.408 +	lodsb
   6.409 +	stosb
   6.410 +	cmpb	$0,%al
   6.411 +	jne	pack
   6.412 +	jmp	shrink0
   6.413 +	
   6.414 +	.org	0x0400,0xEE
   6.415 +	.org	0x0600,0xFF
   6.416 +	.org	0x0750,0xBB
   6.417 +stopmsg:
   6.418 +	.ascii	"This program cannot be run in DOS mode.$"
   6.419 +	.org	0x0778,0xEE
   6.420 +	.org	0xF002-0xC0
   6.421 +iso_open:
   6.422 +	.word	0
   6.423 +	.word	0
   6.424 +iso_readmenu:
   6.425 +	.word	0
   6.426 +run_linld:
   6.427  
   6.428 -vm86modemsg:
   6.429 -// --------------- Must be in 7F40 7FFF range ------------------------
   6.430 -	.ascii	"v"			// v86 mode
   6.431 -	.ascii	"86"			// 86 mode
   6.432 -	.byte	EXESTR(mode)
   6.433 -rmPaging:
   6.434 -	.ascii	"X"			// Xreal mode
   6.435 -realmodemsg:
   6.436 -	.ascii	"real"			// real mode
   6.437 -// --------------- Must be in 7FC0 7FFF range ------------------------
   6.438 -mode:
   6.439 -	.ascii	" mode"
   6.440 -	.byte	EXESTR(eol)
   6.441 -noDOS3:
   6.442 -	.ascii	"DOS3?"			// DOS3?
   6.443 -	.byte	EXESTR(eol)
   6.444 -help:
   6.445 -	.ascii	"SliTaz iso boot"	// SliTaz iso boot
   6.446 -eol:
   6.447 -	.ascii	"\r\n"
   6.448 -	.byte	1			// puts will return
   6.449 -
   6.450 -	.space	16,0			// ISO md5
   6.451 -	.org	0x8000
   6.452 -////////////////////////// ISO9660 header /////////////////////////////////////
   6.453 +	.end
     7.1 --- a/syslinux/stuff/iso2exe/iso2exe.sh	Fri Jun 19 11:08:54 2020 -0400
     7.2 +++ b/syslinux/stuff/iso2exe/iso2exe.sh	Fri Jun 19 15:46:21 2020 +0000
     7.3 @@ -79,7 +79,7 @@
     7.4  add_win32exe()
     7.5  {
     7.6  	SIZE=$($0 --get win32.exe 2> /dev/null | tee /tmp/exe$$ | wc -c)
     7.7 -	[ -n "$gpt" ] && n=1536 || n=512
     7.8 +	n=1536
     7.9  	SIZE=$(($SIZE+$n))
    7.10  	printf "Adding WIN32 file at %04X (%d bytes) ...\n" 0 $SIZE
    7.11  	[ -n "$gpt" ] && printf "Adding GPT at %04X (1024 bytes) ...\n" 512
    7.12 @@ -93,25 +93,20 @@
    7.13  	ddn if=/tmp/exe$$ of=$1 bs=1 skip=$cut seek=$(($n+$cut))
    7.14  	printf "Adding bootiso head at %04X...\n" 0
    7.15  	$0 --get bootiso.bin 2> /dev/null > /tmp/exe$$
    7.16 -	x=$(($(get 0x14 /tmp/exe$$ 1)+0x40))
    7.17 -	printf "Adding bootiso DOS stub at %04X...\n" $(($n+$x))
    7.18 -	ddn if=/tmp/exe$$ of=$1 bs=1 seek=$(($n+$x)) skip=$((0x7F00+$x)) count=$((256-$x))
    7.19 -	x=$(($n/256+1))
    7.20 -	store $((0x15)) $x /tmp/exe$$ 8		### exe IP 
    7.21 -	store $((0x6c)) $x /tmp/exe$$ 8		### puts data 
    7.22 -	ddn if=/tmp/exe$$ of=$1 bs=128 count=1	### DOS header
    7.23 -	ddn if=/tmp/exe$$ of=$1 bs=1 count=24 seek=$((0x1A0)) skip=$((0x1A0))
    7.24 -	ddn if=$2 bs=1 skip=$((0x1B8)) seek=$((0x1B8)) count=72 of=$1
    7.25  	store 510 $((0xAA55)) $1
    7.26 -	i=$SIZE; OFS=$(($SIZE+512))
    7.27 -	store 417 $(($i/512)) $1 8	### isolinux boot sector
    7.28 -	printf "Moving syslinux hybrid boot record at %04X (512 bytes) ...\n" $i
    7.29 -	ddn if=$2 bs=1 count=512 of=$1 seek=$i
    7.30 -	if [ $(get $((0x7C00)) /tmp/exe$$) -eq 60905 ]; then	# partition boot code
    7.31 -		ddn if=/tmp/exe$$ bs=1 count=66 skip=$((0x7DBE)) of=$1 seek=$(($i + 0x1BE))
    7.32 -		ddn if=$1 bs=1 count=3 skip=$i of=$1 seek=$(($i + 0x1BE))
    7.33 -		ddn if=/tmp/exe$$ bs=1 count=3 skip=$((0x7C00)) of=$1 seek=$i
    7.34 -	fi
    7.35 +	while read adrs sz; do
    7.36 +		ddn if=/tmp/exe$$ of=$1 bs=1 count=$((0x$sz)) seek=$((0x$adrs)) skip=$((0x$adrs))
    7.37 +	done <<EOT
    7.38 +0000 0080
    7.39 +0178 0040
    7.40 +0270 0190
    7.41 +0750 0028
    7.42 +EOT
    7.43 +	i=$((0x600))
    7.44 +	store 417 $(($i/512)) $1 8		### isolinux boot sector
    7.45 +	printf "Moving syslinux hybrid boot record at %04X (336 bytes) ...\n" $i
    7.46 +	OFS=$SIZE
    7.47 +	ddn if=$2 bs=1 count=336 of=$1 seek=$i
    7.48  	rm -f /tmp/exe$$ /tmp/coff$$
    7.49  	if [ -z "$RECURSIVE_PARTITION" -a $(get 454 $1 4) -eq 0 ]; then
    7.50  		store 448 $((1+$i/512)) $1 8			### 446+2 SECTOR
    7.51 @@ -159,8 +154,8 @@
    7.52  	SIZE=0; OFFSET=0
    7.53  	case "$1" in
    7.54  	win32.exe)	[ $x -eq 2048 ] && x=10752
    7.55 -			[ $x -eq 1024 ] || SIZE=$(($x - 512));;
    7.56 -	syslinux.mbr)	[ $x -eq 1024 ] || OFFSET=$(($x - 512)); SIZE=512;;
    7.57 +			[ $x -eq 1024 ] || SIZE=$x;;
    7.58 +	syslinux.mbr)	[ $x -eq 1024 ] || OFFSET=$(($x - 512)); SIZE=336;;
    7.59  	flavor.info)	[ $(get 22528 "$ISO") -eq 35615 ] && OFFSET=22528
    7.60  			[ $x -eq 2048 ] && x=$(get 0x25C "$ISO") &&
    7.61  					   SIZE=$(get 0x25E "$ISO")
    7.62 @@ -308,6 +303,8 @@
    7.63  	find $TMP -type f -print0 | xargs -0 chmod +x
    7.64  	find $TMP -print0 | xargs -0 touch -t 197001010100.00
    7.65  	( cd $TMP; find dev init.exe | cpio -o -H newc ) | compress > rootfs.gz
    7.66 +	p=$((4-($(stat -c %s rootfs.gz)%4)))
    7.67 +	[ $p = 4 ] || dd if=/dev/zero bs=1 count=$p >> rootfs.gz
    7.68  	rm -rf $TMP
    7.69  	chmod 644 ${@/init/rootfs.gz}
    7.70  	chown root.root ${@/init/rootfs.gz}