1 1.5 christos /* $NetBSD: pio.h,v 1.5 2005/12/11 12:16:39 christos 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