Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch Move mainbus(4) driver files in various x86 sub-arc...



details:   https://anonhg.NetBSD.org/src/rev/113467d84b7a
branches:  trunk
changeset: 995420:113467d84b7a
user:      cherry <cherry%NetBSD.org@localhost>
date:      Sat Dec 22 06:33:36 2018 +0000

description:
Move mainbus(4) driver files in various x86 sub-archs to name prefixed
versions. This allows us to further modularise them by unifying common
bus probe code in x86/x86/mainbus.c to  be introduced next.

This commit has no functional changes. It is done for ease of
visibility of newer diffs in the queue.

diffstat:

 sys/arch/amd64/amd64/amd64_mainbus.c |  326 ++++++++++++++++++++++++
 sys/arch/amd64/amd64/mainbus.c       |  326 ------------------------
 sys/arch/amd64/conf/files.amd64      |    4 +-
 sys/arch/i386/conf/files.i386        |    4 +-
 sys/arch/i386/i386/i386_mainbus.c    |  465 +++++++++++++++++++++++++++++++++++
 sys/arch/i386/i386/mainbus.c         |  465 -----------------------------------
 sys/arch/xen/conf/files.xen          |    4 +-
 sys/arch/xen/x86/mainbus.c           |  225 ----------------
 sys/arch/xen/x86/xen_mainbus.c       |  225 ++++++++++++++++
 9 files changed, 1022 insertions(+), 1022 deletions(-)

diffs (truncated from 2110 to 300 lines):

