wok-current rev 22176

linld: spare up to 30k more for zImage
author Pascal Bellard <pascal.bellard@slitaz.org>
date Fri Nov 08 20:55:40 2019 +0100 (2019-11-08)
parents 55af2ae5af8f
children 7dd1225d9461
files linld/stuff/src/!COMPILE.BAT linld/stuff/src/A20.ASM linld/stuff/src/CRTL.ASM linld/stuff/src/JUMP.ASM linld/stuff/src/LOAD.CPP linld/stuff/src/pipehole.awk
line diff
     1.1 --- a/linld/stuff/src/!COMPILE.BAT	Fri Nov 08 17:15:11 2019 +0100
     1.2 +++ b/linld/stuff/src/!COMPILE.BAT	Fri Nov 08 20:55:40 2019 +0100
     1.3 @@ -3,12 +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 -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  mawk -f pipehole.awk LINLD.ASO > LINLD.ASM
    1.13  mawk -f pipehole.awk LOAD.ASO > LOAD.ASM
    1.14  mawk -f pipehole.awk HIMEM.ASO > HIMEM.ASM
    1.15 -tasm /la /m /dUSE_ARGSTR /dNO386 /dLARGE_IMAGES /dLONG_FILENAME *.asm > asm.log
    1.16 +tasm /la /m /dMOVE_SETUP /dUSE_ARGSTR /dNO386 /dLARGE_IMAGES /dLONG_FILENAME *.asm > asm.log
    1.17  tlink /m /s /t @link.cmd > lnk.log
     2.1 --- a/linld/stuff/src/A20.ASM	Fri Nov 08 17:15:11 2019 +0100
     2.2 +++ b/linld/stuff/src/A20.ASM	Fri Nov 08 20:55:40 2019 +0100
     2.3 @@ -99,23 +99,24 @@
     2.4  		push	si di
     2.5  		extrn	_heap_top:word
     2.6  		ifdef	NO386
     2.7 +		mov	ax,[_heap_top]
     2.8 +		mov	cl,4
     2.9 +		shr	ax,cl
    2.10 +		mov	dx,cs
    2.11 +		add	dx,ax
    2.12  		extrn	_topseg:near
    2.13  		call	near _topseg
    2.14 -		mov	cl,4
    2.15  		mov	[word sssp+2],ax
    2.16 -		xchg	ax,dx
    2.17 -		mov	ax,[_heap_top]
    2.18 -		shr	ax,cl
    2.19  		else
    2.20                  p386
    2.21  		mov	ax,[_heap_top]
    2.22  		shr	ax,4
    2.23 -		mov	dx,9000h
    2.24 +		mov	dx,cs
    2.25 +		add	dx,ax
    2.26 +		mov	ax,9000h
    2.27  		endif
    2.28 -		mov	es,dx
    2.29 -		mov	cx,cs
    2.30 -		add	ax,cx
    2.31 -		cmp	ax,dx
    2.32 +		mov	es,ax
    2.33 +		cmp	dx,ax
    2.34  		jb	@@nooverflow
    2.35  ; Oops! We can stomp on our toes... better stop now
    2.36  		mov	bx,offset overflow
    2.37 @@ -124,9 +125,18 @@
    2.38  		mov	cx,[bx-5]	; size
    2.39  		mov	si,[bx-2]	; data
    2.40  		xor	di,di
    2.41 +		ifdef	MOVE_SETUP
    2.42 +		extrn	_pm_high:byte
    2.43 +		cmp	[_pm_high],al
    2.44 +		jne	@@move_clear
    2.45 +		mov	di,8000h
    2.46 +		sub	di,cx
    2.47 +		extrn	_rm_offset:word
    2.48 +		mov	[_rm_offset],di
    2.49 +		endif
    2.50  @@move_clear:
    2.51  		movsb
    2.52 -		mov	[byte si-1],0
    2.53 +		mov	[byte si-1],al
    2.54  		loop	@@move_clear
    2.55  		;push	ds
    2.56  		;pop	es
     3.1 --- a/linld/stuff/src/CRTL.ASM	Fri Nov 08 17:15:11 2019 +0100
     3.2 +++ b/linld/stuff/src/CRTL.ASM	Fri Nov 08 20:55:40 2019 +0100
     3.3 @@ -59,9 +59,6 @@
     3.4  _xfer_buf	db	4096	dup (?)
     3.5  filecnt		db	?		; in fact 0 minus file count...
     3.6  nextfilename	dw	?
     3.7 -	ifdef	LARGE_IMAGES
     3.8 -curdata		dw	?
     3.9 -	endif
    3.10  	ifdef	EXTRA
    3.11  ultoabuf	db	12	dup (?)
    3.12  	endif
    3.13 @@ -586,12 +583,12 @@
    3.14  		mov	[byte si],ah		; set temp eos
    3.15  		call	open
    3.16  		pop	[word si]		; restore string
    3.17 -		jc	@@die
    3.18 +		jc	jcdie
    3.19  		mov	[(image_himem di).fd],ax
    3.20  		mov	[(image_himem di).fd2close],ax
    3.21  		mov	bl,02h			; SEEK_END
    3.22  		call	lseek0
    3.23 -@@die:
    3.24 +jcdie:
    3.25  		mov	bx,[(image_himem di).errmsg]
    3.26  		jc	die
    3.27  		ifndef	NO386
    3.28 @@ -663,12 +660,12 @@
    3.29  		mov	[(image_himem si).bufv],ax
    3.30  		xchg	ax,si
    3.31  @@vcpi_alloc:
    3.32 -                xor     edx,edx
    3.33                  mov     ax,0DE04h
    3.34                  int     67h
    3.35  		or	ah,ah
    3.36 +		stc
    3.37  		mov	bx,offset vcpi_alloc_err
    3.38 -		jnz	die
    3.39 +		jnz	jcdie
    3.40  ; for (i = cnt-1; i >= 0; i--)
    3.41  	ifdef	LARGE_IMAGES
    3.42  		mov	eax,ecx
    3.43 @@ -867,7 +864,9 @@
    3.44  _next_bufv:
    3.45  		clc
    3.46  		push	si
    3.47 -		mov	si,[curdata]
    3.48 +		mov	si,0
    3.49 +		org	$-2
    3.50 +curdata		dw	?
    3.51  		sbb	ax,ax
    3.52  		cmc
    3.53  		adc	ax,[(data_himem si).cacheidx]	; -1/+1
     4.1 --- a/linld/stuff/src/JUMP.ASM	Fri Nov 08 17:15:11 2019 +0100
     4.2 +++ b/linld/stuff/src/JUMP.ASM	Fri Nov 08 20:55:40 2019 +0100
     4.3 @@ -157,6 +157,12 @@
     4.4  		lodsw
     4.5  		xchg	ax,bx			; get pm->fallback low word
     4.6  		lodsw				; get pm->fallback high word
     4.7 +		ifdef	MOVE_SETUP
     4.8 +		mov	si,0
     4.9 +	global	_rm_offset:word
    4.10 +		org	$-2
    4.11 +_rm_offset	dw	?
    4.12 +		endif
    4.13  		push	es
    4.14  		call	near @@isbzimage	; pop cs ; ds=es=ss
    4.15  
    4.16 @@ -183,6 +189,14 @@
    4.17  		extrn   memcpy32:near
    4.18  		call	memcpy32
    4.19  
    4.20 +		ifdef	MOVE_SETUP
    4.21 +		;xor	di,di
    4.22 +		mov	cx,8000h
    4.23 +		;sub	cx,si
    4.24 +		rep
    4.25 +		  movsb
    4.26 +		endif
    4.27 +
    4.28  		ifndef  noelks
    4.29  		ifndef	NO386
    4.30  		cmp	[dword 1E6h],'SKLE'
     5.1 --- a/linld/stuff/src/LOAD.CPP	Fri Nov 08 17:15:11 2019 +0100
     5.2 +++ b/linld/stuff/src/LOAD.CPP	Fri Nov 08 20:55:40 2019 +0100
     5.3 @@ -119,7 +119,7 @@
     5.4  #define topseg() 0x9000
     5.5  #endif
     5.6  u16 rm_size;
     5.7 -static u8 pm_high;	// @ = @rm_size + 2, see JUMP.ASM
     5.8 +u8 pm_high;		// @ = @rm_size + 2, see JUMP.ASM
     5.9  static u8* rm_buf;	// @ = @rm_size + 3, see JUMP.ASM
    5.10  struct image_himem imgs[2];
    5.11  
    5.12 @@ -211,7 +211,13 @@
    5.13      // Try to load kernel high, maybe even blindly storing it
    5.14      // in unallocated memory as a last resort
    5.15  
    5.16 +#ifdef	MOVE_SETUP
    5.17 +    extern unsigned rm_offset;
    5.18 +    if((u16)(((m->fallback=(u32(u16(_CS)+(u16(heap_top)>>4)+1)<<4))
    5.19 +             +m->size-rm_offset)>>16) >=
    5.20 +#else
    5.21      if((u16)(((m->fallback=(u32(u16(_CS)+(u16(heap_top)>>4)+1)<<4))+m->size)>>16) >=
    5.22 +#endif
    5.23  		 (u16)(topseg()>>12) || _pm_high) {
    5.24          m->fallback = base_himem;
    5.25      }
     6.1 --- a/linld/stuff/src/pipehole.awk	Fri Nov 08 17:15:11 2019 +0100
     6.2 +++ b/linld/stuff/src/pipehole.awk	Fri Nov 08 20:55:40 2019 +0100
     6.3 @@ -183,7 +183,7 @@
     6.4  			print	"	extrn	N_LXLSH@4:near"
     6.5  			sub(/N_LXLSH@/,"N_LXLSH@4")
     6.6  		}
     6.7 -		sub(/,0/,",dh")
     6.8 +		sub(/-3\],0/,"-3],dh")
     6.9  		if (/_base_himem\+2/ || /pop/ || /push/) next
    6.10  		if (/_base_himem$/) {
    6.11  			sub(/mov	dx,/,"les	dx,d")