Home | History | Annotate | Line # | Download | only in boot32
rmheader.S revision 1.2
      1 /*	$NetBSD: rmheader.S,v 1.2 2003/01/08 15:29:09 reinoud Exp $	*/
      2 
      3 /*-
      4  * Copyright (c) 2001 Ben Harris
      5  * All rights reserved.
      6  *
      7  * Redistribution and use in source and binary forms, with or without
      8  * modification, are permitted provided that the following conditions
      9  * are met:
     10  * 1. Redistributions of source code must retain the above copyright
     11  *    notice, this list of conditions and the following disclaimer.
     12  * 2. Redistributions in binary form must reproduce the above copyright
     13  *    notice, this list of conditions and the following disclaimer in the
     14  *    documentation and/or other materials provided with the distribution.
     15  * 3. The name of the author may not be used to endorse or promote products
     16  *    derived from this software without specific prior written permission.
     17  *
     18  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
     19  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
     20  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
     21  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
     22  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
     23  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
     24  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
     25  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
     26  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
     27  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
     28  */
     29 
     30 /*
     31  * Relocatable module header for boot32.
     32  */
     33 
     34 #include <riscoscalls.h>
     35 
     36 rmbase:
     37 	b	rmstart			/* Start code */
     38 	.word	0			/* Initialisation code */
     39 	.word	0			/* Finalisation code */
     40 	.word	0			/* Service call handler */
     41 	.word	rmtitle - rmbase	/* Title string */
     42 	.word	rmhelp - rmbase		/* Help string */
     43 	.word	rmcmdtbl - rmbase	/* Help and command keyword table */
     44 
     45 rmtitle:
     46 	.asciz	"boot32"
     47 	.align
     48 rmstart:
     49 	/*
     50 	 * This entry point is called when we're started up as an application,
     51 	 * so we're allowed to use application workspace.  This is good,
     52 	 * because most of our code is linked to run at 0x8000.
     53 	 */
     54 	mov	r0, #0x8000
     55 	adr	r1, rmbase
     56 	ldr	r2, Lsize
     57 Lcopyloop:
     58 	ldr	r3, [r1], #4
     59 	str	r3, [r0], #4
     60 	subs	r2, r2, #4
     61 	bgt	Lcopyloop
     62 	mov	r0, #0x8000
     63 	mov	r1, #128*1024
     64 LDsync_loop:
     65 	ldrb	r3, [r0], #1
     66 	subs	r1, r1, #1
     67 	bgt	LDsync_loop
     68 	ldr	r0, Lstart
     69 	mov	pc, r0
     70 
     71 	/*
     72 	 * The size of the code/data to be moved is not `end - rmbase' but
     73 	 * `__bss_start__ - rmbase' for the module is loaded into RISC OS
     74 	 * based on the filesize where as NetBSD doesn't have to include all
     75 	 * the bss space into the file itself. In some odd cases the
     76 	 * relocatable module area can be smaller than the module + bss and
     77 	 * thus bomb out.
     78 	 */
     79 Lsize:
     80 	.word	__bss_start__ - rmbase
     81 Lstart:
     82 	.word	_start
     83 
     84 rmcmdtbl:
     85 	.asciz	"boot32"		/* Command text */
     86 	.align
     87 	.word	rmcmd_boot32 - rmbase	/* Command code */
     88 	.byte	0x00			/* Min 0 parameters */
     89 	.byte	0x00			/* No GSTransed parameters */
     90 	.byte	0xff			/* Max 255 parameters */
     91 	.byte	0x00			/* Normal command */
     92 	.word	0			/* No syntax message */
     93 	.word	0			/* No help message */
     94 
     95 rmcmd_boot32:
     96 	/* We're called with r0 -> command tail. */
     97 	stmfd	r13!, {r14}
     98 	mov	r2, r0
     99 	mov	r0, #2
    100 	adr	r1, rmtitle
    101 	swi	XOS_Module
    102 	ldmfd	r13!, {pc}
    103