diff -r 5b46f8f4d92a -r 113467d84b7a sys/arch/amd64/amd64/amd64_mainbus.c
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/sys/arch/amd64/amd64/amd64_mainbus.c      Sat Dec 22 06:33:36 2018 +0000
@@ -0,0 +1,326 @@
+/*     $NetBSD: amd64_mainbus.c,v 1.1 2018/12/22 06:33:36 cherry Exp $ */
+
+/*
+ * Copyright (c) 1996 Christopher G. Demetriou.  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. All advertising materials mentioning features or use of this software
+ *    must display the following acknowledgement:
+ *      This product includes software developed by Christopher G. Demetriou
+ *     for the NetBSD Project.
+ * 4. 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.
+ */
+
+#include <sys/cdefs.h>
+__KERNEL_RCSID(0, "$NetBSD: amd64_mainbus.c,v 1.1 2018/12/22 06:33:36 cherry Exp $");
+
+#include <sys/param.h>
+#include <sys/systm.h>
+#include <sys/device.h>
+#include <sys/reboot.h>
+#include <sys/bus.h>
+
+#include <dev/isa/isavar.h>
+#include <dev/pci/pcivar.h>
+
+#include <dev/isa/isareg.h>
+
+#include "pci.h"
+#include "isa.h"
+#include "isadma.h"
+#include "acpica.h"
+#include "ipmi.h"
+
+#include "opt_acpi.h"
+#include "opt_mpbios.h"
+#include "opt_pcifixup.h"
+
+#include <machine/cpuvar.h>
+#include <machine/i82093var.h>
+#include <machine/mpbiosvar.h>
+#include <machine/mpacpi.h>
+
+#if NACPICA > 0
+#include <dev/acpi/acpivar.h>
+#endif
+
+#if NIPMI > 0
+#include <x86/ipmivar.h>
+#endif
+
+#if NPCI > 0
+#if defined(PCI_BUS_FIXUP)
+#include <arch/x86/pci/pci_bus_fixup.h>
+#if defined(PCI_ADDR_FIXUP)
+#include <arch/x86/pci/pci_addr_fixup.h>
+#endif
+#endif
+#ifdef __HAVE_PCI_MSI_MSIX
+#include <arch/x86/pci/msipic.h>
+#endif /* __HAVE_PCI_MSI_MSIX */
+#endif
+
+/*
+ * XXXfvdl ACPI
+ */
+
+int    mainbus_match(device_t, cfdata_t, void *);
+void   mainbus_attach(device_t, device_t, void *);
+
+CFATTACH_DECL_NEW(mainbus, 0,
+    mainbus_match, mainbus_attach, NULL, NULL);
+
+int    mainbus_print(void *, const char *);
+
+union mainbus_attach_args {
+       const char *mba_busname;                /* first elem of all */
+       struct pcibus_attach_args mba_pba;
+       struct isabus_attach_args mba_iba;
+       struct cpu_attach_args mba_caa;
+#if NACPICA > 0
+       struct acpibus_attach_args mba_acpi;
+#endif
+       struct apic_attach_args aaa_caa;
+#if NIPMI > 0
+       struct ipmi_attach_args mba_ipmi;
+#endif
+};
+
+/*
+ * This is set when the ISA bus is attached.  If it's not set by the
+ * time it's checked below, then mainbus attempts to attach an ISA.
+ */
+int    isa_has_been_seen;
+struct x86_isa_chipset x86_isa_chipset;
+#if NISA > 0
+static const struct isabus_attach_args mba_iba = {
+       ._iba_busname = "isa",
+       .iba_dmat = &isa_bus_dma_tag,
+       .iba_ic = &x86_isa_chipset
+};
+#endif
+
+#if defined(MPBIOS) || NACPICA > 0
+struct mp_bus *mp_busses;
+int mp_nbus;
+struct mp_intr_map *mp_intrs;
+int mp_nintr;
+ 
+int mp_isa_bus = -1;
+int mp_eisa_bus = -1;
+
+bool acpi_present;
+bool mpacpi_active;
+
+# ifdef MPVERBOSE
+#  if MPVERBOSE > 0
+int mp_verbose = MPVERBOSE;
+#  else
+int mp_verbose = 1;
+#  endif
+# else
+int mp_verbose = 0;
+# endif
+#endif
+
+
+/*
+ * Probe for the mainbus; always succeeds.
+ */
+int
+mainbus_match(device_t parent, cfdata_t match, void *aux)
+{
+
+       return 1;
+}
+
+/*
+ * Attach the mainbus.
+ */
+void
+mainbus_attach(device_t parent, device_t self, void *aux)
+{
+#if NPCI > 0 || NACPICA > 0 || NIPMI > 0
+       union mainbus_attach_args mba;
+#endif
+#if NPCI > 0
+       int mode;
+#endif
+#ifdef MPBIOS
+       int mpbios_present = 0;
+#endif
+       int numcpus = 0;
+#if defined(PCI_BUS_FIXUP)
+       int pci_maxbus = 0;
+#endif
+
+       aprint_naive("\n");
+       aprint_normal("\n");
+
+#ifdef MPBIOS
+       mpbios_present = mpbios_probe(self);
+#endif
+
+#if NPCI > 0
+#ifdef __HAVE_PCI_MSI_MSIX
+       msipic_init();
+#endif
+
+       /*
+        * ACPI needs to be able to access PCI configuration space.
+        */
+       mode = pci_mode_detect();
+#if defined(PCI_BUS_FIXUP)
+       if (mode != 0) {
+               pci_maxbus = pci_bus_fixup(NULL, 0);
+               aprint_debug("PCI bus max, after pci_bus_fixup: %i\n",
+                   pci_maxbus);
+#if defined(PCI_ADDR_FIXUP)
+               pciaddr.extent_port = NULL;
+               pciaddr.extent_mem = NULL;
+               pci_addr_fixup(NULL, pci_maxbus);
+#endif
+       }
+#endif
+#endif
+
+#if NACPICA > 0
+       if ((boothowto & RB_MD2) == 0 && acpi_check(self, "acpibus"))
+               acpi_present = acpi_probe() != 0;
+       /*
+        * First, see if the MADT contains CPUs, and possibly I/O APICs.
+        * Building the interrupt routing structures can only
+        * be done later (via a callback).
+        */
+       if (acpi_present)
+               mpacpi_active = mpacpi_scan_apics(self, &numcpus) != 0;
+
+       if (!mpacpi_active) {
+#endif         
+#ifdef MPBIOS
+               if (mpbios_present)
+                       mpbios_scan(self, &numcpus);
+               else
+#endif
+               if (numcpus == 0) {
+                       struct cpu_attach_args caa;
+                        
+                       memset(&caa, 0, sizeof(caa));
+                       caa.cpu_number = 0;
+                       caa.cpu_role = CPU_ROLE_SP;
+                       caa.cpu_func = 0;
+                        
+                       config_found_ia(self, "cpubus", &caa, mainbus_print);
+               }
+#if NACPICA > 0                
+       }
+#endif
+
+#if NISADMA > 0 && NACPICA > 0
+       /*
+        * ACPI needs ISA DMA initialized before they start probing.
+        */
+       isa_dmainit(&x86_isa_chipset, x86_bus_space_io, &isa_bus_dma_tag,
+           self);
+#endif
+
+#if NACPICA > 0
+       if (acpi_present) {
+               mba.mba_acpi.aa_iot = x86_bus_space_io;
+               mba.mba_acpi.aa_memt = x86_bus_space_mem;
+               mba.mba_acpi.aa_pc = NULL;
+               mba.mba_acpi.aa_pciflags =
+                   PCI_FLAGS_IO_OKAY | PCI_FLAGS_MEM_OKAY |
+                   PCI_FLAGS_MRL_OKAY | PCI_FLAGS_MRM_OKAY |
+                   PCI_FLAGS_MWI_OKAY;
+               mba.mba_acpi.aa_ic = &x86_isa_chipset;
+               mba.mba_acpi.aa_dmat = &pci_bus_dma_tag;
+               mba.mba_acpi.aa_dmat64 = &pci_bus_dma64_tag;
+               config_found_ia(self, "acpibus", &mba.mba_acpi, 0);
+       }
+#endif
+
+#if NIPMI > 0
+       memset(&mba.mba_ipmi, 0, sizeof(mba.mba_ipmi));
+       mba.mba_ipmi.iaa_iot = x86_bus_space_io;
+       mba.mba_ipmi.iaa_memt = x86_bus_space_mem;
+       if (ipmi_probe(&mba.mba_ipmi))
+               config_found_ia(self, "ipmibus", &mba.mba_ipmi, 0);
+#endif
+
+#if NPCI > 0
+       if (mode != 0) {
+               int npcibus = 0;
+
+               mba.mba_pba.pba_iot = x86_bus_space_io;
+               mba.mba_pba.pba_memt = x86_bus_space_mem;
+               mba.mba_pba.pba_dmat = &pci_bus_dma_tag;
+               mba.mba_pba.pba_dmat64 = &pci_bus_dma64_tag;
+               mba.mba_pba.pba_pc = NULL;
+               mba.mba_pba.pba_flags =
+                   PCI_FLAGS_IO_OKAY | PCI_FLAGS_MEM_OKAY |
+                   PCI_FLAGS_MRL_OKAY | PCI_FLAGS_MRM_OKAY |
+                   PCI_FLAGS_MWI_OKAY;
+               mba.mba_pba.pba_bus = 0;
+               mba.mba_pba.pba_bridgetag = NULL;
+#if NACPICA > 0 && defined(ACPI_SCANPCI)
+               if (npcibus == 0 && mpacpi_active)
+                       npcibus = mp_pci_scan(self, &mba.mba_pba, pcibusprint);
+#endif
+#if defined(MPBIOS) && defined(MPBIOS_SCANPCI)
+               if (npcibus == 0 && mpbios_scanned != 0)
+                       npcibus = mp_pci_scan(self, &mba.mba_pba, pcibusprint);
+#endif
+               if (npcibus == 0)
+                       config_found_ia(self, "pcibus", &mba.mba_pba,
+                           pcibusprint);
+



Home | Main Index | Thread Index | Old Index