xref: /netbsd/sys/arch/landisk/stand/bootxx/bootxx.S (revision 6550d01e)
1/*	$NetBSD: bootxx.S,v 1.1 2006/09/01 21:26:19 uwe Exp $	*/
2
3/*-
4 * Copyright (c) 2005 NONAKA Kimihiro
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 *
16 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
17 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19 * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
20 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26 * SUCH DAMAGE.
27 */
28
29#include <machine/asm.h>
30#include <sys/bootblock.h>
31
32ENTRY(bootxx_start)
33	bra	bootxx_start1
34	 nop
35	.balign 4
36ENTRY(bootxx_magic)
37	.long	LANDISK_BOOT_MAGIC_1
38boot_params:
39	.long	1f - boot_params
40#include <boot_params.S>
41
42	. = bootxx_start + 0x80
43bootxx_start1:
44	mov.l	.L._end, r0		/* zero bss */
45	mov.l	.L.__bss_start, r1
46	sub	r1, r0
47	shlr2	r0			/* _end and __bss_start are aligned */
48	mov	#0, r2
491:	mov.l	r2, @r1
50	dt	r0
51	bf/s	1b
52	 add	#4, r1
53
54	mov.l	.L.2nd_loadaddr, r15	/* new stack pointer */
55	mov.l	r4, @-r15
56	mov.l	.L.boot1, r0
57	jsr	@r0
58	 mov	r15, r4
59
60	tst	r0, r0
61	bf/s	boot_fail
62	 mov.l	@r15+, r5		/* pass boot sector to boot */
63
64	/* flush cache */
65	mov	#0, r4
66	mov	#6, r0
67	trapa	#0x3f
68
69	mov.l	.L.2nd_loadaddr, r0
70	mov.l	.L.boot_params, r4
71	jmp	@r0
72	 nop
73
74boot_fail:
75	mov	r0, r1
76	mova	.L.errtxt, r0
77	mov	r0, r4
78	mov	#32, r0
79	trapa	#0x3f
80	mov	r1, r4
81	mov	#32, r0
82	trapa	#0x3f
83	mova	.L.crlf, r0
84	mov	r0, r4
85	mov	#32, r0
86	trapa	#0x3f
8799:	bra	99b
88	 nop
89
90
91	.align	2
92.L._end:
93	.long	_end
94.L.__bss_start:
95	.long	__bss_start
96.L.boot1:
97	.long	_C_LABEL(boot1)
98.L.2nd_loadaddr:
99	.long	SECONDARY_LOAD_ADDRESS
100.L.boot_params:
101	.long	boot_params
102
103	.align	2
104.L.errtxt:	.asciz	"Error: "
105	.align	2
106.L.crlf:	.asciz	"\r\n"
107
108
109	/*
110	 * Vector the fs calls through here so we can support multiple
111	 * file system types with one copy of the library code and
112	 * multiple copies of this file.
113	 */
114ENTRY(xxfs_open)
115	mov.l	1f, r0
116	jmp	@r0
117	 nop
118	.align	2
1191:	.long	_C_LABEL(XXfs_open)
120
121ENTRY(xxfs_close)
122	mov.l	1f, r0
123	jmp	@r0
124	 nop
125	.align	2
1261:	.long	_C_LABEL(XXfs_close)
127
128ENTRY(xxfs_read)
129	mov.l	1f, r0
130	jmp	@r0
131	 nop
132	.align	2
1331:	.long	_C_LABEL(XXfs_read)
134
135ENTRY(xxfs_stat)
136	mov.l	1f, r0
137	jmp	@r0
138	 nop
139	.align	2
1401:	.long	_C_LABEL(XXfs_stat)
141
142
143
144/*
145 * int readsects(int dev, uint32_t lba, void *buf, size_t size);
146 */
147ENTRY(readsects)
148	mov	#2, r0
149	trapa	#0x3f
150	rts
151	 nop
152argerror:
153	rts
154	 mov	#-1, r0
155
156/*
157 * void putstr(const char *str);
158 */
159ENTRY(putstr)
160	mov	#32, r0
161	trapa	#0x3f
162	rts
163	 nop
164