| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208 | |*************************************************************************|*                                                                       *|*       DSTART.S        Startup module for Pascal programs using dLibs  *|*                                                                       *|*************************************************************************|*|* entry points|*.globl  __base                  | basepage pointer.globl  __start                 | startup entry point.globl  _etext                  | end of text segment.globl  _edata                  | end of data segment.globl  _end                    | end of BSS segment (end of program).globl  __BREAK                 | location of stack/heap break.globl  __ARGC                  | number of arguments.globl  __ARGS                  | argument list pointer.globl  __envp                  | environment string pointer.globl  _errno                  | system error number|| external references||.globl  __stklen               | Stack size value from C (unsigned long)|| useful constants|MINSTK          =     16384   | Minimum 16K stack sizeMARGIN          =     512     | Minimum memory to return to OS|| GEMDOS functions|Cconws          =     0x09     | Console write stringPterm           =     0x4C     | Process terminate (with exit code)Mshrink         =     0x4A     | Shrink program space|| basepage offsets|p_hitpa         =     0x04     | top of TPAp_tbase         =     0x08     | base of textp_tlen          =     0x0C     | length of textp_dbase         =     0x10     | base of datap_dlen          =     0x14     | length of datap_bbase         =     0x18     | base of BSSp_blen          =     0x1C     | length of BSSp_env           =     0x2C     | environment stringp_cmdlin        =     0x80     | command line image|| STARTUP ROUTINE (must be first object in link)|.text   .globl start   .globl _start__start:start:_start:|| save initial stack and basepage pointers|	movel  sp,a5                   | a5 = initial stack pointer	movel  sp@(4),a4                | a4 = basepage address	movel  a4,__base	movel  a4@(p_tbase),d3	addl   a4@(p_tlen),d3	movel  d3,_etext               | end of text segment	movel  a4@(p_dbase),d3	addl   a4@(p_dlen),d3	movel  d3,_edata               | end of data segment	movel  a4@(p_bbase),d3	addl   a4@(p_blen),d3	movel  d3,_end                 | end of BSS (end of program)	movel  d3,__BREAK;             | set initial _break value	movel  a4@(p_env),__envp        | save environment pointer|| call C function to get command line arguments|	lea   a4@(p_cmdlin),a0         | get pointer to command line image	moveb  a0@+,d0	extw   d0                     | extract length|	movew  d0,sp@-                | cmdlen|	movel  a0,sp@-                | cmdline|	jsr     __initar              | call _initargs(cmdline, cmdlen)|	addql  #6,sp   movew  d0,__ARGC              | save length   movel  a0,__ARGS              | save pointer to string|| calculate free space available to program|	movel  __BREAK,d3	movel  d3,a3                   | a3 = base of free space	negl   d3	addl   a4@(p_hitpa),d3	subl   #MARGIN,d3              | d3 = free space|| calculate new stack size (store in d2)|| ASSUME 8K STACK FOR THE MOMENT. 	movel   __stklen,d2            | d2 = _STKSIZ 	tstl    d2                     | if __STKSIZ is zero	beq     minimum                |   use MINSTK	bra     setstk                 |   use __STKSIZminimum:	movel  #MINSTK,d2              |   use MINSTK|| check to see if there is enough room for requested stack|setstk:	cmpl   d3,d2	blt     shrink                  | if (available < requested)	movel  #stkerr,sp@-	movew  #Cconws,sp@-	trap    #1                      |   report a stack error	addql  #6,sp	movew  #-39,sp@-	movew  #Pterm,sp@-	trap    #1                      |   and return error -39 (ENSMEM)|| set up new stack pointer and Mshrink|shrink:	addl   a3,d2                   | new stack = free base + stack size	movel  d2,sp	subl   a4,d2                   | keep space = new stack - __base	movel  d2,sp@-	movel  a4,sp@-	clrw   sp@-	movew  #Mshrink,sp@-	trap    #1                      | Mshrink(0, _base, keep);	addl   #12,sp|| call C entry point function _main()|	jsr     PASCALMAIN               | if _main returns   movew   #0,sp@-                  | Terminate program normally   trap    #1|	movew   d0,sp@(4)                |   insert return value and fall thru|| check for stack overflow (done after all OS traps)|chkstk:	cmpl    __BREAK,sp	bgt     nosweat                 | if (_break > sp)	movel   #stkovf,sp@-	movew   #Cconws,sp@-	trap    #1                      |   report a stack overflow	addql   #6,sp	movew   #-1,sp@-	movew   #Pterm,sp@-	trap    #1                      |   and return error -1 (ERROR)nosweat:	movel   traprtn,sp@-           | else, restore return address	rts                             | and do a normal return.|| this call to _main ensures that it the user's main() function will be| linked, even if it is in a library.|	jsr     PASCALMAIN                   | NO PATH TO THIS STATEMENT   movew   d0,sp@-   movew   #0x4c,sp@-   trap    #1|| initialized data space|.data.evenstkerr:                                 | not enough memory for stack	.ascii   "Not enough memory"   .byte     0x0d,0x0a,0x00stkovf:                                 | impending stack overflow	.ascii   "Stack overflow"   .byte     0x0d,0x0a,0x00_errno:                                 | system error number	.word   0__ARGC:                                 | number of command line args	.word   0__ARGS:                                 | pointer to command line arg list	.long   0|| uninitialized data space|.even__base:                                 | pointer to basepage   .long  0_etext:                                 | pointer to end of text segment   .long  0_edata:                                 | pointer to end of data segment   .long  0_end:                                   | pointer to end of BSS (end of program)   .long  0__BREAK:                                | pointer to stack/heap break   .long 0__envp:                                 | pointer to environment string   .long 0traprtn:                                | storage for return PC in trap hooks   .long 0
 |