Expand PMF_FN_* macros.
[netbsd-mini2440.git] / sys / arch / evbarm / tsarm / isa / isa_io_asm.S
blob9c8d8922f988cef78d8b68979f23277db2555121
1 /*      $NetBSD: isa_io_asm.S,v 1.2 2005/12/11 12:17:11 christos Exp $  */
3 /*-
4  * Copyright (c) 1997 The NetBSD Foundation, Inc.
5  * All rights reserved.
6  *
7  * This code is derived from software contributed to The NetBSD Foundation
8  * by Jesse Off.
9  *
10  * This code is derived from software contributed to The NetBSD Foundation
11  * by Mark Brinicombe.
12  *
13  * Redistribution and use in source and binary forms, with or without
14  * modification, are permitted provided that the following conditions
15  * are met:
16  * 1. Redistributions of source code must retain the above copyright
17  *    notice, this list of conditions and the following disclaimer.
18  * 2. Redistributions in binary form must reproduce the above copyright
19  *    notice, this list of conditions and the following disclaimer in the
20  *    documentation and/or other materials provided with the distribution.
21  *
22  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
23  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
24  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
25  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
26  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
27  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
28  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
29  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
30  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
31  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32  * POSSIBILITY OF SUCH DAMAGE.
33  */
36  * Copyright 1997
37  * Digital Equipment Corporation. All rights reserved.
38  *
39  * This software is furnished under license and may be used and
40  * copied only in accordance with the following terms and conditions.
41  * Subject to these conditions, you may download, copy, install,
42  * use, modify and distribute this software in source and/or binary
43  * form. No title or ownership is transferred hereby.
44  *
45  * 1) Any source code used, modified or distributed must reproduce
46  *    and retain this copyright notice and list of conditions as
47  *    they appear in the source file.
48  *
49  * 2) No right is granted to use any trade name, trademark, or logo of
50  *    Digital Equipment Corporation. Neither the "Digital Equipment
51  *    Corporation" name nor any trademark or logo of Digital Equipment
52  *    Corporation may be used to endorse or promote products derived
53  *    from this software without the prior written permission of
54  *    Digital Equipment Corporation.
55  *
56  * 3) This software is provided "AS-IS" and any express or implied
57  *    warranties, including but not limited to, any implied warranties
58  *    of merchantability, fitness for a particular purpose, or
59  *    non-infringement are disclaimed. In no event shall DIGITAL be
60  *    liable for any damages whatsoever, and in particular, DIGITAL
61  *    shall not be liable for special, indirect, consequential, or
62  *    incidental damages or damages for lost profits, loss of
63  *    revenue or loss of use, whether such damages arise in contract,
64  *    negligence, tort, under statute, in equity, at law or otherwise,
65  *    even if advised of the possibility of such damage.
66  */
69  * bus_space I/O functions for isa
70  */
72 #include <machine/asm.h>
74 #ifdef GPROF
75 #define PAUSE   nop ; nop ; nop ; nop ; nop
76 #else
77 #define PAUSE
78 #endif
81  * Note these functions use ARM Architecture V4 instructions as
82  * all current systems with ISA will be using processors that support
83  * V4 or later architectures (SHARK & CATS & TS7XXX)
84  */
87  * read single
88  */
90 ENTRY(isa_bs_r_1)
91         sub     r1, r1, #0x4000000      /* 8 bit space is 64Mb below in VA */
92         ldrb    r0, [r1, r2]
93         PAUSE
94         mov     pc, lr
96 ENTRY(isa_bs_r_2)
97         ldrh    r0, [r1, r2]
98         PAUSE
99         mov     pc, lr
101 ENTRY(isa_bs_r_4)
102         ldr     r0, [r1, r2]
103         PAUSE
104         mov     pc, lr
107  * read multiple.
108  */
110 ENTRY(isa_bs_rm_1)
111         add     r0, r1, r2
112         mov     r1, r3
113         sub     r0, r0, #0x4000000      /* 8 bit space is 64Mb below in VA */
114         ldr     r2, [sp, #0]
115         teq     r2, #0
116         moveq   pc, lr
118 Lisa_rm_1_loop:
119         ldrb    r3, [r0]
120         strb    r3, [r1], #1
121         subs    r2, r2, #1
122         bne     Lisa_rm_1_loop
124         mov     pc, lr
126 ENTRY(isa_bs_rm_2)
127         add     r0, r1, r2
128         mov     r1, r3
129         ldr     r2, [sp, #0]
130         teq     r2, #0
131         moveq   pc, lr
133 Lisa_rm_2_loop:
134         ldrh    r3, [r0]
135         strh    r3, [r1], #2
136         subs    r2, r2, #1
137         bne     Lisa_rm_2_loop
139         mov     pc, lr
141 ENTRY(isa_bs_rm_4)
142         add     r0, r1, r2
143         mov     r1, r3
144         ldr     r2, [sp, #0]
145         teq     r2, #0
146         moveq   pc, lr
148 Lisa_rm_4_loop:
149         ldr     r3, [r0]
150         str     r3, [r1], #4
151         subs    r2, r2, #1
152         bne     Lisa_rm_4_loop
154         mov     pc, lr
157  * read region.
158  */
160 ENTRY(isa_bs_rr_1)
161         add     r0, r1, r2
162         mov     r1, r3
163         sub     r0, r0, #0x4000000      /* 8 bit space is 64Mb below in VA */
164         ldr     r2, [sp, #0]
165         teq     r2, #0
166         moveq   pc, lr
168 Lisa_rr_1_loop:
169         ldrb    r3, [r0], #1
170         strb    r3, [r1], #1
171         subs    r2, r2, #1
172         bne     Lisa_rr_1_loop
174         mov     pc, lr
176 ENTRY(isa_bs_rr_2)
177         add     r0, r1, r2
178         mov     r1, r3
179         ldr     r2, [sp, #0]
180         teq     r2, #0
181         moveq   pc, lr
183 Lisa_rr_2_loop:
184         ldrh    r3, [r0], #2
185         strh    r3, [r1], #2
186         subs    r2, r2, #1
187         bne     Lisa_rr_2_loop
189         mov     pc, lr
191 ENTRY(isa_bs_rr_4)
192         add     r0, r1, r2
193         mov     r1, r3
194         ldr     r2, [sp, #0]
195         teq     r2, #0
196         moveq   pc, lr
198 Lisa_rr_4_loop:
199         ldr     r3, [r0], #4
200         str     r3, [r1], #4
201         subs    r2, r2, #1
202         bne     Lisa_rr_4_loop
204         mov     pc, lr
207  * write single
208  */
210 ENTRY(isa_bs_w_1)
211         sub     r1, r1, #0x4000000      /* 8 bit space is 64Mb below in VA */
212         strb    r3, [r1, r2]
213         PAUSE
214         mov     pc, lr
216 ENTRY(isa_bs_w_2)
217         strh    r3, [r1, r2]
218         PAUSE
219         mov     pc, lr
221 ENTRY(isa_bs_w_4)
222         str     r3, [r1, r2]
223         PAUSE
224         mov     pc, lr
227  * write multiple
228  */
230 ENTRY(isa_bs_wm_1)
231         add     r0, r1, r2
232         mov     r1, r3
233         sub     r0, r0, #0x4000000      /* 8 bit space is 64Mb below in VA */
234         ldr     r2, [sp, #0]
235         teq     r2, #0
236         moveq   pc, lr
238 Lisa_wm_1_loop:
239         ldrb    r3, [r1], #1
240         strb    r3, [r0]
241         subs    r2, r2, #1
242         bne     Lisa_wm_1_loop
244         mov     pc, lr
246 ENTRY(isa_bs_wm_2)
247         add     r0, r1, r2
248         mov     r1, r3
249         ldr     r2, [sp, #0]
250         teq     r2, #0
251         moveq   pc, lr
253 Lisa_wm_2_loop: 
254         ldrh    r3, [r1], #2
255         strh    r3, [r0]
256         subs    r2, r2, #1
257         bne     Lisa_wm_2_loop
259         mov     pc, lr
261 ENTRY(isa_bs_wm_4)
262         add     r0, r1, r2
263         mov     r1, r3
264         ldr     r2, [sp, #0]
265         teq     r2, #0
266         moveq   pc, lr
268 Lisa_wm_4_loop:
269         ldr     r3, [r1], #4
270         str     r3, [r0]
271         subs    r2, r2, #1
272         bne     Lisa_wm_4_loop
274         mov     pc, lr
278  * write region.
279  */
281 ENTRY(isa_bs_wr_1)
282         add     r0, r1, r2
283         mov     r1, r3
284         sub     r0, r0, #0x4000000      /* 8 bit space is 64Mb below in VA */
285         ldr     r2, [sp, #0]
286         teq     r2, #0
287         moveq   pc, lr
289 Lisa_wr_1_loop:
290         ldrb    r3, [r1], #1
291         strb    r3, [r0], #1
292         subs    r2, r2, #1
293         bne     Lisa_wr_1_loop
295         mov     pc, lr
297 ENTRY(isa_bs_wr_2)
298         add     r0, r1, r2
299         mov     r1, r3
300         ldr     r2, [sp, #0]
301         teq     r2, #0
302         moveq   pc, lr
304 Lisa_wr_2_loop: 
305         ldrh    r3, [r1], #2
306         strh    r3, [r0], #2
307         subs    r2, r2, #1
308         bne     Lisa_wr_2_loop
310         mov     pc, lr
312 ENTRY(isa_bs_wr_4)
313         add     r0, r1, r2
314         mov     r1, r3
315         ldr     r2, [sp, #0]
316         teq     r2, #0
317         moveq   pc, lr
319 Lisa_wr_4_loop:
320         ldr     r3, [r1], #4
321         str     r3, [r0], #4
322         subs    r2, r2, #1
323         bne     Lisa_wr_4_loop
325         mov     pc, lr
328  * Set region
329  */
331 ENTRY(isa_bs_sr_2)
332         add     r0, r1, r2
333         mov     r1, r3
334         ldr     r2, [sp, #0]
335         teq     r2, #0
336         moveq   pc, lr
338 Lisa_bs_sr_2_loop:
339         strh    r1, [r0], #2
340         subs    r2, r2, #1
341         bne     Lisa_bs_sr_2_loop
343         mov     pc, lr