File:  [gforth] / gforth / arch / 4stack / relocate.fs
Revision 1.14: download - view: text, annotated - select for diffs
Sat Nov 1 22:19:30 2008 UTC (12 years, 11 months ago) by anton
Branches: MAIN
CVS tags: v0-7-0, HEAD
updated copyright years

\ relocate 4stack binary

\ Copyright (C) 2000,2003,2007,2008 Free Software Foundation, Inc.

\ This file is part of Gforth.

\ Gforth is free software; you can redistribute it and/or
\ modify it under the terms of the GNU General Public License
\ as published by the Free Software Foundation, either version 3
\ of the License, or (at your option) any later version.

\ This program is distributed in the hope that it will be useful,
\ but WITHOUT ANY WARRANTY; without even the implied warranty of
\ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
\ GNU General Public License for more details.

\ You should have received a copy of the GNU General Public License
\ along with this program. If not, see http://www.gnu.org/licenses/.

Create magic 8 allot
Variable image
Variable relinfo
Variable imagesize

: be@  0 swap 4 bounds DO  8 lshift I c@ +  LOOP ;
: x@   dup 4 + l@ swap l@ ;
: x!   tuck l! 4 + l! ;

: scan-header ( fd -- skip )  >r 0
    BEGIN
	8 +
	magic 8 r@ read-file throw 8 = WHILE
	magic 8 s" Gforth3" compare 0= UNTIL
    ELSE  true abort" Magic not found!"  THEN rdrop ;

Create bits $80 c, $40 c, $20 c, $10 c, $08 c, $04 c, $02 c, $01 c,

: bit@ ( n -- flag )
    dup 3 rshift relinfo @ + c@ swap 7 and bits + c@ and 0<> ;

2Variable dovar
2Variable docol

: relocate ( -- )  hex
    image @ $814 + be@ image @ $810 + be@ docol x!
    image @ $80C + be@ image @ $808 + be@ dovar x!
    imagesize @ 1 2* 2* / 0 ?DO
	image @ I 2* 2* + be@
\	dup 8 u.r I bit@ IF '+ ELSE '- THEN emit I 7 and 7 = IF cr THEN 
	dup $80000000 and 0<> I bit@ and IF
	    CASE
		$FFFFFFFF OF
		    0 image @ I 2* 2* + l!  1 ENDOF \ NIL
		$FFFFFFFE OF
		    docol x@
		    image @ I 2* 2* + x!  2 ENDOF \ docol
		$FFFFFFFD OF
		    dovar x@ $10. d+
		    image @ I 2* 2* + x!  2 ENDOF \ docon
		$FFFFFFFC OF
		    dovar x@
		    image @ I 2* 2* + x!  2 ENDOF \ docon
		$FFFFFFF7 OF
		    image @ I 1+ 2* 2* + be@ 5 -
		    dovar x@ nip
		    image @ I 2* 2* + x!  2 ENDOF \ dodoes
		$FFFFFFF6 OF
		    docol x@
		    image @ I 2* 2* + x!  2 ENDOF \ docol
		1 swap
	    ENDCASE
	ELSE
	    image @ I 2* 2* + l! 1
	THEN
    +LOOP
    image @ imagesize @ bounds ?DO
	I x@ swap I x!
	8 +LOOP ;

: read-gforth ( addr u -- )  r/o bin open-file throw
    >r r@ file-size throw drop
    ( r@ scan-header - ) dup allocate throw image !
    image @ swap r@ read-file throw drop
    image @ dup $804 ( 8 ) + be@ dup imagesize ! + relinfo !
    r> close-file throw
    relocate ;

Create 4magic  here $10 dup allot erase
s" 4stack00" 4magic swap move

: write-gforth ( addr u -- )  w/o bin create-file throw >r
    imagesize @ 4magic $C + !
    4magic $10 r@ write-file throw
    image @ imagesize @ r@ write-file throw
    r> close-file throw ;

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>