pio.h revision 1.4 1 1.4 tsutsui /* $NetBSD: pio.h,v 1.4 2005/01/22 07:35:34 tsutsui Exp $ */
2 1.2 soda /* $OpenBSD: pio.h,v 1.3 1997/04/19 17:19:58 pefo Exp $ */
3 1.1 jonathan
4 1.1 jonathan /*
5 1.1 jonathan * Copyright (c) 1995 Per Fogelstrom. All rights reserved.
6 1.1 jonathan *
7 1.1 jonathan * Redistribution and use in source and binary forms, with or without
8 1.1 jonathan * modification, are permitted provided that the following conditions
9 1.1 jonathan * are met:
10 1.1 jonathan * 1. Redistributions of source code must retain the above copyright
11 1.1 jonathan * notice, this list of conditions and the following disclaimer.
12 1.1 jonathan * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 jonathan * notice, this list of conditions and the following disclaimer in the
14 1.1 jonathan * documentation and/or other materials provided with the distribution.
15 1.1 jonathan * 3. All advertising materials mentioning features or use of this software
16 1.1 jonathan * must display the following acknowledgement:
17 1.2 soda * This product includes software developed by Per Fogelstrom.
18 1.1 jonathan * 4. The name of the author may not be used to endorse or promote products
19 1.1 jonathan * derived from this software without specific prior written permission
20 1.1 jonathan *
21 1.1 jonathan * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
22 1.1 jonathan * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
23 1.1 jonathan * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
24 1.1 jonathan * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
25 1.1 jonathan * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
26 1.1 jonathan * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27 1.1 jonathan * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28 1.1 jonathan * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29 1.1 jonathan * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
30 1.1 jonathan * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31 1.1 jonathan */
32 1.1 jonathan
33 1.2 soda #ifndef _ARC_PIO_H_
34 1.2 soda #define _ARC_PIO_H_
35 1.1 jonathan /*
36 1.1 jonathan * I/O macros.
37 1.1 jonathan */
38 1.1 jonathan
39 1.1 jonathan #define outb(a,v) (*(volatile unsigned char*)(a) = (v))
40 1.1 jonathan #define outw(a,v) (*(volatile unsigned short*)(a) = (v))
41 1.1 jonathan #define out16(a,v) outw(a,v)
42 1.1 jonathan #define outl(a,v) (*(volatile unsigned int*)(a) = (v))
43 1.1 jonathan #define out32(a,v) outl(a,v)
44 1.1 jonathan #define inb(a) (*(volatile unsigned char*)(a))
45 1.1 jonathan #define inw(a) (*(volatile unsigned short*)(a))
46 1.1 jonathan #define in16(a) inw(a)
47 1.1 jonathan #define inl(a) (*(volatile unsigned int*)(a))
48 1.1 jonathan #define in32(a) inl(a)
49 1.1 jonathan
50 1.4 tsutsui void insb(uint8_t *, uint8_t *,int);
51 1.4 tsutsui void insw(uint16_t *, uint16_t *,int);
52 1.4 tsutsui void insl(uint32_t *, uint32_t *,int);
53 1.4 tsutsui void outsb(uint8_t *, const uint8_t *,int);
54 1.4 tsutsui void outsw(uint16_t *, const uint16_t *,int);
55 1.4 tsutsui void outsl(uint32_t *, const uint32_t *,int);
56 1.3 soda
57 1.3 soda extern struct arc_bus_space arc_bus_io, arc_bus_mem;
58 1.2 soda
59 1.2 soda #endif /*_ARC_PIO_H_*/
60