mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-25 21:24:08 +08:00
ia64: remove the zx1 swiotlb machvec
The aim of this machvec is to support devices with < 32-bit dma masks. But given that ia64 only has a ZONE_DMA32 and not a ZONE_DMA that isn't supported by swiotlb either. Signed-off-by: Christoph Hellwig <hch@lst.de> Link: https://lkml.kernel.org/r/20190813072514.23299-21-hch@lst.de Signed-off-by: Tony Luck <tony.luck@intel.com>
This commit is contained in:
parent
2e0f2b1659
commit
df43acac8e
@ -2373,7 +2373,7 @@
|
|||||||
|
|
||||||
machvec= [IA-64] Force the use of a particular machine-vector
|
machvec= [IA-64] Force the use of a particular machine-vector
|
||||||
(machvec) in a generic kernel.
|
(machvec) in a generic kernel.
|
||||||
Example: machvec=hpzx1_swiotlb
|
Example: machvec=hpzx1
|
||||||
|
|
||||||
machtype= [Loongson] Share the same kernel image file between different
|
machtype= [Loongson] Share the same kernel image file between different
|
||||||
yeeloong laptop.
|
yeeloong laptop.
|
||||||
|
@ -138,7 +138,6 @@ config IA64_GENERIC
|
|||||||
DIG-compliant For DIG ("Developer's Interface Guide") compliant systems
|
DIG-compliant For DIG ("Developer's Interface Guide") compliant systems
|
||||||
DIG+Intel+IOMMU For DIG systems with Intel IOMMU
|
DIG+Intel+IOMMU For DIG systems with Intel IOMMU
|
||||||
HP-zx1/sx1000 For HP systems
|
HP-zx1/sx1000 For HP systems
|
||||||
HP-zx1/sx1000+swiotlb For HP systems with (broken) DMA-constrained devices.
|
|
||||||
SGI-UV For SGI UV systems
|
SGI-UV For SGI UV systems
|
||||||
|
|
||||||
If you don't know what to do, choose "generic".
|
If you don't know what to do, choose "generic".
|
||||||
@ -158,16 +157,6 @@ config IA64_HP_ZX1
|
|||||||
Build a kernel that runs on HP zx1 and sx1000 systems. This adds
|
Build a kernel that runs on HP zx1 and sx1000 systems. This adds
|
||||||
support for the HP I/O MMU.
|
support for the HP I/O MMU.
|
||||||
|
|
||||||
config IA64_HP_ZX1_SWIOTLB
|
|
||||||
bool "HP-zx1/sx1000 with software I/O TLB"
|
|
||||||
select SWIOTLB
|
|
||||||
help
|
|
||||||
Build a kernel that runs on HP zx1 and sx1000 systems even when they
|
|
||||||
have broken PCI devices which cannot DMA to full 32 bits. Apart
|
|
||||||
from support for the HP I/O MMU, this includes support for the software
|
|
||||||
I/O TLB, which allows supporting the broken devices at the expense of
|
|
||||||
wasting some kernel memory (about 2MB by default).
|
|
||||||
|
|
||||||
config IA64_SGI_UV
|
config IA64_SGI_UV
|
||||||
bool "SGI-UV"
|
bool "SGI-UV"
|
||||||
select NUMA
|
select NUMA
|
||||||
@ -350,7 +339,7 @@ config ARCH_SPARSEMEM_ENABLE
|
|||||||
select SPARSEMEM_VMEMMAP_ENABLE
|
select SPARSEMEM_VMEMMAP_ENABLE
|
||||||
|
|
||||||
config ARCH_DISCONTIGMEM_DEFAULT
|
config ARCH_DISCONTIGMEM_DEFAULT
|
||||||
def_bool y if (IA64_GENERIC || IA64_HP_ZX1 || IA64_HP_ZX1_SWIOTLB)
|
def_bool y if (IA64_GENERIC || IA64_HP_ZX1)
|
||||||
depends on ARCH_DISCONTIGMEM_ENABLE
|
depends on ARCH_DISCONTIGMEM_ENABLE
|
||||||
|
|
||||||
config NUMA
|
config NUMA
|
||||||
|
@ -14,7 +14,7 @@ config IA64_GRANULE_16MB
|
|||||||
|
|
||||||
config IA64_GRANULE_64MB
|
config IA64_GRANULE_64MB
|
||||||
bool "64MB"
|
bool "64MB"
|
||||||
depends on !(IA64_GENERIC || IA64_HP_ZX1 || IA64_HP_ZX1_SWIOTLB)
|
depends on !(IA64_GENERIC || IA64_HP_ZX1)
|
||||||
|
|
||||||
endchoice
|
endchoice
|
||||||
|
|
||||||
|
@ -54,12 +54,10 @@ core-$(CONFIG_IA64_DIG) += arch/ia64/dig/
|
|||||||
core-$(CONFIG_IA64_DIG_VTD) += arch/ia64/dig/
|
core-$(CONFIG_IA64_DIG_VTD) += arch/ia64/dig/
|
||||||
core-$(CONFIG_IA64_GENERIC) += arch/ia64/dig/
|
core-$(CONFIG_IA64_GENERIC) += arch/ia64/dig/
|
||||||
core-$(CONFIG_IA64_HP_ZX1) += arch/ia64/dig/
|
core-$(CONFIG_IA64_HP_ZX1) += arch/ia64/dig/
|
||||||
core-$(CONFIG_IA64_HP_ZX1_SWIOTLB) += arch/ia64/dig/
|
|
||||||
core-$(CONFIG_IA64_SGI_UV) += arch/ia64/uv/
|
core-$(CONFIG_IA64_SGI_UV) += arch/ia64/uv/
|
||||||
|
|
||||||
drivers-y += arch/ia64/pci/
|
drivers-y += arch/ia64/pci/
|
||||||
drivers-$(CONFIG_IA64_HP_ZX1) += arch/ia64/hp/common/ arch/ia64/hp/zx1/
|
drivers-$(CONFIG_IA64_HP_ZX1) += arch/ia64/hp/common/ arch/ia64/hp/zx1/
|
||||||
drivers-$(CONFIG_IA64_HP_ZX1_SWIOTLB) += arch/ia64/hp/common/ arch/ia64/hp/zx1/
|
|
||||||
drivers-$(CONFIG_IA64_GENERIC) += arch/ia64/hp/common/ arch/ia64/hp/zx1/ arch/ia64/uv/
|
drivers-$(CONFIG_IA64_GENERIC) += arch/ia64/hp/common/ arch/ia64/hp/zx1/ arch/ia64/uv/
|
||||||
drivers-$(CONFIG_OPROFILE) += arch/ia64/oprofile/
|
drivers-$(CONFIG_OPROFILE) += arch/ia64/oprofile/
|
||||||
|
|
||||||
|
@ -7,6 +7,4 @@
|
|||||||
#
|
#
|
||||||
|
|
||||||
obj-y := sba_iommu.o
|
obj-y := sba_iommu.o
|
||||||
obj-$(CONFIG_IA64_HP_ZX1_SWIOTLB) += hwsw_iommu.o
|
|
||||||
obj-$(CONFIG_IA64_GENERIC) += hwsw_iommu.o
|
|
||||||
obj-$(CONFIG_IA64_HP_AML_NFW) += aml_nfw.o
|
obj-$(CONFIG_IA64_HP_AML_NFW) += aml_nfw.o
|
||||||
|
@ -1,60 +0,0 @@
|
|||||||
// SPDX-License-Identifier: GPL-2.0
|
|
||||||
/*
|
|
||||||
* Copyright (c) 2004 Hewlett-Packard Development Company, L.P.
|
|
||||||
* Contributed by David Mosberger-Tang <davidm@hpl.hp.com>
|
|
||||||
*
|
|
||||||
* This is a pseudo I/O MMU which dispatches to the hardware I/O MMU
|
|
||||||
* whenever possible. We assume that the hardware I/O MMU requires
|
|
||||||
* full 32-bit addressability, as is the case, e.g., for HP zx1-based
|
|
||||||
* systems (there, the I/O MMU window is mapped at 3-4GB). If a
|
|
||||||
* device doesn't provide full 32-bit addressability, we fall back on
|
|
||||||
* the sw I/O TLB. This is good enough to let us support broken
|
|
||||||
* hardware such as soundcards which have a DMA engine that can
|
|
||||||
* address only 28 bits.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <linux/device.h>
|
|
||||||
#include <linux/dma-mapping.h>
|
|
||||||
#include <linux/swiotlb.h>
|
|
||||||
#include <linux/export.h>
|
|
||||||
#include <asm/machvec.h>
|
|
||||||
|
|
||||||
extern const struct dma_map_ops sba_dma_ops;
|
|
||||||
|
|
||||||
/* swiotlb declarations & definitions: */
|
|
||||||
extern int swiotlb_late_init_with_default_size (size_t size);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Note: we need to make the determination of whether or not to use
|
|
||||||
* the sw I/O TLB based purely on the device structure. Anything else
|
|
||||||
* would be unreliable or would be too intrusive.
|
|
||||||
*/
|
|
||||||
static inline int use_swiotlb(struct device *dev)
|
|
||||||
{
|
|
||||||
return dev && dev->dma_mask &&
|
|
||||||
!sba_dma_ops.dma_supported(dev, *dev->dma_mask);
|
|
||||||
}
|
|
||||||
|
|
||||||
const struct dma_map_ops *hwsw_dma_get_ops(struct device *dev)
|
|
||||||
{
|
|
||||||
if (use_swiotlb(dev))
|
|
||||||
return NULL;
|
|
||||||
return &sba_dma_ops;
|
|
||||||
}
|
|
||||||
EXPORT_SYMBOL(hwsw_dma_get_ops);
|
|
||||||
|
|
||||||
void __init
|
|
||||||
hwsw_init (void)
|
|
||||||
{
|
|
||||||
/* default to a smallish 2MB sw I/O TLB */
|
|
||||||
if (swiotlb_late_init_with_default_size (2 * (1<<20)) != 0) {
|
|
||||||
#ifdef CONFIG_IA64_GENERIC
|
|
||||||
/* Better to have normal DMA than panic */
|
|
||||||
printk(KERN_WARNING "%s: Failed to initialize software I/O TLB,"
|
|
||||||
" reverting to hpzx1 platform vector\n", __func__);
|
|
||||||
machvec_init("hpzx1");
|
|
||||||
#else
|
|
||||||
panic("Unable to initialize software I/O TLB services");
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
}
|
|
@ -2059,7 +2059,7 @@ arch_initcall(acpi_sba_ioc_init_acpi);
|
|||||||
static int __init
|
static int __init
|
||||||
sba_init(void)
|
sba_init(void)
|
||||||
{
|
{
|
||||||
if (!ia64_platform_is("hpzx1") && !ia64_platform_is("hpzx1_swiotlb"))
|
if (!ia64_platform_is("hpzx1"))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
#if defined(CONFIG_IA64_GENERIC)
|
#if defined(CONFIG_IA64_GENERIC)
|
||||||
@ -2102,19 +2102,6 @@ sba_init(void)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(CONFIG_IA64_GENERIC) || defined(CONFIG_IA64_HP_ZX1_SWIOTLB)
|
|
||||||
/*
|
|
||||||
* hpzx1_swiotlb needs to have a fairly small swiotlb bounce
|
|
||||||
* buffer setup to support devices with smaller DMA masks than
|
|
||||||
* sba_iommu can handle.
|
|
||||||
*/
|
|
||||||
if (ia64_platform_is("hpzx1_swiotlb")) {
|
|
||||||
extern void hwsw_init(void);
|
|
||||||
|
|
||||||
hwsw_init();
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
{
|
{
|
||||||
struct pci_bus *b = NULL;
|
struct pci_bus *b = NULL;
|
||||||
while ((b = pci_find_next_bus(b)) != NULL)
|
while ((b = pci_find_next_bus(b)) != NULL)
|
||||||
|
@ -6,4 +6,4 @@
|
|||||||
# Copyright (C) Alex Williamson (alex_williamson@hp.com)
|
# Copyright (C) Alex Williamson (alex_williamson@hp.com)
|
||||||
#
|
#
|
||||||
|
|
||||||
obj-$(CONFIG_IA64_GENERIC) += hpzx1_machvec.o hpzx1_swiotlb_machvec.o
|
obj-$(CONFIG_IA64_GENERIC) += hpzx1_machvec.o
|
||||||
|
@ -1,3 +0,0 @@
|
|||||||
#define MACHVEC_PLATFORM_NAME hpzx1_swiotlb
|
|
||||||
#define MACHVEC_PLATFORM_HEADER <asm/machvec_hpzx1_swiotlb.h>
|
|
||||||
#include <asm/machvec_init.h>
|
|
@ -39,8 +39,6 @@ static inline const char *acpi_get_sysname (void)
|
|||||||
{
|
{
|
||||||
# if defined (CONFIG_IA64_HP_ZX1)
|
# if defined (CONFIG_IA64_HP_ZX1)
|
||||||
return "hpzx1";
|
return "hpzx1";
|
||||||
# elif defined (CONFIG_IA64_HP_ZX1_SWIOTLB)
|
|
||||||
return "hpzx1_swiotlb";
|
|
||||||
# elif defined (CONFIG_IA64_SGI_UV)
|
# elif defined (CONFIG_IA64_SGI_UV)
|
||||||
return "uv";
|
return "uv";
|
||||||
# elif defined (CONFIG_IA64_DIG)
|
# elif defined (CONFIG_IA64_DIG)
|
||||||
|
@ -6,17 +6,11 @@
|
|||||||
* Copyright (C) 2003-2004 Hewlett-Packard Co
|
* Copyright (C) 2003-2004 Hewlett-Packard Co
|
||||||
* David Mosberger-Tang <davidm@hpl.hp.com>
|
* David Mosberger-Tang <davidm@hpl.hp.com>
|
||||||
*/
|
*/
|
||||||
#include <asm/machvec.h>
|
|
||||||
#include <linux/scatterlist.h>
|
|
||||||
#include <linux/dma-debug.h>
|
|
||||||
|
|
||||||
extern const struct dma_map_ops *dma_ops;
|
extern const struct dma_map_ops *dma_ops;
|
||||||
extern struct ia64_machine_vector ia64_mv;
|
|
||||||
extern void set_iommu_machvec(void);
|
|
||||||
|
|
||||||
static inline const struct dma_map_ops *get_arch_dma_ops(struct bus_type *bus)
|
static inline const struct dma_map_ops *get_arch_dma_ops(struct bus_type *bus)
|
||||||
{
|
{
|
||||||
return platform_dma_get_ops(NULL);
|
return dma_ops;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* _ASM_IA64_DMA_MAPPING_H */
|
#endif /* _ASM_IA64_DMA_MAPPING_H */
|
||||||
|
@ -17,12 +17,6 @@ struct device;
|
|||||||
|
|
||||||
typedef void ia64_mv_setup_t (char **);
|
typedef void ia64_mv_setup_t (char **);
|
||||||
typedef void ia64_mv_dma_init (void);
|
typedef void ia64_mv_dma_init (void);
|
||||||
typedef const struct dma_map_ops *ia64_mv_dma_get_ops(struct device *);
|
|
||||||
|
|
||||||
static inline void
|
|
||||||
machvec_noop (void)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
extern void machvec_setup (char **);
|
extern void machvec_setup (char **);
|
||||||
|
|
||||||
@ -32,8 +26,6 @@ extern void machvec_setup (char **);
|
|||||||
# include <asm/machvec_dig_vtd.h>
|
# include <asm/machvec_dig_vtd.h>
|
||||||
# elif defined (CONFIG_IA64_HP_ZX1)
|
# elif defined (CONFIG_IA64_HP_ZX1)
|
||||||
# include <asm/machvec_hpzx1.h>
|
# include <asm/machvec_hpzx1.h>
|
||||||
# elif defined (CONFIG_IA64_HP_ZX1_SWIOTLB)
|
|
||||||
# include <asm/machvec_hpzx1_swiotlb.h>
|
|
||||||
# elif defined (CONFIG_IA64_SGI_UV)
|
# elif defined (CONFIG_IA64_SGI_UV)
|
||||||
# include <asm/machvec_uv.h>
|
# include <asm/machvec_uv.h>
|
||||||
# elif defined (CONFIG_IA64_GENERIC)
|
# elif defined (CONFIG_IA64_GENERIC)
|
||||||
@ -44,7 +36,6 @@ extern void machvec_setup (char **);
|
|||||||
# define ia64_platform_name ia64_mv.name
|
# define ia64_platform_name ia64_mv.name
|
||||||
# define platform_setup ia64_mv.setup
|
# define platform_setup ia64_mv.setup
|
||||||
# define platform_dma_init ia64_mv.dma_init
|
# define platform_dma_init ia64_mv.dma_init
|
||||||
# define platform_dma_get_ops ia64_mv.dma_get_ops
|
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
/* __attribute__((__aligned__(16))) is required to make size of the
|
/* __attribute__((__aligned__(16))) is required to make size of the
|
||||||
@ -56,7 +47,6 @@ struct ia64_machine_vector {
|
|||||||
const char *name;
|
const char *name;
|
||||||
ia64_mv_setup_t *setup;
|
ia64_mv_setup_t *setup;
|
||||||
ia64_mv_dma_init *dma_init;
|
ia64_mv_dma_init *dma_init;
|
||||||
ia64_mv_dma_get_ops *dma_get_ops;
|
|
||||||
} __attribute__((__aligned__(16))); /* align attrib? see above comment */
|
} __attribute__((__aligned__(16))); /* align attrib? see above comment */
|
||||||
|
|
||||||
#define MACHVEC_INIT(name) \
|
#define MACHVEC_INIT(name) \
|
||||||
@ -64,7 +54,6 @@ struct ia64_machine_vector {
|
|||||||
#name, \
|
#name, \
|
||||||
platform_setup, \
|
platform_setup, \
|
||||||
platform_dma_init, \
|
platform_dma_init, \
|
||||||
platform_dma_get_ops, \
|
|
||||||
}
|
}
|
||||||
|
|
||||||
extern struct ia64_machine_vector ia64_mv;
|
extern struct ia64_machine_vector ia64_mv;
|
||||||
@ -76,7 +65,6 @@ extern void machvec_init_from_cmdline(const char *cmdline);
|
|||||||
# endif /* CONFIG_IA64_GENERIC */
|
# endif /* CONFIG_IA64_GENERIC */
|
||||||
|
|
||||||
extern void swiotlb_dma_init(void);
|
extern void swiotlb_dma_init(void);
|
||||||
extern const struct dma_map_ops *dma_get_ops(struct device *);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Define default versions so we can extend machvec for new platforms without having
|
* Define default versions so we can extend machvec for new platforms without having
|
||||||
@ -88,8 +76,5 @@ extern const struct dma_map_ops *dma_get_ops(struct device *);
|
|||||||
#ifndef platform_dma_init
|
#ifndef platform_dma_init
|
||||||
# define platform_dma_init swiotlb_dma_init
|
# define platform_dma_init swiotlb_dma_init
|
||||||
#endif
|
#endif
|
||||||
#ifndef platform_dma_get_ops
|
|
||||||
# define platform_dma_get_ops dma_get_ops
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* _ASM_IA64_MACHVEC_H */
|
#endif /* _ASM_IA64_MACHVEC_H */
|
||||||
|
@ -1,20 +0,0 @@
|
|||||||
/* SPDX-License-Identifier: GPL-2.0 */
|
|
||||||
#ifndef _ASM_IA64_MACHVEC_HPZX1_SWIOTLB_h
|
|
||||||
#define _ASM_IA64_MACHVEC_HPZX1_SWIOTLB_h
|
|
||||||
|
|
||||||
extern ia64_mv_setup_t dig_setup;
|
|
||||||
extern ia64_mv_dma_get_ops hwsw_dma_get_ops;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* This stuff has dual use!
|
|
||||||
*
|
|
||||||
* For a generic kernel, the macros are used to initialize the
|
|
||||||
* platform's machvec structure. When compiling a non-generic kernel,
|
|
||||||
* the macros are used directly.
|
|
||||||
*/
|
|
||||||
#define ia64_platform_name "hpzx1_swiotlb"
|
|
||||||
#define platform_setup dig_setup
|
|
||||||
#define platform_dma_init machvec_noop
|
|
||||||
#define platform_dma_get_ops hwsw_dma_get_ops
|
|
||||||
|
|
||||||
#endif /* _ASM_IA64_MACHVEC_HPZX1_SWIOTLB_h */
|
|
@ -9,12 +9,6 @@ int iommu_detected __read_mostly;
|
|||||||
const struct dma_map_ops *dma_ops;
|
const struct dma_map_ops *dma_ops;
|
||||||
EXPORT_SYMBOL(dma_ops);
|
EXPORT_SYMBOL(dma_ops);
|
||||||
|
|
||||||
const struct dma_map_ops *dma_get_ops(struct device *dev)
|
|
||||||
{
|
|
||||||
return dma_ops;
|
|
||||||
}
|
|
||||||
EXPORT_SYMBOL(dma_get_ops);
|
|
||||||
|
|
||||||
#ifdef CONFIG_SWIOTLB
|
#ifdef CONFIG_SWIOTLB
|
||||||
void *arch_dma_alloc(struct device *dev, size_t size,
|
void *arch_dma_alloc(struct device *dev, size_t size,
|
||||||
dma_addr_t *dma_handle, gfp_t gfp, unsigned long attrs)
|
dma_addr_t *dma_handle, gfp_t gfp, unsigned long attrs)
|
||||||
|
@ -118,7 +118,7 @@ config AGP_I460
|
|||||||
|
|
||||||
config AGP_HP_ZX1
|
config AGP_HP_ZX1
|
||||||
tristate "HP ZX1 chipset AGP support"
|
tristate "HP ZX1 chipset AGP support"
|
||||||
depends on AGP && (IA64_HP_ZX1 || IA64_HP_ZX1_SWIOTLB || IA64_GENERIC)
|
depends on AGP && (IA64_HP_ZX1 || IA64_GENERIC)
|
||||||
help
|
help
|
||||||
This option gives you AGP GART support for the HP ZX1 chipset
|
This option gives you AGP GART support for the HP ZX1 chipset
|
||||||
for IA64 processors.
|
for IA64 processors.
|
||||||
|
Loading…
Reference in New Issue
Block a user