8206c3e00b
INO) for incorrect interrupt map entries on E250 machines. These incorrect entries caused the INO of the on-board HME to be also assigned to the second on-board NS16550 and to the on-board printer port controller. Further down the road caused hme(4) to fail to attach to the on-board HME in FreeBSD 5 and 6 as INTR_FAST and non-INTR_FAST handlers can't share the same IRQ there (it's unknown what whould happen in -CURRENT now that INTR_FAST and non-INTR_FAST handlers can share an IRQ but I'd expect funny problems with uart(4)). - Make sure there are exactly 4 PCI ranges instead of just checking that the bridge has a 'ranges' property in the OFW device tree at all. Besides the fact that currently the 64bit memory range isn't used by this driver it we can't really work with less than 4 ranges and don't have memory for more than 4 bus handles for the ranges in the softc. - Remove sc_range and sc_nrange from softc; for the bridges supported by this driver we no longer need to know the ranges besides the bus handles obtained from them once this driver is attached. That way we also can free the memory allocated for sc_range during attach again. - Remove sc_dvmabase from the softc and pass it to psycho_iommu_init() via an additional argument as we no longer need to know the DVMA base in this driver once the IOMMU is initialized. - Remove sc_dmatag from the softc, there isn't much sense in keeping the nexus dma tag around locally. PR: 88279 [1] Info from: OpenSolaris [1] Tested by: kensmith [1] MFC after: 1 month
87 lines
2.7 KiB
C
87 lines
2.7 KiB
C
/*-
|
|
* Copyright (c) 1999, 2000 Matthew R. Green
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
* documentation and/or other materials provided with the distribution.
|
|
* 3. The name of the author may not be used to endorse or promote products
|
|
* derived from this software without specific prior written permission.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
|
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
|
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
|
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
|
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
* SUCH DAMAGE.
|
|
*
|
|
* from: NetBSD: psychovar.h,v 1.6 2001/07/20 00:07:13 eeh Exp
|
|
*
|
|
* $FreeBSD$
|
|
*/
|
|
|
|
#ifndef _SPARC64_PCI_PSYCHOVAR_H_
|
|
#define _SPARC64_PCI_PSYCHOVAR_H_
|
|
|
|
/*
|
|
* Per-PCI bus on mainbus softc structure; one for sabre, or two
|
|
* per pair of psychos.
|
|
*/
|
|
struct psycho_softc {
|
|
device_t sc_dev;
|
|
vm_paddr_t sc_basepaddr;
|
|
|
|
/* Interrupt Group Number for this device */
|
|
int sc_ign;
|
|
|
|
/* Our tags (from parent) */
|
|
bus_space_tag_t sc_bustag;
|
|
bus_space_handle_t sc_bushandle;
|
|
|
|
bus_addr_t sc_pcictl;
|
|
|
|
phandle_t sc_node; /* Firmware node */
|
|
int sc_mode;
|
|
#define PSYCHO_MODE_SABRE 1
|
|
#define PSYCHO_MODE_PSYCHO 2
|
|
|
|
/* Bus A or B of a psycho pair? */
|
|
int sc_half;
|
|
|
|
struct iommu_state *sc_is;
|
|
|
|
struct resource *sc_mem_res;
|
|
struct resource *sc_irq_res[PSYCHO_NINTR];
|
|
void *sc_ihand[PSYCHO_NINTR];
|
|
|
|
struct ofw_bus_iinfo sc_pci_iinfo;
|
|
|
|
/* Tags for PCI access */
|
|
bus_space_tag_t sc_pci_cfgt;
|
|
bus_space_tag_t sc_pci_memt;
|
|
bus_space_tag_t sc_pci_iot;
|
|
bus_dma_tag_t sc_pci_dmat;
|
|
|
|
bus_space_handle_t sc_pci_bh[PSYCHO_NRANGE];
|
|
|
|
u_int sc_pci_secbus;
|
|
u_int sc_pci_subbus;
|
|
|
|
struct rman sc_pci_mem_rman;
|
|
struct rman sc_pci_io_rman;
|
|
|
|
SLIST_ENTRY(psycho_softc) sc_link;
|
|
};
|
|
|
|
#endif /* !_SPARC64_PCI_PSYCHOVAR_H_ */
|