aupcivar.h revision 1.2.22.2 1 1.2.22.2 rpaulo /* $NetBSD: aupcivar.h,v 1.2.22.2 2006/09/09 02:41:14 rpaulo Exp $ */
2 1.2.22.2 rpaulo
3 1.2.22.2 rpaulo /*-
4 1.2.22.2 rpaulo * Copyright (c) 2006 Itronix Inc.
5 1.2.22.2 rpaulo * All rights reserved.
6 1.2.22.2 rpaulo *
7 1.2.22.2 rpaulo * Written by Garrett D'Amore for Itronix Inc.
8 1.2.22.2 rpaulo *
9 1.2.22.2 rpaulo * Redistribution and use in source and binary forms, with or without
10 1.2.22.2 rpaulo * modification, are permitted provided that the following conditions
11 1.2.22.2 rpaulo * are met:
12 1.2.22.2 rpaulo * 1. Redistributions of source code must retain the above copyright
13 1.2.22.2 rpaulo * notice, this list of conditions and the following disclaimer.
14 1.2.22.2 rpaulo * 2. Redistributions in binary form must reproduce the above copyright
15 1.2.22.2 rpaulo * notice, this list of conditions and the following disclaimer in the
16 1.2.22.2 rpaulo * documentation and/or other materials provided with the distribution.
17 1.2.22.2 rpaulo * 3. The name of Itronix Inc. may not be used to endorse
18 1.2.22.2 rpaulo * or promote products derived from this software without specific
19 1.2.22.2 rpaulo * prior written permission.
20 1.2.22.2 rpaulo *
21 1.2.22.2 rpaulo * THIS SOFTWARE IS PROVIDED BY ITRONIX INC. ``AS IS'' AND
22 1.2.22.2 rpaulo * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
23 1.2.22.2 rpaulo * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
24 1.2.22.2 rpaulo * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL ITRONIX INC. BE LIABLE FOR ANY
25 1.2.22.2 rpaulo * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
26 1.2.22.2 rpaulo * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
27 1.2.22.2 rpaulo * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
28 1.2.22.2 rpaulo * ON ANY THEORY OF LIABILITY, WHETHER IN
29 1.2.22.2 rpaulo * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
30 1.2.22.2 rpaulo * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
31 1.2.22.2 rpaulo * POSSIBILITY OF SUCH DAMAGE.
32 1.2.22.2 rpaulo */
33 1.2.22.2 rpaulo
34 1.2.22.2 rpaulo #ifndef _MIPS_ALCHEMY_DEV_AUPCIVAR_H
35 1.2.22.2 rpaulo #define _MIPS_ALCHEMY_DEV_AUPCIVAR_H
36 1.2.22.2 rpaulo
37 1.2.22.2 rpaulo #include <dev/pci/pcivar.h>
38 1.2.22.2 rpaulo
39 1.2.22.2 rpaulo /*
40 1.2.22.2 rpaulo * PCI configuration space encompasses all 32-bits.
41 1.2.22.2 rpaulo *
42 1.2.22.2 rpaulo * PCI memory space encompasses all 32-bits, excepting that portion of
43 1.2.22.2 rpaulo * the address space that is decoded by the Alchemy core for accesses
44 1.2.22.2 rpaulo * to host memory. (That range is determined dynamically.)
45 1.2.22.2 rpaulo *
46 1.2.22.2 rpaulo * PCI I/O address range. We want to start offset from zero to avoid
47 1.2.22.2 rpaulo * potential problems with devices. These addresses do not
48 1.2.22.2 rpaulo * participate on the Alchemy system bus, hence we can choose any
49 1.2.22.2 rpaulo * range we like. 16 MB is plenty.
50 1.2.22.2 rpaulo */
51 1.2.22.2 rpaulo
52 1.2.22.2 rpaulo #define AUPCI_IO_START 0x1000000
53 1.2.22.2 rpaulo #define AUPCI_IO_END 0x1FFFFFF
54 1.2.22.2 rpaulo
55 1.2.22.2 rpaulo
56 1.2.22.2 rpaulo /*
57 1.2.22.2 rpaulo * Machdep code must implement this. Stores an IRQ number in
58 1.2.22.2 rpaulo * pci_intr_handle_t. See pci_intr_map(9) for more detail. Returns 0
59 1.2.22.2 rpaulo * on success, non-zero on failure.
60 1.2.22.2 rpaulo */
61 1.2.22.2 rpaulo int aupci_intr_map(struct pci_attach_args *, pci_intr_handle_t *);
62 1.2.22.2 rpaulo
63 1.2.22.2 rpaulo #endif /* _MIPS_ALCHEMY_DEV_AUPCIVAR_H */
64