mirror of
https://git.FreeBSD.org/src.git
synced 2025-01-14 14:55:41 +00:00
remove the 4GB boundary requirement on PCI DMA segments
Reviewed by: kib Discussed with: jhb Sponsored by: Dell EMC Isilon Differential Revision: https://reviews.freebsd.org/D19867
This commit is contained in:
parent
7296d6c9bf
commit
96ca24dc32
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=346386
@ -3067,3 +3067,11 @@ struct bge_softc {
|
||||
#define BGE_LOCK_ASSERT(_sc) mtx_assert(&(_sc)->bge_mtx, MA_OWNED)
|
||||
#define BGE_UNLOCK(_sc) mtx_unlock(&(_sc)->bge_mtx)
|
||||
#define BGE_LOCK_DESTROY(_sc) mtx_destroy(&(_sc)->bge_mtx)
|
||||
|
||||
#ifdef BUS_SPACE_MAXADDR
|
||||
#if (BUS_SPACE_MAXADDR > 0xFFFFFFFF)
|
||||
#define BGE_DMA_BOUNDARY (0x100000000)
|
||||
#else
|
||||
#define BGE_DMA_BOUNDARY 0
|
||||
#endif
|
||||
#endif
|
||||
|
@ -4343,9 +4343,6 @@ pci_attach_common(device_t dev)
|
||||
{
|
||||
struct pci_softc *sc;
|
||||
int busno, domain;
|
||||
#ifdef PCI_DMA_BOUNDARY
|
||||
int error, tag_valid;
|
||||
#endif
|
||||
#ifdef PCI_RES_BUS
|
||||
int rid;
|
||||
#endif
|
||||
@ -4365,23 +4362,7 @@ pci_attach_common(device_t dev)
|
||||
if (bootverbose)
|
||||
device_printf(dev, "domain=%d, physical bus=%d\n",
|
||||
domain, busno);
|
||||
#ifdef PCI_DMA_BOUNDARY
|
||||
tag_valid = 0;
|
||||
if (device_get_devclass(device_get_parent(device_get_parent(dev))) !=
|
||||
devclass_find("pci")) {
|
||||
error = bus_dma_tag_create(bus_get_dma_tag(dev), 1,
|
||||
PCI_DMA_BOUNDARY, BUS_SPACE_MAXADDR, BUS_SPACE_MAXADDR,
|
||||
NULL, NULL, BUS_SPACE_MAXSIZE, BUS_SPACE_UNRESTRICTED,
|
||||
BUS_SPACE_MAXSIZE, 0, NULL, NULL, &sc->sc_dma_tag);
|
||||
if (error)
|
||||
device_printf(dev, "Failed to create DMA tag: %d\n",
|
||||
error);
|
||||
else
|
||||
tag_valid = 1;
|
||||
}
|
||||
if (!tag_valid)
|
||||
#endif
|
||||
sc->sc_dma_tag = bus_get_dma_tag(dev);
|
||||
sc->sc_dma_tag = bus_get_dma_tag(dev);
|
||||
return (0);
|
||||
}
|
||||
|
||||
|
@ -693,14 +693,6 @@ int pcie_link_reset(device_t port, int pcie_location);
|
||||
|
||||
void pci_print_faulted_dev(void);
|
||||
|
||||
#ifdef BUS_SPACE_MAXADDR
|
||||
#if (BUS_SPACE_MAXADDR > 0xFFFFFFFF)
|
||||
#define PCI_DMA_BOUNDARY 0x100000000
|
||||
#else
|
||||
#define PCI_DMA_BOUNDARY 0
|
||||
#endif
|
||||
#endif
|
||||
|
||||
#endif /* _SYS_BUS_H_ */
|
||||
|
||||
/*
|
||||
|
@ -57,6 +57,12 @@
|
||||
#define TW_OSLI_MAX_NUM_IOS (TW_OSLI_MAX_NUM_REQUESTS - 2)
|
||||
#define TW_OSLI_MAX_NUM_AENS 0x100
|
||||
|
||||
#ifdef PAE
|
||||
#define TW_OSLI_DMA_BOUNDARY (1u << 31)
|
||||
#else
|
||||
#define TW_OSLI_DMA_BOUNDARY ((bus_size_t)((uint64_t)1 << 32))
|
||||
#endif
|
||||
|
||||
/* Possible values of req->state. */
|
||||
#define TW_OSLI_REQ_STATE_INIT 0x0 /* being initialized */
|
||||
#define TW_OSLI_REQ_STATE_BUSY 0x1 /* submitted to CL */
|
||||
|
@ -551,7 +551,7 @@ tw_osli_alloc_mem(struct twa_softc *sc)
|
||||
/* Create the parent dma tag. */
|
||||
if (bus_dma_tag_create(bus_get_dma_tag(sc->bus_dev), /* parent */
|
||||
sc->alignment, /* alignment */
|
||||
0, /* boundary */
|
||||
TW_OSLI_DMA_BOUNDARY, /* boundary */
|
||||
BUS_SPACE_MAXADDR, /* lowaddr */
|
||||
BUS_SPACE_MAXADDR, /* highaddr */
|
||||
NULL, NULL, /* filter, filterarg */
|
||||
|
@ -130,7 +130,7 @@ ctx_tag_init(struct dmar_ctx *ctx, device_t dev)
|
||||
maxaddr = MIN(ctx->domain->end, BUS_SPACE_MAXADDR);
|
||||
ctx->ctx_tag.common.ref_count = 1; /* Prevent free */
|
||||
ctx->ctx_tag.common.impl = &bus_dma_dmar_impl;
|
||||
ctx->ctx_tag.common.boundary = PCI_DMA_BOUNDARY;
|
||||
ctx->ctx_tag.common.boundary = 0;
|
||||
ctx->ctx_tag.common.lowaddr = maxaddr;
|
||||
ctx->ctx_tag.common.highaddr = maxaddr;
|
||||
ctx->ctx_tag.common.maxsize = maxaddr;
|
||||
|
Loading…
Reference in New Issue
Block a user