RTEMS 6.1-rc1
cfg_auto.h
Go to the documentation of this file.
1/* SPDX-License-Identifier: BSD-2-Clause */
2
9/*
10 * COPYRIGHT (c) 2010 Cobham Gaisler AB.
11 *
12 * Redistribution and use in source and binary forms, with or without
13 * modification, are permitted provided that the following conditions
14 * are met:
15 * 1. Redistributions of source code must retain the above copyright
16 * notice, this list of conditions and the following disclaimer.
17 * 2. Redistributions in binary form must reproduce the above copyright
18 * notice, this list of conditions and the following disclaimer in the
19 * documentation and/or other materials provided with the distribution.
20 *
21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
22 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
25 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
26 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
27 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
28 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
29 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
30 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
31 * POSSIBILITY OF SUCH DAMAGE.
32 */
33
34#ifndef __PCI_CFG_AUTO_H__
35#define __PCI_CFG_AUTO_H__
36
37#define CFGOPT_NOSETUP_IRQ 0x1 /* Skip IRQ setup */
38
39/* PCI Memory Layout setup, used by the auto-config library in order to
40 * determine the addresses of PCI BARs and Buses.
41 *
42 * All addresses are in PCI address space, the actual address the CPU access
43 * may be different, and taken care of elsewhere.
44 */
46 int options;
47
48 /* PCI prefetchable Memory space (OPTIONAL) */
49 uint32_t mem_start;
50 uint32_t mem_size; /* 0 = Use MEMIO space for prefetchable mem BARs */
51
52 /* PCI non-prefetchable Memory */
53 uint32_t memio_start;
54 uint32_t memio_size;
55
56 /* PCI I/O space (OPTIONAL) */
57 uint32_t io_start;
58 uint32_t io_size; /* 0 = No I/O space */
59
60 /* Get System IRQ connected to a PCI line of a PCI device on bus0.
61 * The return IRQ value zero equals no IRQ (IRQ disabled).
62 */
63 uint8_t (*irq_map)(pci_dev_t dev, int irq_pin);
64
65 /* IRQ Bridge routing. Returns the interrupt pin (0..3 = A..D) that
66 * a device is connected to on parent bus.
67 */
68 int (*irq_route)(pci_dev_t dev, int irq_pin);
69};
70
71/* Do PCI initialization: Enumrate buses, scan buses for devices, assign
72 * I/O MEM and MEMIO resources, assign IRQ and so on.
73 */
74extern int pci_config_auto(void);
75
76/* Register a configuration for the auto library (struct pci_auto_setup *) */
77extern void pci_config_auto_register(void *config);
78
79/* PCI memory map */
80extern struct pci_auto_setup pci_auto_cfg;
81
82#endif
Definition: deflate.c:114
Definition: cfg_auto.h:45