2007-02-02 09:48:19 -07:00
|
|
|
/*
|
2005-04-16 15:20:36 -07:00
|
|
|
* This file is subject to the terms and conditions of the GNU General Public
|
|
|
|
* License. See the file "COPYING" in the main directory of this archive
|
|
|
|
* for more details.
|
|
|
|
*
|
Altix: Add initial ACPI IO support
First phase in introducing ACPI support to SN.
In this phase, when running with an ACPI capable PROM,
the DSDT will define the root busses and all SN nodes
(SGIHUB, SGITIO). An ACPI bus driver will be registered
for the node devices, with the acpi_pci_root_driver being
used for the root busses. An ACPI vendor descriptor is
now used to pass platform specific information for both
nodes and busses, eliminating the need for the current
SAL calls. Also, with ACPI support, SN fixup code is no longer
needed to initiate the PCI bus scans, as the acpi_pci_root_driver
does that.
However, to maintain backward compatibility with non-ACPI capable
PROMs, none of the current 'fixup' code can been deleted, though
much restructuring has been done. For example, the bulk of the code
in io_common.c is relocated code that is now common regardless
of what PROM is running, while io_acpi_init.c and io_init.c contain
routines specific to an ACPI or non ACPI capable PROM respectively.
A new pci bus fixup platform vector has been created to provide
a hook for invoking platform specific bus fixup from pcibios_fixup_bus().
The size of io_space[] has been increased to support systems with
large IO configurations.
Signed-off-by: John Keller <jpk@sgi.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2006-10-04 14:49:25 -07:00
|
|
|
* Copyright (C) 2000-2003, 2006 Silicon Graphics, Inc. All rights reserved.
|
2005-04-16 15:20:36 -07:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <linux/module.h>
|
Altix: Add initial ACPI IO support
First phase in introducing ACPI support to SN.
In this phase, when running with an ACPI capable PROM,
the DSDT will define the root busses and all SN nodes
(SGIHUB, SGITIO). An ACPI bus driver will be registered
for the node devices, with the acpi_pci_root_driver being
used for the root busses. An ACPI vendor descriptor is
now used to pass platform specific information for both
nodes and busses, eliminating the need for the current
SAL calls. Also, with ACPI support, SN fixup code is no longer
needed to initiate the PCI bus scans, as the acpi_pci_root_driver
does that.
However, to maintain backward compatibility with non-ACPI capable
PROMs, none of the current 'fixup' code can been deleted, though
much restructuring has been done. For example, the bulk of the code
in io_common.c is relocated code that is now common regardless
of what PROM is running, while io_acpi_init.c and io_init.c contain
routines specific to an ACPI or non ACPI capable PROM respectively.
A new pci bus fixup platform vector has been created to provide
a hook for invoking platform specific bus fixup from pcibios_fixup_bus().
The size of io_space[] has been increased to support systems with
large IO configurations.
Signed-off-by: John Keller <jpk@sgi.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2006-10-04 14:49:25 -07:00
|
|
|
#include <linux/acpi.h>
|
2005-04-16 15:20:36 -07:00
|
|
|
#include <asm/io.h>
|
|
|
|
#include <asm/delay.h>
|
2005-04-26 08:01:00 -07:00
|
|
|
#include <asm/vga.h>
|
2005-04-16 15:20:36 -07:00
|
|
|
#include <asm/sn/nodepda.h>
|
|
|
|
#include <asm/sn/simulator.h>
|
|
|
|
#include <asm/sn/pda.h>
|
|
|
|
#include <asm/sn/sn_cpuid.h>
|
|
|
|
#include <asm/sn/shub_mmr.h>
|
2007-02-02 20:14:22 -07:00
|
|
|
#include <asm/sn/acpi.h>
|
2005-04-16 15:20:36 -07:00
|
|
|
|
2005-04-26 08:01:00 -07:00
|
|
|
#define IS_LEGACY_VGA_IOPORT(p) \
|
|
|
|
(((p) >= 0x3b0 && (p) <= 0x3bb) || ((p) >= 0x3c0 && (p) <= 0x3df))
|
|
|
|
|
2005-04-16 15:20:36 -07:00
|
|
|
/**
|
|
|
|
* sn_io_addr - convert an in/out port to an i/o address
|
|
|
|
* @port: port to convert
|
|
|
|
*
|
|
|
|
* Legacy in/out instructions are converted to ld/st instructions
|
2007-02-02 09:48:19 -07:00
|
|
|
* on IA64. This routine will convert a port number into a valid
|
2005-04-16 15:20:36 -07:00
|
|
|
* SN i/o address. Used by sn_in*() and sn_out*().
|
|
|
|
*/
|
2007-02-02 09:48:19 -07:00
|
|
|
|
2005-04-16 15:20:36 -07:00
|
|
|
void *sn_io_addr(unsigned long port)
|
|
|
|
{
|
|
|
|
if (!IS_RUNNING_ON_SIMULATOR()) {
|
2005-04-26 08:01:00 -07:00
|
|
|
if (IS_LEGACY_VGA_IOPORT(port))
|
Altix: Add initial ACPI IO support
First phase in introducing ACPI support to SN.
In this phase, when running with an ACPI capable PROM,
the DSDT will define the root busses and all SN nodes
(SGIHUB, SGITIO). An ACPI bus driver will be registered
for the node devices, with the acpi_pci_root_driver being
used for the root busses. An ACPI vendor descriptor is
now used to pass platform specific information for both
nodes and busses, eliminating the need for the current
SAL calls. Also, with ACPI support, SN fixup code is no longer
needed to initiate the PCI bus scans, as the acpi_pci_root_driver
does that.
However, to maintain backward compatibility with non-ACPI capable
PROMs, none of the current 'fixup' code can been deleted, though
much restructuring has been done. For example, the bulk of the code
in io_common.c is relocated code that is now common regardless
of what PROM is running, while io_acpi_init.c and io_init.c contain
routines specific to an ACPI or non ACPI capable PROM respectively.
A new pci bus fixup platform vector has been created to provide
a hook for invoking platform specific bus fixup from pcibios_fixup_bus().
The size of io_space[] has been increased to support systems with
large IO configurations.
Signed-off-by: John Keller <jpk@sgi.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2006-10-04 14:49:25 -07:00
|
|
|
return (__ia64_mk_io_addr(port));
|
2005-04-16 15:20:36 -07:00
|
|
|
/* On sn2, legacy I/O ports don't point at anything */
|
|
|
|
if (port < (64 * 1024))
|
|
|
|
return NULL;
|
2007-02-02 20:14:22 -07:00
|
|
|
if (SN_ACPI_BASE_SUPPORT())
|
Altix: Add initial ACPI IO support
First phase in introducing ACPI support to SN.
In this phase, when running with an ACPI capable PROM,
the DSDT will define the root busses and all SN nodes
(SGIHUB, SGITIO). An ACPI bus driver will be registered
for the node devices, with the acpi_pci_root_driver being
used for the root busses. An ACPI vendor descriptor is
now used to pass platform specific information for both
nodes and busses, eliminating the need for the current
SAL calls. Also, with ACPI support, SN fixup code is no longer
needed to initiate the PCI bus scans, as the acpi_pci_root_driver
does that.
However, to maintain backward compatibility with non-ACPI capable
PROMs, none of the current 'fixup' code can been deleted, though
much restructuring has been done. For example, the bulk of the code
in io_common.c is relocated code that is now common regardless
of what PROM is running, while io_acpi_init.c and io_init.c contain
routines specific to an ACPI or non ACPI capable PROM respectively.
A new pci bus fixup platform vector has been created to provide
a hook for invoking platform specific bus fixup from pcibios_fixup_bus().
The size of io_space[] has been increased to support systems with
large IO configurations.
Signed-off-by: John Keller <jpk@sgi.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2006-10-04 14:49:25 -07:00
|
|
|
return (__ia64_mk_io_addr(port));
|
|
|
|
else
|
|
|
|
return ((void *)(port | __IA64_UNCACHED_OFFSET));
|
2005-04-16 15:20:36 -07:00
|
|
|
} else {
|
|
|
|
/* but the simulator uses them... */
|
|
|
|
unsigned long addr;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* word align port, but need more than 10 bits
|
|
|
|
* for accessing registers in bedrock local block
|
|
|
|
* (so we don't do port&0xfff)
|
|
|
|
*/
|
|
|
|
addr = (is_shub2() ? 0xc00000028c000000UL : 0xc0000087cc000000UL) | ((port >> 2) << 12);
|
|
|
|
if ((port >= 0x1f0 && port <= 0x1f7) || port == 0x3f6 || port == 0x3f7)
|
|
|
|
addr |= port;
|
|
|
|
return (void *)addr;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
EXPORT_SYMBOL(sn_io_addr);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* __sn_mmiowb - I/O space memory barrier
|
|
|
|
*
|
2008-08-01 10:13:32 -07:00
|
|
|
* See arch/ia64/include/asm/io.h and Documentation/DocBook/deviceiobook.tmpl
|
2005-04-16 15:20:36 -07:00
|
|
|
* for details.
|
|
|
|
*
|
|
|
|
* On SN2, we wait for the PIO_WRITE_STATUS SHub register to clear.
|
|
|
|
* See PV 871084 for details about the WAR about zero value.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
void __sn_mmiowb(void)
|
|
|
|
{
|
|
|
|
volatile unsigned long *adr = pda->pio_write_status_addr;
|
|
|
|
unsigned long val = pda->pio_write_status_val;
|
|
|
|
|
|
|
|
while ((*adr & SH_PIO_WRITE_STATUS_PENDING_WRITE_COUNT_MASK) != val)
|
|
|
|
cpu_relax();
|
|
|
|
}
|
|
|
|
|
|
|
|
EXPORT_SYMBOL(__sn_mmiowb);
|