1 1.3 christos /* $NetBSD: eisa_machdep.h,v 1.3 2014/03/29 19:28:29 christos Exp $ */ 2 1.1 garbled 3 1.1 garbled /* 4 1.1 garbled * Copyright (c) 1996 Christopher G. Demetriou. All rights reserved. 5 1.1 garbled * 6 1.1 garbled * Redistribution and use in source and binary forms, with or without 7 1.1 garbled * modification, are permitted provided that the following conditions 8 1.1 garbled * are met: 9 1.1 garbled * 1. Redistributions of source code must retain the above copyright 10 1.1 garbled * notice, this list of conditions and the following disclaimer. 11 1.1 garbled * 2. Redistributions in binary form must reproduce the above copyright 12 1.1 garbled * notice, this list of conditions and the following disclaimer in the 13 1.1 garbled * documentation and/or other materials provided with the distribution. 14 1.1 garbled * 3. All advertising materials mentioning features or use of this software 15 1.1 garbled * must display the following acknowledgement: 16 1.1 garbled * This product includes software developed by Christopher G. Demetriou 17 1.1 garbled * for the NetBSD Project. 18 1.1 garbled * 4. The name of the author may not be used to endorse or promote products 19 1.1 garbled * derived from this software without specific prior written permission 20 1.1 garbled * 21 1.1 garbled * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 22 1.1 garbled * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 23 1.1 garbled * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 24 1.1 garbled * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 25 1.1 garbled * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 26 1.1 garbled * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 27 1.1 garbled * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 28 1.1 garbled * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 29 1.1 garbled * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 30 1.1 garbled * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 31 1.1 garbled */ 32 1.1 garbled 33 1.1 garbled /* 34 1.1 garbled * Machine-specific definitions for EISA autoconfiguration. 35 1.1 garbled */ 36 1.1 garbled 37 1.1 garbled /* 38 1.1 garbled * prep-specific EISA definitions. 39 1.1 garbled * NOT TO BE USED DIRECTLY BY MACHINE INDEPENDENT CODE. 40 1.1 garbled */ 41 1.1 garbled #define EISA_ID "EISA" 42 1.1 garbled #define EISA_ID_LEN (sizeof(EISA_ID) - 1) 43 1.1 garbled #define EISA_ID_PADDR 0xfffd9 44 1.1 garbled 45 1.1 garbled extern struct powerpc_bus_dma_tag eisa_bus_dma_tag; 46 1.1 garbled 47 1.1 garbled /* EISA Edge/Level trigger control registers */ 48 1.1 garbled #define ELCR0 0x4d0 /* eisa irq 0-7 */ 49 1.1 garbled #define ELCR1 0x4d1 /* eisa irq 8-15 */ 50 1.1 garbled 51 1.1 garbled /* 52 1.1 garbled * Types provided to machine-independent EISA code. 53 1.1 garbled */ 54 1.1 garbled typedef void *eisa_chipset_tag_t; 55 1.1 garbled typedef int eisa_intr_handle_t; 56 1.1 garbled 57 1.1 garbled /* 58 1.1 garbled * Functions provided to machine-independent EISA code. 59 1.1 garbled */ 60 1.2 matt void eisa_attach_hook(device_t, device_t, 61 1.1 garbled struct eisabus_attach_args *); 62 1.1 garbled int eisa_maxslots(eisa_chipset_tag_t); 63 1.1 garbled int eisa_intr_map(eisa_chipset_tag_t, u_int, 64 1.1 garbled eisa_intr_handle_t *); 65 1.3 christos const char *eisa_intr_string(eisa_chipset_tag_t, eisa_intr_handle_t, 66 1.3 christos char *, size_t); 67 1.1 garbled const struct evcnt *eisa_intr_evcnt(eisa_chipset_tag_t, eisa_intr_handle_t); 68 1.1 garbled void *eisa_intr_establish(eisa_chipset_tag_t, 69 1.1 garbled eisa_intr_handle_t, int, int, int (*)(void *), void *); 70 1.1 garbled void eisa_intr_disestablish(eisa_chipset_tag_t, void *); 71 1.1 garbled int eisa_mem_alloc(bus_space_tag_t, bus_size_t, bus_size_t, 72 1.1 garbled bus_addr_t, int, bus_addr_t *, bus_space_handle_t *); 73 1.1 garbled void eisa_mem_free(bus_space_tag_t, bus_space_handle_t, 74 1.1 garbled bus_size_t); 75 1.1 garbled 76 1.1 garbled int eisa_conf_read_mem(eisa_chipset_tag_t, int, int, int, 77 1.1 garbled struct eisa_cfg_mem *); 78 1.1 garbled int eisa_conf_read_irq(eisa_chipset_tag_t, int, int, int, 79 1.1 garbled struct eisa_cfg_irq *); 80 1.1 garbled int eisa_conf_read_dma(eisa_chipset_tag_t, int, int, int, 81 1.1 garbled struct eisa_cfg_dma *); 82 1.1 garbled int eisa_conf_read_io(eisa_chipset_tag_t, int, int, int, 83 1.1 garbled struct eisa_cfg_io *); 84