summaryrefslogtreecommitdiff
path: root/sys/arch
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch')
-rw-r--r--sys/arch/sparc64/dev/pyro.c43
1 files changed, 40 insertions, 3 deletions
diff --git a/sys/arch/sparc64/dev/pyro.c b/sys/arch/sparc64/dev/pyro.c
index 0d3d0257600..03e001a85e5 100644
--- a/sys/arch/sparc64/dev/pyro.c
+++ b/sys/arch/sparc64/dev/pyro.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pyro.c,v 1.3 2007/03/31 22:14:52 kettenis Exp $ */
+/* $OpenBSD: pyro.c,v 1.4 2007/04/01 12:48:07 kettenis Exp $ */
/*
* Copyright (c) 2002 Jason L. Wright (jason@thought.net)
@@ -70,6 +70,7 @@ bus_space_tag_t pyro_alloc_io_tag(struct pyro_pbm *);
bus_space_tag_t pyro_alloc_config_tag(struct pyro_pbm *);
bus_space_tag_t _pyro_alloc_bus_tag(struct pyro_pbm *, const char *,
int, int, int);
+bus_dma_tag_t pyro_alloc_dma_tag(struct pyro_pbm *);
int pyro_intr_map(struct pci_attach_args *, pci_intr_handle_t *);
int _pyro_bus_map(bus_space_tag_t, bus_space_tag_t, bus_addr_t,
@@ -79,6 +80,9 @@ paddr_t _pyro_bus_mmap(bus_space_tag_t, bus_space_tag_t, bus_addr_t, off_t,
void *_pyro_intr_establish(bus_space_tag_t, bus_space_tag_t, int, int, int,
int (*)(void *), void *, const char *);
+int pyro_dmamap_create(bus_dma_tag_t, bus_dma_tag_t, bus_size_t, int,
+ bus_size_t, bus_size_t, int, bus_dmamap_t *);
+
int
pyro_match(struct device *parent, void *match, void *aux)
{
@@ -146,9 +150,7 @@ pyro_init(struct pyro_softc *sc, int busa)
pbm->pp_memt = pyro_alloc_mem_tag(pbm);
pbm->pp_iot = pyro_alloc_io_tag(pbm);
pbm->pp_cfgt = pyro_alloc_config_tag(pbm);
-#if 0
pbm->pp_dmat = pyro_alloc_dma_tag(pbm);
-#endif
if (bus_space_map(pbm->pp_cfgt, 0, 0x10000000, 0, &pbm->pp_cfgh))
panic("pyro: could not map config space");
@@ -272,6 +274,33 @@ _pyro_alloc_bus_tag(struct pyro_pbm *pbm, const char *name, int ss,
return (bt);
}
+bus_dma_tag_t
+pyro_alloc_dma_tag(struct pyro_pbm *pbm)
+{
+ struct pyro_softc *sc = pbm->pp_sc;
+ bus_dma_tag_t dt, pdt = sc->sc_dmat;
+
+ dt = (bus_dma_tag_t)malloc(sizeof(struct sparc_bus_dma_tag),
+ M_DEVBUF, M_NOWAIT);
+ if (dt == NULL)
+ panic("pyro: could not alloc dma tag");
+
+ bzero(dt, sizeof(*dt));
+ dt->_cookie = pbm;
+ dt->_parent = pdt;
+ dt->_dmamap_create = pyro_dmamap_create;
+ dt->_dmamap_destroy = iommu_dvmamap_destroy;
+ dt->_dmamap_load = iommu_dvmamap_load;
+ dt->_dmamap_load_raw = iommu_dvmamap_load_raw;
+ dt->_dmamap_unload = iommu_dvmamap_unload;
+ dt->_dmamap_sync = iommu_dvmamap_sync;
+ dt->_dmamem_alloc = iommu_dvmamem_alloc;
+ dt->_dmamem_free = iommu_dvmamem_free;
+ dt->_dmamem_map = iommu_dvmamem_map;
+ dt->_dmamem_unmap = iommu_dvmamem_unmap;
+ return (dt);
+}
+
pci_chipset_tag_t
pyro_alloc_chipset(struct pyro_pbm *pbm, int node, pci_chipset_tag_t pc)
{
@@ -287,6 +316,14 @@ pyro_alloc_chipset(struct pyro_pbm *pbm, int node, pci_chipset_tag_t pc)
}
int
+pyro_dmamap_create(bus_dma_tag_t t, bus_dma_tag_t t0, bus_size_t size,
+ int nsegments, bus_size_t maxsegsz, bus_size_t boundary, int flags,
+ bus_dmamap_t *dmamp)
+{
+ return (ENOMEM);
+}
+
+int
_pyro_bus_map(bus_space_tag_t t, bus_space_tag_t t0, bus_addr_t offset,
bus_size_t size, int flags, bus_space_handle_t *hp)
{