summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/arch/alpha/dev/bus_dma.c8
-rw-r--r--sys/arch/alpha/include/bus.h23
-rw-r--r--sys/arch/alpha/isa/isa_machdep.h6
-rw-r--r--sys/arch/alpha/isa/isadma_bounce.c8
-rw-r--r--sys/arch/hppa/gsc/gscbus.c11
-rw-r--r--sys/arch/hppa/hppa/mainbus.c15
-rw-r--r--sys/arch/hppa/include/bus.h20
-rw-r--r--sys/arch/i386/i386/machdep.c8
-rw-r--r--sys/arch/i386/include/bus.h25
-rw-r--r--sys/arch/i386/isa/isa_machdep.c33
-rw-r--r--sys/arch/macppc/include/bus.h23
-rw-r--r--sys/arch/macppc/macppc/dma.c15
-rw-r--r--sys/arch/mvmeppc/include/bus_mi.h25
-rw-r--r--sys/arch/mvmeppc/mvmeppc/bus_dma.c10
-rw-r--r--sys/dev/eisa/cac_eisa.c8
-rw-r--r--sys/dev/i2o/iop.c37
-rw-r--r--sys/dev/ic/aac.c8
-rw-r--r--sys/dev/ic/adv.c6
-rw-r--r--sys/dev/ic/adv.h10
-rw-r--r--sys/dev/ic/adw.c6
-rw-r--r--sys/dev/ic/adw.h11
-rw-r--r--sys/dev/ic/aic7xxx.c36
-rw-r--r--sys/dev/ic/ami.c18
-rw-r--r--sys/dev/ic/awi_wep.c3
-rw-r--r--sys/dev/ic/cac.c14
-rw-r--r--sys/dev/ic/dpt.c53
-rw-r--r--sys/dev/ic/fxp.c11
-rw-r--r--sys/dev/ic/fxpvar.h20
-rw-r--r--sys/dev/ic/gdt_common.c8
-rw-r--r--sys/dev/ic/iha.c6
-rw-r--r--sys/dev/ic/iha.h12
-rw-r--r--sys/dev/ic/siop.c16
-rw-r--r--sys/dev/ic/siopvar_common.h12
-rw-r--r--sys/dev/ic/twe.c18
-rw-r--r--sys/dev/isa/if_tr_isa.c3
-rw-r--r--sys/dev/isa/if_tribm_isa.c3
-rw-r--r--sys/dev/isa/if_trtcm_isa.c3
-rw-r--r--sys/dev/isa/isadma.c13
-rw-r--r--sys/dev/pci/cac_pci.c8
-rw-r--r--sys/dev/pci/hifn7751.c42
-rw-r--r--sys/dev/pci/hifn7751var.h8
-rw-r--r--sys/dev/pci/if_txp.c48
-rw-r--r--sys/dev/pci/if_txpreg.h9
-rw-r--r--sys/dev/pci/ises.c16
-rw-r--r--sys/dev/pci/isp_pci.c18
-rw-r--r--sys/dev/pci/pciide.c19
-rw-r--r--sys/dev/pci/pcscp.c16
-rw-r--r--sys/dev/pci/ubsec.c28
-rw-r--r--sys/dev/pci/yds.c145
49 files changed, 421 insertions, 501 deletions
diff --git a/sys/arch/alpha/dev/bus_dma.c b/sys/arch/alpha/dev/bus_dma.c
index 2a09c4552a4..81b7171a774 100644
--- a/sys/arch/alpha/dev/bus_dma.c
+++ b/sys/arch/alpha/dev/bus_dma.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: bus_dma.c,v 1.4 2001/09/19 20:50:56 mickey Exp $ */
+/* $OpenBSD: bus_dma.c,v 1.5 2001/11/05 17:25:57 art Exp $ */
/* $NetBSD: bus_dma.c,v 1.40 2000/07/17 04:47:56 thorpej Exp $ */
/*-
@@ -429,10 +429,12 @@ _bus_dmamap_unload(t, map)
* by chipset-specific DMA map synchronization functions.
*/
void
-_bus_dmamap_sync(t, map, op)
+_bus_dmamap_sync(t, map, offset, len, op)
bus_dma_tag_t t;
bus_dmamap_t map;
- bus_dmasync_op_t op;
+ bus_addr_t offset;
+ bus_size_t len;
+ int op;
{
/*
diff --git a/sys/arch/alpha/include/bus.h b/sys/arch/alpha/include/bus.h
index 2c6070bcfc3..0f7d4a1c183 100644
--- a/sys/arch/alpha/include/bus.h
+++ b/sys/arch/alpha/include/bus.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: bus.h,v 1.14 2001/10/26 01:28:06 nate Exp $ */
+/* $OpenBSD: bus.h,v 1.15 2001/11/05 17:25:57 art Exp $ */
/* $NetBSD: bus.h,v 1.10 1996/12/02 22:19:32 cgd Exp $ */
/*
@@ -430,16 +430,12 @@ struct uio;
struct alpha_sgmap;
/*
- * bus_dmasync_op_t
- *
* Operations performed by bus_dmamap_sync().
*/
-typedef enum {
- BUS_DMASYNC_PREREAD,
- BUS_DMASYNC_POSTREAD,
- BUS_DMASYNC_PREWRITE,
- BUS_DMASYNC_POSTWRITE,
-} bus_dmasync_op_t;
+#define BUS_DMASYNC_PREREAD 0x01
+#define BUS_DMASYNC_POSTREAD 0x02
+#define BUS_DMASYNC_PREWRITE 0x04
+#define BUS_DMASYNC_POSTWRITE 0x08
/*
* alpha_bus_t
@@ -537,7 +533,7 @@ struct alpha_bus_dma_tag {
bus_dma_segment_t *, int, bus_size_t, int);
void (*_dmamap_unload)(bus_dma_tag_t, bus_dmamap_t);
void (*_dmamap_sync)(bus_dma_tag_t, bus_dmamap_t,
- bus_dmasync_op_t);
+ bus_addr_t, bus_size_t, int);
/*
* DMA memory utility functions.
@@ -570,8 +566,8 @@ struct alpha_bus_dma_tag {
(*(t)->_dmamap_load_raw)((t), (m), (sg), (n), (s), (f))
#define bus_dmamap_unload(t, p) \
(*(t)->_dmamap_unload)((t), (p))
-#define bus_dmamap_sync(t, p, op) \
- (*(t)->_dmamap_sync)((t), (p), (op))
+#define bus_dmamap_sync(t, p, a, s, op) \
+ (*(t)->_dmamap_sync)((t), (p), (a), (s), (op))
#define bus_dmamem_alloc(t, s, a, b, sg, n, r, f) \
(*(t)->_dmamem_alloc)((t), (s), (a), (b), (sg), (n), (r), (f))
#define bus_dmamem_free(t, sg, n) \
@@ -635,7 +631,8 @@ int _bus_dmamap_load_raw_direct(bus_dma_tag_t,
bus_dmamap_t, bus_dma_segment_t *, int, bus_size_t, int);
void _bus_dmamap_unload(bus_dma_tag_t, bus_dmamap_t);
-void _bus_dmamap_sync(bus_dma_tag_t, bus_dmamap_t, bus_dmasync_op_t);
+void _bus_dmamap_sync(bus_dma_tag_t, bus_dmamap_t, bus_addr_t,
+ bus_size_t, int);
int _bus_dmamem_alloc(bus_dma_tag_t tag, bus_size_t size,
bus_size_t alignment, bus_size_t boundary,
diff --git a/sys/arch/alpha/isa/isa_machdep.h b/sys/arch/alpha/isa/isa_machdep.h
index 0fdf551a634..2c9f75f5a07 100644
--- a/sys/arch/alpha/isa/isa_machdep.h
+++ b/sys/arch/alpha/isa/isa_machdep.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: isa_machdep.h,v 1.9 2001/11/05 02:39:57 art Exp $ */
+/* $OpenBSD: isa_machdep.h,v 1.10 2001/11/05 17:25:57 art Exp $ */
/* $NetBSD: isa_machdep.h,v 1.3 1996/11/19 04:53:07 cgd Exp $ */
/*
@@ -77,8 +77,8 @@ int isadma_bounce_dmamap_load_uio(bus_dma_tag_t, bus_dmamap_t,
int isadma_bounce_dmamap_load_raw(bus_dma_tag_t, bus_dmamap_t,
bus_dma_segment_t *, int, bus_size_t, int);
void isadma_bounce_dmamap_unload(bus_dma_tag_t, bus_dmamap_t);
-void isadma_bounce_dmamap_sync(bus_dma_tag_t, bus_dmamap_t,
- bus_dmasync_op_t);
+void isadma_bounce_dmamap_sync(bus_dma_tag_t, bus_dmamap_t, bus_addr_t,
+ bus_size_t, int);
int isadma_bounce_dmamem_alloc(bus_dma_tag_t, bus_size_t, bus_size_t,
bus_size_t, bus_dma_segment_t *, int, int *, int);
#endif /* _ALPHA_BUS_DMA_PRIVATE */
diff --git a/sys/arch/alpha/isa/isadma_bounce.c b/sys/arch/alpha/isa/isadma_bounce.c
index 7dc9014957d..14b61e65560 100644
--- a/sys/arch/alpha/isa/isadma_bounce.c
+++ b/sys/arch/alpha/isa/isadma_bounce.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: isadma_bounce.c,v 1.1 2001/11/05 02:39:56 art Exp $ */
+/* $OpenBSD: isadma_bounce.c,v 1.2 2001/11/05 17:25:57 art Exp $ */
/* $NetBSD: isadma_bounce.c,v 1.3 2000/06/29 09:02:57 mrg Exp $ */
/*-
@@ -386,12 +386,10 @@ isadma_bounce_dmamap_unload(bus_dma_tag_t t, bus_dmamap_t map)
}
void
-isadma_bounce_dmamap_sync(bus_dma_tag_t t, bus_dmamap_t map,
- bus_dmasync_op_t ops)
+isadma_bounce_dmamap_sync(bus_dma_tag_t t, bus_dmamap_t map, bus_addr_t offset,
+ bus_size_t len, int ops)
{
struct isadma_bounce_cookie *cookie = map->_dm_cookie;
- bus_addr_t offset = 0;
- bus_size_t len = map->dm_mapsize;
/*
* Mixing PRE and POST operations is not allowed.
diff --git a/sys/arch/hppa/gsc/gscbus.c b/sys/arch/hppa/gsc/gscbus.c
index c12c94147bb..02ed051d1cf 100644
--- a/sys/arch/hppa/gsc/gscbus.c
+++ b/sys/arch/hppa/gsc/gscbus.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: gscbus.c,v 1.14 2001/10/04 22:01:30 mickey Exp $ */
+/* $OpenBSD: gscbus.c,v 1.15 2001/11/05 17:25:57 art Exp $ */
/*
* Copyright (c) 1998 Michael Shalayeff
@@ -106,7 +106,8 @@ int gsc_dmamap_load_uio __P((void *, bus_dmamap_t, struct uio *, int));
int gsc_dmamap_load_raw __P((void *, bus_dmamap_t,
bus_dma_segment_t *, int, bus_size_t, int));
void gsc_dmamap_unload __P((void *, bus_dmamap_t));
-void gsc_dmamap_sync __P((void *, bus_dmamap_t, bus_dmasync_op_t));
+void gsc_dmamap_sync __P((void *, bus_dmamap_t, bus_addr_t, bus_size_t,
+ int));
int gsc_dmamem_alloc __P((void *, bus_size_t, bus_size_t,
bus_size_t, bus_dma_segment_t *, int, int *, int));
@@ -347,10 +348,12 @@ gsc_dmamap_unload(v, map)
}
void
-gsc_dmamap_sync(v, map, op)
+gsc_dmamap_sync(v, map, offset, len, op)
void *v;
bus_dmamap_t map;
- bus_dmasync_op_t op;
+ bus_addr_t offset;
+ bus_size_t len;
+ int op;
{
}
diff --git a/sys/arch/hppa/hppa/mainbus.c b/sys/arch/hppa/hppa/mainbus.c
index b31a8ed923b..d1c50ad91c7 100644
--- a/sys/arch/hppa/hppa/mainbus.c
+++ b/sys/arch/hppa/hppa/mainbus.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: mainbus.c,v 1.13 2001/09/19 20:50:56 mickey Exp $ */
+/* $OpenBSD: mainbus.c,v 1.14 2001/11/05 17:25:57 art Exp $ */
/*
* Copyright (c) 1998-2000 Michael Shalayeff
@@ -682,7 +682,8 @@ mbus_dmamap_unload(void *v, bus_dmamap_t map)
}
void
-mbus_dmamap_sync(void *v, bus_dmamap_t map, bus_dmasync_op_t ops)
+mbus_dmamap_sync(void *v, bus_dmamap_t map, bus_addr_t offset, bus_size_t len,
+ int ops)
{
int i;
switch (ops) {
@@ -693,15 +694,17 @@ mbus_dmamap_sync(void *v, bus_dmamap_t map, bus_dmasync_op_t ops)
case BUS_DMASYNC_PREREAD:
for (i = map->dm_nsegs; i--; )
- pdcache(HPPA_SID_KERNEL, map->dm_segs[i].ds_addr,
- map->dm_segs[i].ds_len);
+ pdcache(HPPA_SID_KERNEL,
+ map->dm_segs[i].ds_addr + offset,
+ len);
sync_caches();
break;
case BUS_DMASYNC_PREWRITE:
for (i = map->dm_nsegs; i--; )
- fdcache(HPPA_SID_KERNEL, map->dm_segs[i].ds_addr,
- map->dm_segs[i].ds_len);
+ fdcache(HPPA_SID_KERNEL,
+ map->dm_segs[i].ds_addr + offset,
+ len);
sync_caches();
break;
}
diff --git a/sys/arch/hppa/include/bus.h b/sys/arch/hppa/include/bus.h
index 1139bb4c994..4465645ca40 100644
--- a/sys/arch/hppa/include/bus.h
+++ b/sys/arch/hppa/include/bus.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: bus.h,v 1.13 2001/07/30 14:15:59 art Exp $ */
+/* $OpenBSD: bus.h,v 1.14 2001/11/05 17:25:57 art Exp $ */
/*
* Copyright (c) 1998,1999 Michael Shalayeff
@@ -298,12 +298,11 @@ struct mbuf;
struct proc;
struct uio;
-typedef enum {
- BUS_DMASYNC_POSTREAD,
- BUS_DMASYNC_POSTWRITE,
- BUS_DMASYNC_PREREAD,
- BUS_DMASYNC_PREWRITE
-} bus_dmasync_op_t;
+/* Operations performed by bus_dmamap_sync(). */
+#define BUS_DMASYNC_POSTREAD 0x01
+#define BUS_DMASYNC_POSTWRITE 0x02
+#define BUS_DMASYNC_PREREAD 0x04
+#define BUS_DMASYNC_PREWRITE 0x08
typedef const struct hppa_bus_dma_tag *bus_dma_tag_t;
typedef struct hppa_bus_dmamap *bus_dmamap_t;
@@ -345,7 +344,8 @@ struct hppa_bus_dma_tag {
int (*_dmamap_load_raw) __P((void *, bus_dmamap_t,
bus_dma_segment_t *, int, bus_size_t, int));
void (*_dmamap_unload) __P((void *, bus_dmamap_t));
- void (*_dmamap_sync) __P((void *, bus_dmamap_t, bus_dmasync_op_t));
+ void (*_dmamap_sync) __P((void *, bus_dmamap_t, bus_addr_t,
+ bus_size_t, int));
/*
* DMA memory utility functions.
@@ -374,9 +374,9 @@ struct hppa_bus_dma_tag {
(*(t)->_dmamap_load_raw)((t)->_cookie, (m), (sg), (n), (s), (f))
#define bus_dmamap_unload(t, p) \
(*(t)->_dmamap_unload)((t)->_cookie, (p))
-#define bus_dmamap_sync(t, p, o) \
+#define bus_dmamap_sync(t, p, a, l, o) \
(void)((t)->_dmamap_sync ? \
- (*(t)->_dmamap_sync)((t)->_cookie, (p), (o)) : (void)0)
+ (*(t)->_dmamap_sync)((t)->_cookie, (p), (a), (l), (o)) : (void)0)
#define bus_dmamem_alloc(t, s, a, b, sg, n, r, f) \
(*(t)->_dmamem_alloc)((t)->_cookie, (s), (a), (b), (sg), (n), (r), (f))
diff --git a/sys/arch/i386/i386/machdep.c b/sys/arch/i386/i386/machdep.c
index 72d05721a4c..db953029c67 100644
--- a/sys/arch/i386/i386/machdep.c
+++ b/sys/arch/i386/i386/machdep.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: machdep.c,v 1.178 2001/10/04 21:25:03 mickey Exp $ */
+/* $OpenBSD: machdep.c,v 1.179 2001/11/05 17:25:57 art Exp $ */
/* $NetBSD: machdep.c,v 1.214 1996/11/10 03:16:17 thorpej Exp $ */
/*-
@@ -3012,10 +3012,12 @@ _bus_dmamap_unload(t, map)
* by bus-specific DMA map synchronization functions.
*/
void
-_bus_dmamap_sync(t, map, op)
+_bus_dmamap_sync(t, map, addr, size, op)
bus_dma_tag_t t;
bus_dmamap_t map;
- bus_dmasync_op_t op;
+ bus_addr_t addr;
+ bus_size_t size;
+ int op;
{
/* Nothing to do here. */
diff --git a/sys/arch/i386/include/bus.h b/sys/arch/i386/include/bus.h
index c04d967e0cd..7f65068456f 100644
--- a/sys/arch/i386/include/bus.h
+++ b/sys/arch/i386/include/bus.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: bus.h,v 1.30 2001/07/30 14:15:59 art Exp $ */
+/* $OpenBSD: bus.h,v 1.31 2001/11/05 17:25:57 art Exp $ */
/* $NetBSD: bus.h,v 1.6 1996/11/10 03:19:25 thorpej Exp $ */
/*-
@@ -747,16 +747,12 @@ struct proc;
struct uio;
/*
- * bus_dmasync_op_t
- *
- * Operations performed by bus_dmamap_sync().
+ * Operations performed by bus_dmamap_sync().
*/
-typedef enum {
- BUS_DMASYNC_PREREAD,
- BUS_DMASYNC_POSTREAD,
- BUS_DMASYNC_PREWRITE,
- BUS_DMASYNC_POSTWRITE,
-} bus_dmasync_op_t;
+#define BUS_DMASYNC_PREREAD 0x01
+#define BUS_DMASYNC_POSTREAD 0x02
+#define BUS_DMASYNC_PREWRITE 0x04
+#define BUS_DMASYNC_POSTWRITE 0x08
typedef struct i386_bus_dma_tag *bus_dma_tag_t;
typedef struct i386_bus_dmamap *bus_dmamap_t;
@@ -799,7 +795,7 @@ struct i386_bus_dma_tag {
bus_dma_segment_t *, int, bus_size_t, int));
void (*_dmamap_unload) __P((bus_dma_tag_t, bus_dmamap_t));
void (*_dmamap_sync) __P((bus_dma_tag_t, bus_dmamap_t,
- bus_dmasync_op_t));
+ bus_addr_t, bus_size_t, int));
/*
* DMA memory utility functions.
@@ -829,9 +825,9 @@ struct i386_bus_dma_tag {
(*(t)->_dmamap_load_raw)((t), (m), (sg), (n), (s), (f))
#define bus_dmamap_unload(t, p) \
(*(t)->_dmamap_unload)((t), (p))
-#define bus_dmamap_sync(t, p, o) \
+#define bus_dmamap_sync(t, p, o, l, ops) \
(void)((t)->_dmamap_sync ? \
- (*(t)->_dmamap_sync)((t), (p), (o)) : (void)0)
+ (*(t)->_dmamap_sync)((t), (p), (o), (l), (ops)) : (void)0)
#define bus_dmamem_alloc(t, s, a, b, sg, n, r, f) \
(*(t)->_dmamem_alloc)((t), (s), (a), (b), (sg), (n), (r), (f))
@@ -882,7 +878,8 @@ int _bus_dmamap_load_uio __P((bus_dma_tag_t, bus_dmamap_t,
int _bus_dmamap_load_raw __P((bus_dma_tag_t, bus_dmamap_t,
bus_dma_segment_t *, int, bus_size_t, int));
void _bus_dmamap_unload __P((bus_dma_tag_t, bus_dmamap_t));
-void _bus_dmamap_sync __P((bus_dma_tag_t, bus_dmamap_t, bus_dmasync_op_t));
+void _bus_dmamap_sync __P((bus_dma_tag_t, bus_dmamap_t, bus_addr_t,
+ bus_size_t, int));
int _bus_dmamem_alloc __P((bus_dma_tag_t tag, bus_size_t size,
bus_size_t alignment, bus_size_t boundary,
diff --git a/sys/arch/i386/isa/isa_machdep.c b/sys/arch/i386/isa/isa_machdep.c
index 345633fc772..13cdd3ff3cb 100644
--- a/sys/arch/i386/isa/isa_machdep.c
+++ b/sys/arch/i386/isa/isa_machdep.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: isa_machdep.c,v 1.38 2001/07/30 14:15:59 art Exp $ */
+/* $OpenBSD: isa_machdep.c,v 1.39 2001/11/05 17:25:57 art Exp $ */
/* $NetBSD: isa_machdep.c,v 1.22 1997/06/12 23:57:32 thorpej Exp $ */
#define ISA_DMA_STATS
@@ -169,7 +169,7 @@ int _isa_bus_dmamap_load_raw __P((bus_dma_tag_t, bus_dmamap_t,
bus_dma_segment_t *, int, bus_size_t, int));
void _isa_bus_dmamap_unload __P((bus_dma_tag_t, bus_dmamap_t));
void _isa_bus_dmamap_sync __P((bus_dma_tag_t, bus_dmamap_t,
- bus_dmasync_op_t));
+ bus_addr_t, bus_size_t, int));
int _isa_bus_dmamem_alloc __P((bus_dma_tag_t, bus_size_t, bus_size_t,
bus_size_t, bus_dma_segment_t *, int, int *, int));
@@ -885,13 +885,24 @@ _isa_bus_dmamap_unload(t, map)
* Synchronize an ISA DMA map.
*/
void
-_isa_bus_dmamap_sync(t, map, op)
+_isa_bus_dmamap_sync(t, map, offset, len, op)
bus_dma_tag_t t;
bus_dmamap_t map;
- bus_dmasync_op_t op;
+ bus_addr_t offset;
+ bus_size_t len;
+ int op;
{
struct i386_isa_dma_cookie *cookie = map->_dm_cookie;
+#ifdef DEBUG
+ if ((op & (BUS_DMASYNC_PREWRITE|BUS_DMASYNC_POSTREAD)) != 0) {
+ if (offset >= map->dm_mapsize)
+ panic("_isa_bus_dmamap_sync: bad offset");
+ if (len == 0 || (offset + len) > map->dm_mapsize)
+ panic("_isa_bus_dmamap_sync: bad length");
+ }
+#endif
+
switch (op) {
case BUS_DMASYNC_PREREAD:
/*
@@ -905,8 +916,9 @@ _isa_bus_dmamap_sync(t, map, op)
* caller's buffer to the bounce buffer.
*/
if (cookie->id_flags & ID_IS_BOUNCING)
- bcopy(cookie->id_origbuf, cookie->id_bouncebuf,
- cookie->id_origbuflen);
+ bcopy(cookie->id_origbuf + offset,
+ cookie->id_bouncebuf + offset,
+ len);
break;
case BUS_DMASYNC_POSTREAD:
@@ -915,8 +927,9 @@ _isa_bus_dmamap_sync(t, map, op)
* bounce buffer to the caller's buffer.
*/
if (cookie->id_flags & ID_IS_BOUNCING)
- bcopy(cookie->id_bouncebuf, cookie->id_origbuf,
- cookie->id_origbuflen);
+ bcopy(cookie->id_bouncebuf + offset,
+ cookie->id_origbuf + offset,
+ len);
break;
case BUS_DMASYNC_POSTWRITE:
@@ -1214,7 +1227,7 @@ isadma_copyfrombuf(addr, nbytes, nphys, phys)
bus_dma_tag_t dmat = ((struct isa_softc *)isa_dev)->sc_dmat;
bus_dmamap_t dmam = phys[0].dmam;
- bus_dmamap_sync(dmat, dmam, BUS_DMASYNC_POSTREAD);
+ bus_dmamap_sync(dmat, dmam, 0, dmam->dm_mapsize, BUS_DMASYNC_POSTREAD);
}
/*
@@ -1230,7 +1243,7 @@ isadma_copytobuf(addr, nbytes, nphys, phys)
bus_dma_tag_t dmat = ((struct isa_softc *)isa_dev)->sc_dmat;
bus_dmamap_t dmam = phys[0].dmam;
- bus_dmamap_sync(dmat, dmam, BUS_DMASYNC_PREWRITE);
+ bus_dmamap_sync(dmat, dmam, 0, dmam->dm_mapsize, BUS_DMASYNC_PREWRITE);
}
#endif /* __ISADMA_COMPAT */
#endif /* NISADMA > 0 */
diff --git a/sys/arch/macppc/include/bus.h b/sys/arch/macppc/include/bus.h
index eb4904a0ad5..91243530911 100644
--- a/sys/arch/macppc/include/bus.h
+++ b/sys/arch/macppc/include/bus.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: bus.h,v 1.1 2001/09/01 15:49:06 drahn Exp $ */
+/* $OpenBSD: bus.h,v 1.2 2001/11/05 17:25:58 art Exp $ */
/*
* Copyright (c) 1997 Per Fogelstrom. All rights reserved.
@@ -393,12 +393,10 @@ struct mbuf;
struct proc;
struct uio;
-typedef enum {
- BUS_DMASYNC_POSTREAD,
- BUS_DMASYNC_POSTWRITE,
- BUS_DMASYNC_PREREAD,
- BUS_DMASYNC_PREWRITE
-} bus_dmasync_op_t;
+#define BUS_DMASYNC_POSTREAD 0x01
+#define BUS_DMASYNC_POSTWRITE 0x02
+#define BUS_DMASYNC_PREREAD 0x04
+#define BUS_DMASYNC_PREWRITE 0x08
typedef struct powerpc_bus_dma_tag *bus_dma_tag_t;
typedef struct powerpc_bus_dmamap *bus_dmamap_t;
@@ -440,7 +438,8 @@ struct powerpc_bus_dma_tag {
int (*_dmamap_load_raw) __P((bus_dma_tag_t , bus_dmamap_t,
bus_dma_segment_t *, int, bus_size_t, int));
void (*_dmamap_unload) __P((bus_dma_tag_t , bus_dmamap_t));
- void (*_dmamap_sync) __P((bus_dma_tag_t , bus_dmamap_t, bus_dmasync_op_t));
+ void (*_dmamap_sync) __P((bus_dma_tag_t , bus_dmamap_t,
+ bus_addr_t, bus_size_t, int));
/*
* DMA memory utility functions.
@@ -469,9 +468,9 @@ struct powerpc_bus_dma_tag {
(*(t)->_dmamap_load_raw)((t), (m), (sg), (n), (s), (f))
#define bus_dmamap_unload(t, p) \
(*(t)->_dmamap_unload)((t), (p))
-#define bus_dmamap_sync(t, p, o) \
+#define bus_dmamap_sync(t, p, a, l, o) \
(void)((t)->_dmamap_sync ? \
- (*(t)->_dmamap_sync)((t), (p), (o)) : (void)0)
+ (*(t)->_dmamap_sync)((t), (p), (a), (l), (o)) : (void)0)
#define bus_dmamem_alloc(t, s, a, b, sg, n, r, f) \
(*(t)->_dmamem_alloc)((t)->_cookie, (s), (a), (b), (sg), (n), (r), (f))
@@ -494,7 +493,8 @@ int _dmamap_load_uio __P((bus_dma_tag_t, bus_dmamap_t, struct uio *, int));
int _dmamap_load_raw __P((bus_dma_tag_t, bus_dmamap_t,
bus_dma_segment_t *, int, bus_size_t, int));
void _dmamap_unload __P((bus_dma_tag_t, bus_dmamap_t));
-void _dmamap_sync __P((bus_dma_tag_t, bus_dmamap_t, bus_dmasync_op_t));
+void _dmamap_sync __P((bus_dma_tag_t, bus_dmamap_t, bus_addr_t, bus_size_t,
+ int));
int _dmamem_alloc __P((bus_dma_tag_t, bus_size_t, bus_size_t,
bus_size_t, bus_dma_segment_t *, int, int *, int));
@@ -524,6 +524,7 @@ struct powerpc_bus_dmamap {
/*
* PUBLIC MEMBERS: these are used by machine-independent code.
*/
+ bus_size_t dm_mapsize; /* size of the mapping */
int dm_nsegs; /* # valid segments in mapping */
bus_dma_segment_t dm_segs[1]; /* segments; variable length */
};
diff --git a/sys/arch/macppc/macppc/dma.c b/sys/arch/macppc/macppc/dma.c
index 0258f412bbf..c7b1b7198f6 100644
--- a/sys/arch/macppc/macppc/dma.c
+++ b/sys/arch/macppc/macppc/dma.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: dma.c,v 1.3 2001/09/19 20:50:57 mickey Exp $ */
+/* $OpenBSD: dma.c,v 1.4 2001/11/05 17:25:58 art Exp $ */
/* $NetBSD: machdep.c,v 1.214 1996/11/10 03:16:17 thorpej Exp $ */
/*-
@@ -104,6 +104,7 @@ _dmamap_create(t, size, nsegments, maxsegsz, boundary, flags, dmamp)
map->_dm_boundary = boundary;
map->_dm_flags = flags & ~(BUS_DMA_WAITOK|BUS_DMA_NOWAIT);
map->dm_nsegs = 0; /* no valid mappings */
+ map->dm_mapsize = 0;
*dmamp = map;
return (0);
@@ -140,11 +141,13 @@ _dmamap_load(t, map, buf, buflen, p, flags)
caddr_t vaddr = buf;
int first, seg;
pmap_t pmap;
+ bus_size_t saved_buflen;
/*
* Make sure that on error condition we return "no valid mappings".
*/
map->dm_nsegs = 0;
+ map->dm_mapsize = 0;
if (buflen > map->_dm_size)
return (EINVAL);
@@ -157,6 +160,7 @@ _dmamap_load(t, map, buf, buflen, p, flags)
lastaddr = ~0; /* XXX gcc */
bmask = ~(map->_dm_boundary - 1);
+ saved_buflen = buflen;
for (first = 1, seg = 0; buflen > 0; ) {
/*
* Get the physical address for this segment.
@@ -215,6 +219,7 @@ _dmamap_load(t, map, buf, buflen, p, flags)
return (EFBIG); /* XXX better return value here? */
map->dm_nsegs = seg + 1;
+ map->dm_mapsize = saved_buflen;
return (0);
}
@@ -280,6 +285,7 @@ _dmamap_load_raw(t, map, segs, nsegs, size, flags)
bcopy(segs, map->dm_segs, nsegs * sizeof(*segs));
map->dm_nsegs = nsegs;
+ map->dm_mapsize = size;
return (0);
}
@@ -298,6 +304,7 @@ _dmamap_unload(t, map)
* invalid.
*/
map->dm_nsegs = 0;
+ map->dm_mapsize = 0;
}
/*
@@ -305,10 +312,12 @@ _dmamap_unload(t, map)
* by bus-specific DMA map synchronization functions.
*/
void
-_dmamap_sync(t, map, op)
+_dmamap_sync(t, map, offset, len, op)
bus_dma_tag_t t;
bus_dmamap_t map;
- bus_dmasync_op_t op;
+ bus_addr_t offset;
+ bus_size_t len;
+ int op;
{
/* Nothing to do here. */
diff --git a/sys/arch/mvmeppc/include/bus_mi.h b/sys/arch/mvmeppc/include/bus_mi.h
index 9ce8209835b..a2cc5b80ba3 100644
--- a/sys/arch/mvmeppc/include/bus_mi.h
+++ b/sys/arch/mvmeppc/include/bus_mi.h
@@ -1,5 +1,5 @@
/* $NetBSD: bus.h,v 1.1 2001/06/06 17:37:37 matt Exp $ */
-/* $OpenBSD: bus_mi.h,v 1.2 2001/09/23 01:42:38 miod Exp $ */
+/* $OpenBSD: bus_mi.h,v 1.3 2001/11/05 17:25:58 art Exp $ */
/*-
* Copyright (c) 1996, 1997, 1998 The NetBSD Foundation, Inc.
@@ -977,15 +977,10 @@ bus_space_copy_region_4(t, h1, o1, h2, o2, c)
struct mbuf;
struct uio;
-/*
- * Operations performed by bus_dmamap_sync().
- */
-typedef enum {
- BUS_DMASYNC_PREREAD = 0x01, /* pre-read synchronization */
- BUS_DMASYNC_POSTREAD = 0x02, /* post-read synchronization */
- BUS_DMASYNC_PREWRITE = 0x04, /* pre-write synchronization */
- BUS_DMASYNC_POSTWRITE = 0x08 /* post-write synchronization */
-} bus_dmasync_op_t;
+#define BUS_DMASYNC_PREREAD 0x01
+#define BUS_DMASYNC_POSTREAD 0x02
+#define BUS_DMASYNC_PREWRITE 0x04
+#define BUS_DMASYNC_POSTWRITE 0x08
typedef struct powerpc_bus_dma_tag *bus_dma_tag_t;
typedef struct powerpc_bus_dmamap *bus_dmamap_t;
@@ -1035,7 +1030,8 @@ struct powerpc_bus_dma_tag {
int (*_dmamap_load_raw) __P((bus_dma_tag_t, bus_dmamap_t,
bus_dma_segment_t *, int, bus_size_t, int));
void (*_dmamap_unload) __P((bus_dma_tag_t, bus_dmamap_t));
- void (*_dmamap_sync) __P((bus_dma_tag_t , bus_dmamap_t, bus_dmasync_op_t));
+ void (*_dmamap_sync) __P((bus_dma_tag_t, bus_dmamap_t,
+ bus_addr_t, bus_size_t, int));
/*
* DMA memory utility functions.
@@ -1065,9 +1061,9 @@ struct powerpc_bus_dma_tag {
(*(t)->_dmamap_load_raw)((t), (m), (sg), (n), (s), (f))
#define bus_dmamap_unload(t, p) \
(*(t)->_dmamap_unload)((t), (p))
-#define bus_dmamap_sync(t, p, o) \
+#define bus_dmamap_sync(t, p, a, l, o) \
(void)((t)->_dmamap_sync ? \
- (*(t)->_dmamap_sync)((t), (p), (o)) : (void)0)
+ (*(t)->_dmamap_sync)((t), (p), (a), (l), (o)) : (void)0)
#define bus_dmamem_alloc(t, s, a, b, sg, n, r, f) \
(*(t)->_dmamem_alloc)((t), (s), (a), (b), (sg), (n), (r), (f))
@@ -1119,7 +1115,8 @@ int _bus_dmamap_load_uio __P((bus_dma_tag_t, bus_dmamap_t,
int _bus_dmamap_load_raw __P((bus_dma_tag_t, bus_dmamap_t,
bus_dma_segment_t *, int, bus_size_t, int));
void _bus_dmamap_unload __P((bus_dma_tag_t, bus_dmamap_t));
-void _bus_dmamap_sync __P((bus_dma_tag_t, bus_dmamap_t, bus_dmasync_op_t));
+void _bus_dmamap_sync __P((bus_dma_tag_t, bus_dmamap_t, bus_addr_t,
+ bus_size_t, int));
int _bus_dmamem_alloc __P((bus_dma_tag_t tag, bus_size_t size,
bus_size_t alignment, bus_size_t boundary,
diff --git a/sys/arch/mvmeppc/mvmeppc/bus_dma.c b/sys/arch/mvmeppc/mvmeppc/bus_dma.c
index c00ab320083..eef88567b78 100644
--- a/sys/arch/mvmeppc/mvmeppc/bus_dma.c
+++ b/sys/arch/mvmeppc/mvmeppc/bus_dma.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: bus_dma.c,v 1.5 2001/09/19 20:50:57 mickey Exp $ */
+/* $OpenBSD: bus_dma.c,v 1.6 2001/11/05 17:25:58 art Exp $ */
/* $NetBSD: bus_dma.c,v 1.2 2001/06/10 02:31:25 briggs Exp $ */
/*-
@@ -405,10 +405,12 @@ _bus_dmamap_unload(t, map)
*/
void
-_bus_dmamap_sync(t, map, op)
+_bus_dmamap_sync(t, map, offset, len, op)
bus_dma_tag_t t;
bus_dmamap_t map;
- bus_dmasync_op_t op;
+ bus_addr_t offset;
+ bus_size_t len;
+ int op;
{
int i;
switch (op) {
@@ -418,7 +420,7 @@ _bus_dmamap_sync(t, map, op)
case BUS_DMASYNC_PREREAD:
for (i = map->dm_nsegs; i--; )
invdcache(map->dm_segs[i].ds_addr,
- map->dm_segs[i].ds_len);
+ len);
break;
}
}
diff --git a/sys/dev/eisa/cac_eisa.c b/sys/dev/eisa/cac_eisa.c
index 7c90dea630c..0e79cffc4d5 100644
--- a/sys/dev/eisa/cac_eisa.c
+++ b/sys/dev/eisa/cac_eisa.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: cac_eisa.c,v 1.1 2000/12/17 21:35:03 mickey Exp $ */
+/* $OpenBSD: cac_eisa.c,v 1.2 2001/11/05 17:25:58 art Exp $ */
/* $NetBSD: cac_eisa.c,v 1.1 2000/09/01 12:15:20 ad Exp $ */
/*-
@@ -244,8 +244,8 @@ cac_eisa_l0_submit(struct cac_softc *sc, struct cac_ccb *ccb)
size = letoh16(ccb->ccb_hdr.size) << 2;
ccb->ccb_hdr.size = 0;
- bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap,
- BUS_DMASYNC_PREWRITE | BUS_DMASYNC_PREREAD);
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap, (caddr_t)ccb - sc->sc_ccbs,
+ sizeof(struct cac_ccb), BUS_DMASYNC_PREWRITE | BUS_DMASYNC_PREREAD);
cac_outb(sc, CAC_EISAREG_SYSTEM_DOORBELL, CAC_EISA_CHANNEL_CLEAR);
cac_outl(sc, CAC_EISAREG_LIST_ADDR, ccb->ccb_paddr);
@@ -275,7 +275,7 @@ cac_eisa_l0_completed(struct cac_softc *sc)
off = (off & ~3) - sc->sc_ccbs_paddr;
ccb = (struct cac_ccb *)(sc->sc_ccbs + off);
- bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap, off, sizeof(struct cac_ccb),
BUS_DMASYNC_POSTWRITE | BUS_DMASYNC_POSTREAD);
ccb->ccb_req.error = status;
diff --git a/sys/dev/i2o/iop.c b/sys/dev/i2o/iop.c
index 834ecf43578..a3c20855c8f 100644
--- a/sys/dev/i2o/iop.c
+++ b/sys/dev/i2o/iop.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: iop.c,v 1.19 2001/10/27 20:54:24 mickey Exp $ */
+/* $OpenBSD: iop.c,v 1.20 2001/11/05 17:25:58 art Exp $ */
/* $NetBSD: iop.c,v 1.12 2001/03/21 14:27:05 ad Exp $ */
/*-
@@ -914,15 +914,16 @@ iop_status_get(struct iop_softc *sc, int nosleep)
mf.length = sizeof(*st);
bzero(st, sizeof(*st));
- bus_dmamap_sync(sc->sc_dmat, sc->sc_scr_dmamap, BUS_DMASYNC_PREREAD);
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_scr_dmamap, 0, sizeof(*st),
+ BUS_DMASYNC_PREREAD);
if ((rv = iop_post(sc, (u_int32_t *)&mf)))
return (rv);
/* XXX */
POLL(2500,
- (bus_dmamap_sync(sc->sc_dmat, sc->sc_scr_dmamap,
- BUS_DMASYNC_POSTREAD), st->syncbyte == 0xff));
+ (bus_dmamap_sync(sc->sc_dmat, sc->sc_scr_dmamap, 0,
+ sizeof(*st), BUS_DMASYNC_POSTREAD), st->syncbyte == 0xff));
if (st->syncbyte != 0xff)
return (EIO);
@@ -957,7 +958,8 @@ iop_ofifo_init(struct iop_softc *sc)
mb[0] += 2 << 16;
*sw = 0;
- bus_dmamap_sync(sc->sc_dmat, sc->sc_scr_dmamap, BUS_DMASYNC_PREREAD);
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_scr_dmamap, 0, sizeof(*sw),
+ BUS_DMASYNC_PREREAD);
/*
* The I2O spec says that there are two SGLs: one for the status
@@ -970,7 +972,7 @@ iop_ofifo_init(struct iop_softc *sc)
/* XXX */
POLL(5000,
- (bus_dmamap_sync(sc->sc_dmat, sc->sc_scr_dmamap,
+ (bus_dmamap_sync(sc->sc_dmat, sc->sc_scr_dmamap, 0, sizeof(*sw),
BUS_DMASYNC_POSTREAD),
*sw == htole32(I2O_EXEC_OUTBOUND_INIT_COMPLETE)));
if (*sw != htole32(I2O_EXEC_OUTBOUND_INIT_COMPLETE)) {
@@ -1367,14 +1369,15 @@ iop_reset(struct iop_softc *sc)
mf.statushigh = sizeof pa > sizeof mf.statuslow ? pa >> 32 : 0;
*sw = htole32(0);
- bus_dmamap_sync(sc->sc_dmat, sc->sc_scr_dmamap, BUS_DMASYNC_PREREAD);
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_scr_dmamap, 0, sizeof(*sw),
+ BUS_DMASYNC_PREREAD);
if ((rv = iop_post(sc, (u_int32_t *)&mf)))
return (rv);
/* XXX */
POLL(2500,
- (bus_dmamap_sync(sc->sc_dmat, sc->sc_scr_dmamap,
+ (bus_dmamap_sync(sc->sc_dmat, sc->sc_scr_dmamap, 0, sizeof(*sw),
BUS_DMASYNC_POSTREAD), *sw != htole32(0)));
if (*sw != htole32(I2O_RESET_IN_PROGRESS)) {
printf("%s: reset rejected, status 0x%x\n",
@@ -1462,10 +1465,11 @@ iop_handle_reply(struct iop_softc *sc, u_int32_t rmfa)
rb = (struct i2o_reply *)(sc->sc_rep + off);
/* Perform reply queue DMA synchronisation. XXX This is rubbish. */
- bus_dmamap_sync(sc->sc_dmat, sc->sc_rep_dmamap, BUS_DMASYNC_POSTREAD);
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_rep_dmamap, off,
+ sc->sc_rep_dmamap->dm_mapsize, BUS_DMASYNC_POSTREAD);
if (--sc->sc_curib != 0)
- bus_dmamap_sync(sc->sc_dmat, sc->sc_rep_dmamap,
- BUS_DMASYNC_PREREAD);
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_rep_dmamap, 0,
+ sc->sc_rep_size, BUS_DMASYNC_PREREAD);
#ifdef I2ODEBUG
if ((letoh32(rb->msgflags) & I2O_MSGFLAGS_64BIT) != 0)
@@ -1761,7 +1765,7 @@ iop_msg_map(struct iop_softc *sc, struct iop_msg *im, u_int32_t *mb,
/* Fix up the transfer record, and sync the map. */
ix->ix_flags = (out ? IX_OUT : IX_IN);
ix->ix_size = xfersize;
- bus_dmamap_sync(sc->sc_dmat, ix->ix_map,
+ bus_dmamap_sync(sc->sc_dmat, ix->ix_map, 0, xfersize,
out ? BUS_DMASYNC_POSTWRITE : BUS_DMASYNC_POSTREAD);
/*
@@ -1866,7 +1870,8 @@ iop_msg_map_bio(struct iop_softc *sc, struct iop_msg *im, u_int32_t *mb,
/* Fix up the transfer record, and sync the map. */
ix->ix_flags = (out ? IX_OUT : IX_IN);
ix->ix_size = xfersize;
- bus_dmamap_sync(sc->sc_dmat, ix->ix_map,
+ bus_dmamap_sync(sc->sc_dmat, ix->ix_map, 0,
+ ix->ix_map->dm_mapsize,
out ? BUS_DMASYNC_POSTWRITE : BUS_DMASYNC_POSTREAD);
/*
@@ -1892,7 +1897,7 @@ iop_msg_unmap(struct iop_softc *sc, struct iop_msg *im)
#endif
for (ix = im->im_xfer, i = 0;;) {
- bus_dmamap_sync(sc->sc_dmat, ix->ix_map,
+ bus_dmamap_sync(sc->sc_dmat, ix->ix_map, 0, ix->ix_size,
ix->ix_flags & IX_OUT ? BUS_DMASYNC_POSTWRITE :
BUS_DMASYNC_POSTREAD);
bus_dmamap_unload(sc->sc_dmat, ix->ix_map);
@@ -1948,8 +1953,8 @@ iop_post(struct iop_softc *sc, u_int32_t *mb)
/* Perform reply buffer DMA synchronisation. XXX This is rubbish. */
if (sc->sc_curib++ == 0)
- bus_dmamap_sync(sc->sc_dmat, sc->sc_rep_dmamap,
- BUS_DMASYNC_PREREAD);
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_rep_dmamap, 0,
+ sc->sc_rep_size, BUS_DMASYNC_PREREAD);
/* Copy out the message frame. */
bus_space_write_region_4(sc->sc_iot, sc->sc_ioh, mfa, mb,
diff --git a/sys/dev/ic/aac.c b/sys/dev/ic/aac.c
index ff88c3e58cc..1b69cbd1821 100644
--- a/sys/dev/ic/aac.c
+++ b/sys/dev/ic/aac.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: aac.c,v 1.8 2001/09/21 17:55:43 miod Exp $ */
+/* $OpenBSD: aac.c,v 1.9 2001/11/05 17:25:58 art Exp $ */
/*-
* Copyright (c) 2000 Michael Smith
@@ -1640,7 +1640,8 @@ aac_map_command(struct aac_ccb *ccb)
return (error);
}
- bus_dmamap_sync(sc->sc_dmat, ccb->ac_dmamap_xfer,
+ bus_dmamap_sync(sc->sc_dmat, ccb->ac_dmamap_xfer, 0,
+ ccb->ac_dmamap_xfer->dm_mapsize,
(xs->flags & SCSI_DATA_IN) ? BUS_DMASYNC_PREREAD :
BUS_DMASYNC_PREWRITE);
}
@@ -1666,7 +1667,8 @@ aac_unmap_command(struct aac_ccb *ccb)
#endif
if (xs->datalen != 0) {
- bus_dmamap_sync(sc->sc_dmat, ccb->ac_dmamap_xfer,
+ bus_dmamap_sync(sc->sc_dmat, ccb->ac_dmamap_xfer, 0,
+ ccb->ac_dmamap_xfer->dm_mapsize,
(xs->flags & SCSI_DATA_IN) ? BUS_DMASYNC_POSTREAD :
BUS_DMASYNC_POSTWRITE);
diff --git a/sys/dev/ic/adv.c b/sys/dev/ic/adv.c
index e6a22226a3d..5200e1d0b78 100644
--- a/sys/dev/ic/adv.c
+++ b/sys/dev/ic/adv.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: adv.c,v 1.9 2001/08/26 18:03:07 krw Exp $ */
+/* $OpenBSD: adv.c,v 1.10 2001/11/05 17:25:58 art Exp $ */
/* $NetBSD: adv.c,v 1.6 1998/10/28 20:39:45 dante Exp $ */
/*
@@ -778,7 +778,7 @@ adv_scsi_cmd(xs)
adv_free_ccb(sc, ccb);
return (COMPLETE);
}
- adv_bus_dmamap_sync(dmat, ccb->dmamap_xfer,
+ bus_dmamap_sync(dmat, ccb->dmamap_xfer,
0, ccb->dmamap_xfer->dm_mapsize,
((flags & SCSI_DATA_IN) ? BUS_DMASYNC_PREREAD :
BUS_DMASYNC_PREWRITE));
@@ -990,7 +990,7 @@ adv_narrow_isr_callback(sc, qdonep)
* the data buffer.
*/
if (xs->datalen) {
- adv_bus_dmamap_sync(dmat, ccb->dmamap_xfer,
+ bus_dmamap_sync(dmat, ccb->dmamap_xfer,
0, ccb->dmamap_xfer->dm_mapsize,
((xs->flags & SCSI_DATA_IN) ? BUS_DMASYNC_POSTREAD :
BUS_DMASYNC_POSTWRITE));
diff --git a/sys/dev/ic/adv.h b/sys/dev/ic/adv.h
index e3498fb2101..d8e9b31ae2f 100644
--- a/sys/dev/ic/adv.h
+++ b/sys/dev/ic/adv.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: adv.h,v 1.3 2001/08/26 18:03:07 krw Exp $ */
+/* $OpenBSD: adv.h,v 1.4 2001/11/05 17:25:58 art Exp $ */
/* $NetBSD: adv.h,v 1.3 1998/09/26 16:02:56 dante Exp $ */
/*
@@ -93,12 +93,4 @@ int adv_intr __P((void *arg));
/******************************************************************************/
-#ifdef __HAS_NEW_BUS_DMAMAP_SYNC
-#define adv_bus_dmamap_sync(tag, map, off, len, op) \
- bus_dmamap_sync((tag), (map), (off), (len), (op))
-#else
-#define adv_bus_dmamap_sync(tag, map, off, len, op) \
- bus_dmamap_sync((tag), (map), (op))
-#endif
-
#endif /* _ADVANSYS_NARROW_H_ */
diff --git a/sys/dev/ic/adw.c b/sys/dev/ic/adw.c
index a71e92f199d..6ab8bb987d4 100644
--- a/sys/dev/ic/adw.c
+++ b/sys/dev/ic/adw.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: adw.c,v 1.22 2001/09/21 17:55:43 miod Exp $ */
+/* $OpenBSD: adw.c,v 1.23 2001/11/05 17:25:58 art Exp $ */
/* $NetBSD: adw.c,v 1.23 2000/05/27 18:24:50 dante Exp $ */
/*
@@ -854,7 +854,7 @@ adw_build_req(xs, ccb, flags)
adw_free_ccb(sc, ccb);
return (0);
}
- adw_bus_dmamap_sync(dmat, ccb->dmamap_xfer,
+ bus_dmamap_sync(dmat, ccb->dmamap_xfer,
0, ccb->dmamap_xfer->dm_mapsize,
(xs->flags & SCSI_DATA_IN) ?
BUS_DMASYNC_PREREAD : BUS_DMASYNC_PREWRITE);
@@ -1206,7 +1206,7 @@ adw_isr_callback(sc, scsiq)
*/
dmat = sc->sc_dmat;
if (xs->datalen) {
- adw_bus_dmamap_sync(dmat, ccb->dmamap_xfer,
+ bus_dmamap_sync(dmat, ccb->dmamap_xfer,
0, ccb->dmamap_xfer->dm_mapsize,
((xs->flags & SCSI_DATA_IN) ?
BUS_DMASYNC_POSTREAD : BUS_DMASYNC_POSTWRITE));
diff --git a/sys/dev/ic/adw.h b/sys/dev/ic/adw.h
index 00eccde2028..a2ee9d74e27 100644
--- a/sys/dev/ic/adw.h
+++ b/sys/dev/ic/adw.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: adw.h,v 1.7 2001/08/26 02:39:05 krw Exp $ */
+/* $OpenBSD: adw.h,v 1.8 2001/11/05 17:25:58 art Exp $ */
/* $NetBSD: adw.h,v 1.9 2000/05/26 15:13:43 dante Exp $ */
/*
@@ -116,13 +116,4 @@ ADW_CCB *adw_ccb_phys_kv __P((ADW_SOFTC *, u_int32_t));
/******************************************************************************/
-#ifdef __HAS_NEW_BUS_DMAMAP_SYNC
-#define adw_bus_dmamap_sync(tag, map, off, len, op) \
- bus_dmamap_sync((tag), (map), (off), (len), (op))
-#else
-#define adw_bus_dmamap_sync(tag, map, off, len, op) \
- bus_dmamap_sync((tag), (map), (op))
-#endif
-
-
#endif /* _ADVANSYS_ADW_H_ */
diff --git a/sys/dev/ic/aic7xxx.c b/sys/dev/ic/aic7xxx.c
index 4849d17e887..d1bbca9dd1b 100644
--- a/sys/dev/ic/aic7xxx.c
+++ b/sys/dev/ic/aic7xxx.c
@@ -33,7 +33,7 @@
* SUCH DAMAGE.
*
* $FreeBSD: src/sys/dev/aic7xxx/aic7xxx.c,v 1.40 2000/01/07 23:08:17 gibbs Exp $
- * $OpenBSD: aic7xxx.c,v 1.31 2001/09/20 17:02:31 mpech Exp $
+ * $OpenBSD: aic7xxx.c,v 1.32 2001/11/05 17:25:58 art Exp $
*/
/*
* A few notes on features of the driver.
@@ -255,14 +255,6 @@ typedef enum {
MSGLOOP_TERMINATED
} msg_loop_stat;
-#ifdef __HAS_NEW_BUS_DMAMAP_SYNC
-#define ahc_bus_dmamap_sync(tag, map, off, len, op) \
- bus_dmamap_sync((tag), (map), (off), (len), (op))
-#else
-#define ahc_bus_dmamap_sync(tag, map, off, len, op) \
- bus_dmamap_sync((tag), (map), (op))
-#endif
-
STATIC int ahc_parse_msg __P((struct ahc_softc *ahc,
struct scsi_link *sc_link,
struct ahc_devinfo *devinfo));
@@ -531,7 +523,7 @@ ahc_index_busy_tcl(ahc, tcl, unbusy)
scbid = ahc->untagged_scbs[tcl];
if (unbusy) {
ahc->untagged_scbs[tcl] = SCB_LIST_NULL;
- ahc_bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap,
+ bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap,
UNTAGGEDSCB_OFFSET * 256, 256, BUS_DMASYNC_PREWRITE);
}
@@ -544,7 +536,7 @@ ahc_busy_tcl(ahc, scb)
struct scb *scb;
{
ahc->untagged_scbs[scb->hscb->tcl] = scb->hscb->tag;
- ahc_bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap,
+ bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap,
UNTAGGEDSCB_OFFSET * 256, 256, BUS_DMASYNC_PREWRITE);
}
@@ -606,7 +598,7 @@ ahc_run_qoutfifo(ahc)
struct scb *scb;
u_int scb_index;
- ahc_bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap,
+ bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap,
0, 256, BUS_DMASYNC_POSTREAD);
while (ahc->qoutfifo[ahc->qoutfifonext] != SCB_LIST_NULL) {
@@ -3455,13 +3447,13 @@ ahc_done(ahc, scb)
target = sc_link->target;
if (xs->datalen) {
- bus_dmasync_op_t op;
+ int op;
if ((xs->flags & SCSI_DATA_IN) != 0)
op = BUS_DMASYNC_POSTREAD;
else
op = BUS_DMASYNC_POSTWRITE;
- ahc_bus_dmamap_sync(ahc->sc_dmat, scb->dmamap,
+ bus_dmamap_sync(ahc->sc_dmat, scb->dmamap,
0, scb->dmamap->dm_mapsize, op);
bus_dmamap_unload(ahc->sc_dmat, scb->dmamap);
}
@@ -3681,7 +3673,7 @@ ahc_init(ahc)
for (i = 0; i < 256; i++)
ahc->qoutfifo[i] = SCB_LIST_NULL;
- ahc_bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap,
+ bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap,
0, driver_data_size, BUS_DMASYNC_PREREAD|BUS_DMASYNC_PREWRITE);
/*
@@ -4297,9 +4289,9 @@ ahc_execute_scb(arg, dm_segs, nsegments)
if (nsegments != 0) {
- struct ahc_dma_seg *sg;
+ struct ahc_dma_seg *sg;
bus_dma_segment_t *end_seg;
- bus_dmasync_op_t op;
+ int op;
end_seg = dm_segs + nsegments;
@@ -4323,7 +4315,7 @@ ahc_execute_scb(arg, dm_segs, nsegments)
op = BUS_DMASYNC_PREREAD;
else
op = BUS_DMASYNC_PREWRITE;
- ahc_bus_dmamap_sync(ahc->sc_dmat, scb->dmamap,
+ bus_dmamap_sync(ahc->sc_dmat, scb->dmamap,
0, scb->dmamap->dm_mapsize, op);
} else {
scb->hscb->SG_pointer = 0;
@@ -4379,7 +4371,7 @@ ahc_execute_scb(arg, dm_segs, nsegments)
ahc->qinfifo[ahc->qinfifonext++] = scb->hscb->tag;
- ahc_bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap,
+ bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap,
QINFIFO_OFFSET * 256, 256, BUS_DMASYNC_PREWRITE);
if ((ahc->features & AHC_QUEUE_REGS) != 0) {
@@ -5080,7 +5072,7 @@ bus_reset:
ahc->qinfifo[ahc->qinfifonext++] =
scb->hscb->tag;
- ahc_bus_dmamap_sync(ahc->sc_dmat,
+ bus_dmamap_sync(ahc->sc_dmat,
ahc->shared_data_dmamap,
QINFIFO_OFFSET * 256, 256,
BUS_DMASYNC_PREWRITE);
@@ -5134,7 +5126,7 @@ ahc_search_qinfifo(ahc, target, channel, lun, tag, role, status, action)
* for removal will be re-added to the queue as we go.
*/
ahc->qinfifonext = qinpos;
- ahc_bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap,
+ bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap,
QINFIFO_OFFSET * 256, 256, BUS_DMASYNC_POSTREAD);
while (qinpos != qintail) {
@@ -5165,7 +5157,7 @@ ahc_search_qinfifo(ahc, target, channel, lun, tag, role, status, action)
}
qinpos++;
}
- ahc_bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap,
+ bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap,
QINFIFO_OFFSET * 256, 256, BUS_DMASYNC_PREWRITE);
if ((ahc->features & AHC_QUEUE_REGS) != 0) {
diff --git a/sys/dev/ic/ami.c b/sys/dev/ic/ami.c
index 9d0dc8fc8e5..35a73263a2d 100644
--- a/sys/dev/ic/ami.c
+++ b/sys/dev/ic/ami.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ami.c,v 1.11 2001/09/11 20:05:25 miod Exp $ */
+/* $OpenBSD: ami.c,v 1.12 2001/11/05 17:25:58 art Exp $ */
/*
* Copyright (c) 2001 Michael Shalayeff
@@ -536,7 +536,8 @@ ami_quartz_done(sc, mbox)
qdb = bus_space_read_4(sc->iot, sc->ioh, AMI_QODB);
if (qdb == AMI_QODB_READY) {
- bus_dmamap_sync(sc->dmat, sc->sc_cmdmap, BUS_DMASYNC_POSTREAD);
+ bus_dmamap_sync(sc->dmat, sc->sc_cmdmap, 0,
+ sc->sc_cmdmap->dm_mapsize, BUS_DMASYNC_POSTREAD);
*mbox = *sc->sc_mbox;
/* ack interrupt */
@@ -659,9 +660,11 @@ ami_cmd(ccb, flags, wait)
}
AMI_DPRINTF(AMI_D_DMA, ("> "));
- bus_dmamap_sync(sc->dmat, dmap, BUS_DMASYNC_PREWRITE);
+ bus_dmamap_sync(sc->dmat, dmap, 0, dmap->dm_mapsize,
+ BUS_DMASYNC_PREWRITE);
}
- bus_dmamap_sync(sc->dmat, sc->sc_cmdmap, BUS_DMASYNC_PREWRITE);
+ bus_dmamap_sync(sc->dmat, sc->sc_cmdmap, 0, sc->sc_cmdmap->dm_mapsize,
+ BUS_DMASYNC_PREWRITE);
if ((error = ami_start(ccb, wait))) {
AMI_DPRINTF(AMI_D_DMA, ("error=%d ", error));
@@ -858,7 +861,8 @@ ami_done(sc, idx)
timeout_del(&xs->stimeout);
if (xs->cmd->opcode != PREVENT_ALLOW &&
xs->cmd->opcode != SYNCHRONIZE_CACHE) {
- bus_dmamap_sync(sc->dmat, ccb->ccb_dmamap,
+ bus_dmamap_sync(sc->dmat, ccb->ccb_dmamap, 0,
+ ccb->ccb_dmamap->dm_mapsize,
(xs->flags & SCSI_DATA_IN) ?
BUS_DMASYNC_POSTREAD :
BUS_DMASYNC_POSTWRITE);
@@ -871,8 +875,8 @@ ami_done(sc, idx)
case AMI_INQUIRY:
case AMI_EINQUIRY:
case AMI_EINQUIRY3:
- bus_dmamap_sync(sc->dmat, ccb->ccb_dmamap,
- BUS_DMASYNC_POSTREAD);
+ bus_dmamap_sync(sc->dmat, ccb->ccb_dmamap, 0,
+ ccb->ccb_dmamap->dm_mapsize, BUS_DMASYNC_POSTREAD);
bus_dmamap_unload(sc->dmat, ccb->ccb_dmamap);
break;
default:
diff --git a/sys/dev/ic/awi_wep.c b/sys/dev/ic/awi_wep.c
index 68d2984632f..d5c920aaa12 100644
--- a/sys/dev/ic/awi_wep.c
+++ b/sys/dev/ic/awi_wep.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: awi_wep.c,v 1.5 2001/11/05 16:35:00 mickey Exp $ */
+/* $OpenBSD: awi_wep.c,v 1.6 2001/11/05 17:25:58 art Exp $ */
/* $NetBSD: awi_wep.c,v 1.2 2000/07/04 14:47:58 onoe Exp $ */
/*
@@ -90,6 +90,7 @@
#include <dev/ic/am79c930var.h>
#include <dev/ic/awireg.h>
#include <dev/ic/awivar.h>
+#include <dev/rndvar.h>
#endif
#ifdef __OpenBSD__
diff --git a/sys/dev/ic/cac.c b/sys/dev/ic/cac.c
index b1b983556b3..0dc2bbaf0bd 100644
--- a/sys/dev/ic/cac.c
+++ b/sys/dev/ic/cac.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: cac.c,v 1.7 2001/10/18 20:24:10 mickey Exp $ */
+/* $OpenBSD: cac.c,v 1.8 2001/11/05 17:25:58 art Exp $ */
/* $NetBSD: cac.c,v 1.15 2000/11/08 19:20:35 ad Exp $ */
/*
@@ -339,7 +339,8 @@ cac_cmd(struct cac_softc *sc, int command, void *data, int datasize,
bus_dmamap_load(sc->sc_dmat, ccb->ccb_dmamap_xfer,
(void *)data, datasize, NULL, BUS_DMA_NOWAIT);
- bus_dmamap_sync(sc->sc_dmat, ccb->ccb_dmamap_xfer,
+ bus_dmamap_sync(sc->sc_dmat, ccb->ccb_dmamap_xfer, 0,
+ ccb->ccb_dmamap_xfer->dm_mapsize,
(flags & CAC_CCB_DATA_IN) != 0 ? BUS_DMASYNC_PREREAD :
BUS_DMASYNC_PREWRITE);
@@ -464,7 +465,8 @@ cac_ccb_done(struct cac_softc *sc, struct cac_ccb *ccb)
ccb->ccb_flags &= ~CAC_CCB_ACTIVE;
if ((ccb->ccb_flags & (CAC_CCB_DATA_IN | CAC_CCB_DATA_OUT)) != 0) {
- bus_dmamap_sync(sc->sc_dmat, ccb->ccb_dmamap_xfer,
+ bus_dmamap_sync(sc->sc_dmat, ccb->ccb_dmamap_xfer, 0,
+ ccb->ccb_dmamap_xfer->dm_mapsize,
ccb->ccb_flags & CAC_CCB_DATA_IN ?
BUS_DMASYNC_POSTREAD : BUS_DMASYNC_POSTWRITE);
bus_dmamap_unload(sc->sc_dmat, ccb->ccb_dmamap_xfer);
@@ -795,7 +797,8 @@ cac_l0_submit(struct cac_softc *sc, struct cac_ccb *ccb)
#ifdef CAC_DEBUG
printf("submit-%x ", ccb->ccb_paddr);
#endif
- bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap, 0,
+ sc->sc_dmamap->dm_mapsize,
BUS_DMASYNC_PREWRITE | BUS_DMASYNC_PREREAD);
cac_outl(sc, CAC_REG_CMD_FIFO, ccb->ccb_paddr);
}
@@ -815,7 +818,8 @@ cac_l0_completed(sc)
ccb = (struct cac_ccb *)(sc->sc_ccbs +
((off & ~3) - sc->sc_ccbs_paddr));
- bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap, 0,
+ sc->sc_dmamap->dm_mapsize,
BUS_DMASYNC_POSTWRITE | BUS_DMASYNC_POSTREAD);
return (ccb);
diff --git a/sys/dev/ic/dpt.c b/sys/dev/ic/dpt.c
index b5e5b51a52b..7f0cbf6daca 100644
--- a/sys/dev/ic/dpt.c
+++ b/sys/dev/ic/dpt.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: dpt.c,v 1.4 2001/07/13 17:04:28 mickey Exp $ */
+/* $OpenBSD: dpt.c,v 1.5 2001/11/05 17:25:58 art Exp $ */
/* $NetBSD: dpt.c,v 1.12 1999/10/23 16:26:33 ad Exp $ */
/*-
@@ -202,14 +202,8 @@ dpt_intr(xxx_sc)
break;
}
-#ifdef __NetBSD__
bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap_ccb, sc->sc_spoff,
sizeof(struct eata_sp), BUS_DMASYNC_POSTREAD);
-#endif /* __NetBSD__ */
-#ifdef __OpenBSD__
- bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap_ccb,
- BUS_DMASYNC_POSTREAD);
-#endif /* __OpenBSD__ */
if (!sp) {
more = dpt_inb(sc, HA_STATUS) & HA_ST_MORE;
@@ -234,15 +228,9 @@ dpt_intr(xxx_sc)
sc->sc_dv.dv_xname);
#endif
/* Re-sync DMA map */
-#ifdef __NetBSD__
bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap_ccb,
sc->sc_spoff, sizeof(struct eata_sp),
BUS_DMASYNC_POSTREAD);
-#endif /* __NetBSD__ */
-#ifdef __OpenBSD__
- bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap_ccb,
- BUS_DMASYNC_POSTREAD);
-#endif /* __OpenBSD__ */
}
/* Make sure CCB ID from status packet is realistic */
@@ -250,15 +238,9 @@ dpt_intr(xxx_sc)
/* Sync up DMA map and cache cmd status */
ccb = sc->sc_ccbs + sp->sp_ccbid;
-#ifdef __NetBSD__
bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap_ccb,
CCB_OFF(sc, ccb), sizeof(struct dpt_ccb),
BUS_DMASYNC_POSTWRITE);
-#endif /* __NetBSD__ */
-#ifdef __OpenBSD__
- bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap_ccb,
- BUS_DMASYNC_POSTWRITE);
-#endif /* __OpenBSD__ */
ccb->ccb_hba_status = sp->sp_hba_status & 0x7F;
ccb->ccb_scsi_status = sp->sp_scsi_status;
@@ -824,17 +806,10 @@ dpt_done_ccb(sc, ccb)
* data buffer.
*/
if (xs->datalen) {
-#ifdef __NetBSD__
bus_dmamap_sync(dmat, ccb->ccb_dmamap_xfer, 0,
ccb->ccb_dmamap_xfer->dm_mapsize,
- (xs->xs_control & XS_CTL_DATA_IN) ? BUS_DMASYNC_POSTREAD :
- BUS_DMASYNC_POSTWRITE);
-#endif /* __NetBSD__ */
-#ifdef __OpenBSD__
- bus_dmamap_sync(dmat, ccb->ccb_dmamap_xfer,
(xs->flags & SCSI_DATA_IN) ? BUS_DMASYNC_POSTREAD :
BUS_DMASYNC_POSTWRITE);
-#endif /* __OpenBSD__ */
bus_dmamap_unload(dmat, ccb->ccb_dmamap_xfer);
}
@@ -1195,15 +1170,9 @@ dpt_scsi_cmd(xs)
return (COMPLETE);
}
-#ifdef __NetBSD__
bus_dmamap_sync(dmat, xfer, 0, xfer->dm_mapsize,
- (flags & XS_CTL_DATA_IN) ? BUS_DMASYNC_PREREAD :
+ (flags & SCSI_DATA_IN) ? BUS_DMASYNC_PREREAD :
BUS_DMASYNC_PREWRITE);
-#endif /* __NetBSD__ */
-#ifdef __OpenBSD__
- bus_dmamap_sync(dmat, xfer, (xs->flags & SCSI_DATA_IN) ?
- BUS_DMASYNC_PREREAD : BUS_DMASYNC_PREWRITE);
-#endif /* __OpenBSD__ */
/* Don't bother using scatter/gather for just 1 segment */
if (xfer->dm_nsegs == 1) {
@@ -1235,16 +1204,10 @@ dpt_scsi_cmd(xs)
}
/* Sync up CCB and status packet */
-#ifdef __NetBSD__
bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap_ccb, CCB_OFF(sc, ccb),
sizeof(struct dpt_ccb), BUS_DMASYNC_PREWRITE);
bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap_ccb, sc->sc_spoff,
sizeof(struct eata_sp), BUS_DMASYNC_PREREAD);
-#endif /* __NetBSD__ */
-#ifdef __OpenBSD__
- bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap_ccb, BUS_DMASYNC_PREWRITE);
- bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap_ccb, BUS_DMASYNC_PREREAD);
-#endif /* __OpenBSD__ */
/*
* Start the command. If we are polling on completion, mark it
@@ -1405,19 +1368,12 @@ dpt_hba_inquire(sc, ei)
cp->cp_len = sizeof(struct eata_inquiry_data);
/* Sync up CCB, status packet and scratch area */
-#ifdef __NetBSD__
bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap_ccb, CCB_OFF(sc, ccb),
sizeof(struct dpt_ccb), BUS_DMASYNC_PREWRITE);
bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap_ccb, sc->sc_spoff,
sizeof(struct eata_sp), BUS_DMASYNC_PREREAD);
bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap_ccb, sc->sc_scroff,
sizeof(struct eata_inquiry_data), BUS_DMASYNC_PREREAD);
-#endif /* __NetBSD__ */
-#ifdef __OpenBSD__
- bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap_ccb, BUS_DMASYNC_PREWRITE);
- bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap_ccb, BUS_DMASYNC_PREREAD);
- bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap_ccb, BUS_DMASYNC_PREREAD);
-#endif /* __OpenBSD__ */
/* Start the command and poll on completion */
if (dpt_cmd(sc, &ccb->ccb_eata_cp, ccb->ccb_ccbpa, CP_DMA_CMD, 0))
@@ -1433,12 +1389,7 @@ dpt_hba_inquire(sc, ei)
ccb->ccb_scsi_status);
/* Sync up the DMA map and free CCB, returning */
-#ifdef __NetBSD__
bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap_ccb, sc->sc_scroff,
sizeof(struct eata_inquiry_data), BUS_DMASYNC_POSTREAD);
-#endif /* __NetBSD__ */
-#ifdef __OpenBSD__
- bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap_ccb, BUS_DMASYNC_POSTREAD);
-#endif /* __OpenBSD__ */
dpt_free_ccb(sc, ccb);
}
diff --git a/sys/dev/ic/fxp.c b/sys/dev/ic/fxp.c
index 716b1a195d8..e107cb76b81 100644
--- a/sys/dev/ic/fxp.c
+++ b/sys/dev/ic/fxp.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: fxp.c,v 1.28 2001/09/20 17:02:31 mpech Exp $ */
+/* $OpenBSD: fxp.c,v 1.29 2001/11/05 17:25:58 art Exp $ */
/* $NetBSD: if_fxp.c,v 1.2 1997/06/05 02:01:55 thorpej Exp $ */
/*
@@ -812,7 +812,7 @@ rcvloop:
m = sc->rfa_headm;
rfap = m->m_ext.ext_buf + RFA_ALIGNMENT_FUDGE;
rxmap = *((bus_dmamap_t *)m->m_ext.ext_buf);
- fxp_bus_dmamap_sync(sc->sc_dmat, rxmap,
+ bus_dmamap_sync(sc->sc_dmat, rxmap,
0, MCLBYTES, BUS_DMASYNC_POSTREAD |
BUS_DMASYNC_POSTWRITE);
@@ -1223,8 +1223,9 @@ fxp_init(xsc)
sc->sc_cbt_cnt = 1;
sc->sc_ctrl->tx_cb[0].cb_command = FXP_CB_COMMAND_NOP |
FXP_CB_COMMAND_S | FXP_CB_COMMAND_I;
- fxp_bus_dmamap_sync(sc->sc_dmat, sc->tx_cb_map, 0,
- sc->tx_cb_map->dm_mapsize, BUS_DMASYNC_PREREAD|BUS_DMASYNC_PREWRITE);
+ bus_dmamap_sync(sc->sc_dmat, sc->tx_cb_map, 0,
+ sc->tx_cb_map->dm_mapsize,
+ BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE);
fxp_scb_wait(sc);
CSR_WRITE_4(sc, FXP_CSR_SCB_GENERAL, sc->tx_cb_map->dm_segs->ds_addr +
@@ -1383,7 +1384,7 @@ fxp_add_rfabuf(sc, oldm)
sc->rfa_tailm = m;
- fxp_bus_dmamap_sync(sc->sc_dmat, rxmap, 0, MCLBYTES,
+ bus_dmamap_sync(sc->sc_dmat, rxmap, 0, MCLBYTES,
BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE);
return (m == oldm);
diff --git a/sys/dev/ic/fxpvar.h b/sys/dev/ic/fxpvar.h
index 99c7f172676..5132ef41d5a 100644
--- a/sys/dev/ic/fxpvar.h
+++ b/sys/dev/ic/fxpvar.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: fxpvar.h,v 1.9 2001/09/17 16:24:49 jason Exp $ */
+/* $OpenBSD: fxpvar.h,v 1.10 2001/11/05 17:25:58 art Exp $ */
/* $NetBSD: if_fxpvar.h,v 1.1 1997/06/05 02:01:58 thorpej Exp $ */
/*
@@ -129,29 +129,21 @@ extern int fxp_detach __P((struct fxp_softc *));
#define FXP_RXMAP_GET(sc) ((sc)->sc_rxmaps[(sc)->sc_rxfree++])
#define FXP_RXMAP_PUT(sc,map) ((sc)->sc_rxmaps[--(sc)->sc_rxfree] = (map))
-#ifdef __HAS_NEW_BUS_DMAMAP_SYNC
-#define fxp_bus_dmamap_sync(t, m, o, l, p) \
- bus_dmamap_sync((t), (m), (o), (l), (p))
-#else
-#define fxp_bus_dmamap_sync(t, m, o, l, p) \
- bus_dmamap_sync((t), (m), (p))
-#endif
-
#define FXP_TXCB_SYNC(sc, txs, p) \
- fxp_bus_dmamap_sync((sc)->sc_dmat, (sc)->tx_cb_map, (txs)->tx_off, \
+ bus_dmamap_sync((sc)->sc_dmat, (sc)->tx_cb_map, (txs)->tx_off, \
sizeof(struct fxp_cb_tx), (p))
#define FXP_MCS_SYNC(sc, p) \
- fxp_bus_dmamap_sync((sc)->sc_dmat, (sc)->tx_cb_map, \
+ bus_dmamap_sync((sc)->sc_dmat, (sc)->tx_cb_map, \
offsetof(struct fxp_ctrl, u.mcs), sizeof(struct fxp_cb_mcs), (p))
#define FXP_IAS_SYNC(sc, p) \
- fxp_bus_dmamap_sync((sc)->sc_dmat, (sc)->tx_cb_map, \
+ bus_dmamap_sync((sc)->sc_dmat, (sc)->tx_cb_map, \
offsetof(struct fxp_ctrl, u.ias), sizeof(struct fxp_cb_ias), (p))
#define FXP_CFG_SYNC(sc, p) \
- fxp_bus_dmamap_sync((sc)->sc_dmat, (sc)->tx_cb_map, \
+ bus_dmamap_sync((sc)->sc_dmat, (sc)->tx_cb_map, \
offsetof(struct fxp_ctrl, u.cfg), sizeof(struct fxp_cb_config), (p))
#define FXP_MBUF_SYNC(sc, m, p) \
- fxp_bus_dmamap_sync((sc)->sc_dmat, (m), 0, (m)->dm_mapsize, (p))
+ bus_dmamap_sync((sc)->sc_dmat, (m), 0, (m)->dm_mapsize, (p))
diff --git a/sys/dev/ic/gdt_common.c b/sys/dev/ic/gdt_common.c
index 7a50216bb66..90e139dac90 100644
--- a/sys/dev/ic/gdt_common.c
+++ b/sys/dev/ic/gdt_common.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: gdt_common.c,v 1.14 2001/08/12 20:12:12 mickey Exp $ */
+/* $OpenBSD: gdt_common.c,v 1.15 2001/11/05 17:25:58 art Exp $ */
/*
* Copyright (c) 1999, 2000 Niklas Hallqvist. All rights reserved.
@@ -643,7 +643,8 @@ gdt_scsi_cmd(xs)
scsi_done(xs);
goto ready;
}
- bus_dmamap_sync(gdt->sc_dmat, xfer,
+ bus_dmamap_sync(gdt->sc_dmat, xfer, 0,
+ xfer->dm_mapsize,
(xs->flags & SCSI_DATA_IN) ?
BUS_DMASYNC_PREREAD :
BUS_DMASYNC_PREWRITE);
@@ -1062,7 +1063,8 @@ gdt_intr(arg)
prev_cmd = ccb->gc_flags & GDT_GCF_CMD_MASK;
if (xs && xs->cmd->opcode != PREVENT_ALLOW &&
xs->cmd->opcode != SYNCHRONIZE_CACHE) {
- bus_dmamap_sync(gdt->sc_dmat, ccb->gc_dmamap_xfer,
+ bus_dmamap_sync(gdt->sc_dmat, ccb->gc_dmamap_xfer, 0,
+ ccb->gc_dmamap_xfer->dm_mapsize,
(xs->flags & SCSI_DATA_IN) ? BUS_DMASYNC_POSTREAD :
BUS_DMASYNC_POSTWRITE);
bus_dmamap_unload(gdt->sc_dmat, ccb->gc_dmamap_xfer);
diff --git a/sys/dev/ic/iha.c b/sys/dev/ic/iha.c
index 41027cb49ed..76a108aa76e 100644
--- a/sys/dev/ic/iha.c
+++ b/sys/dev/ic/iha.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: iha.c,v 1.10 2001/10/14 02:56:34 krw Exp $ */
+/* $OpenBSD: iha.c,v 1.11 2001/11/05 17:25:58 art Exp $ */
/*
* Initio INI-9xxxU/UW SCSI Device Driver
*
@@ -308,7 +308,7 @@ iha_scsi_cmd(xs)
} else
pScb->SCB_BufPAddr = dm->dm_segs[0].ds_addr;
- iha_bus_dmamap_sync(sc->sc_dmat, pScb->SCB_Dmamap,
+ bus_dmamap_sync(sc->sc_dmat, pScb->SCB_Dmamap,
0, pScb->SCB_Dmamap->dm_mapsize,
(pScb->SCB_Flags & SCSI_DATA_IN) ?
BUS_DMASYNC_PREREAD : BUS_DMASYNC_PREWRITE);
@@ -2473,7 +2473,7 @@ iha_done_scb(sc, pScb)
}
if (xs->datalen > 0) {
- iha_bus_dmamap_sync(sc->sc_dmat, pScb->SCB_Dmamap,
+ bus_dmamap_sync(sc->sc_dmat, pScb->SCB_Dmamap,
0, pScb->SCB_Dmamap->dm_mapsize,
((xs->flags & SCSI_DATA_IN) ?
BUS_DMASYNC_POSTREAD : BUS_DMASYNC_POSTWRITE));
diff --git a/sys/dev/ic/iha.h b/sys/dev/ic/iha.h
index 1f1aa3e7592..abe3eb522ed 100644
--- a/sys/dev/ic/iha.h
+++ b/sys/dev/ic/iha.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: iha.h,v 1.7 2001/08/26 02:39:05 krw Exp $ */
+/* $OpenBSD: iha.h,v 1.8 2001/11/05 17:25:58 art Exp $ */
/*
* Initio INI-9xxxU/UW SCSI Device Driver
*
@@ -446,14 +446,4 @@ int iha_intr __P((void *));
void iha_minphys __P((struct buf *));
int iha_init_tulip __P((struct iha_softc *));
-#ifdef __HAS_NEW_BUS_DMAMAP_SYNC
-#define iha_bus_dmamap_sync(tag, map, off, len, op) \
- bus_dmamap_sync((tag), (map), (off), (len), (op))
-#else
-#define iha_bus_dmamap_sync(tag, map, off, len, op) \
- bus_dmamap_sync((tag), (map), (op))
-#endif
-
-
-
diff --git a/sys/dev/ic/siop.c b/sys/dev/ic/siop.c
index 5393b229d2a..e7c167075fb 100644
--- a/sys/dev/ic/siop.c
+++ b/sys/dev/ic/siop.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: siop.c,v 1.16 2001/10/30 00:02:55 krw Exp $ */
+/* $OpenBSD: siop.c,v 1.17 2001/11/05 17:25:58 art Exp $ */
/* $NetBSD: siop.c,v 1.39 2001/02/11 18:04:49 bouyer Exp $ */
/*
@@ -126,7 +126,7 @@ siop_script_sync(sc, ops)
int ops;
{
if ((sc->features & SF_CHIP_RAM) == 0)
- siop_bus_dmamap_sync(sc->sc_dmat, sc->sc_scriptdma,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_scriptdma,
0, PAGE_SIZE, ops);
}
@@ -1049,7 +1049,7 @@ siop_scsicmd_end(siop_cmd)
}
if (siop_cmd->status != CMDST_SENSE_DONE &&
xs->flags & (SCSI_DATA_IN | SCSI_DATA_OUT)) {
- siop_bus_dmamap_sync(sc->sc_dmat, siop_cmd->dmamap_data,
+ bus_dmamap_sync(sc->sc_dmat, siop_cmd->dmamap_data,
0, siop_cmd->dmamap_data->dm_mapsize,
(xs->flags & SCSI_DATA_IN) ?
BUS_DMASYNC_POSTREAD : BUS_DMASYNC_POSTWRITE);
@@ -1086,10 +1086,10 @@ siop_scsicmd_end(siop_cmd)
bus_dmamap_unload(sc->sc_dmat, siop_cmd->dmamap_cmd);
goto out;
}
- siop_bus_dmamap_sync(sc->sc_dmat, siop_cmd->dmamap_data,
+ bus_dmamap_sync(sc->sc_dmat, siop_cmd->dmamap_data,
0, siop_cmd->dmamap_data->dm_mapsize,
BUS_DMASYNC_PREREAD);
- siop_bus_dmamap_sync(sc->sc_dmat, siop_cmd->dmamap_cmd,
+ bus_dmamap_sync(sc->sc_dmat, siop_cmd->dmamap_cmd,
0, siop_cmd->dmamap_data->dm_mapsize,
BUS_DMASYNC_PREWRITE);
@@ -1098,7 +1098,7 @@ siop_scsicmd_end(siop_cmd)
TAILQ_INSERT_HEAD(&sc->urgent_list, siop_cmd, next);
return;
} else if (siop_cmd->status == CMDST_SENSE_DONE) {
- siop_bus_dmamap_sync(sc->sc_dmat, siop_cmd->dmamap_data,
+ bus_dmamap_sync(sc->sc_dmat, siop_cmd->dmamap_data,
0, siop_cmd->dmamap_data->dm_mapsize,
BUS_DMASYNC_POSTREAD);
bus_dmamap_unload(sc->sc_dmat, siop_cmd->dmamap_data);
@@ -1348,12 +1348,12 @@ siop_scsicmd(xs)
splx(s);
return(TRY_AGAIN_LATER);
}
- siop_bus_dmamap_sync(sc->sc_dmat, siop_cmd->dmamap_data,
+ bus_dmamap_sync(sc->sc_dmat, siop_cmd->dmamap_data,
0, siop_cmd->dmamap_data->dm_mapsize,
(xs->flags & SCSI_DATA_IN) ?
BUS_DMASYNC_PREREAD : BUS_DMASYNC_PREWRITE);
}
- siop_bus_dmamap_sync(sc->sc_dmat, siop_cmd->dmamap_cmd,
+ bus_dmamap_sync(sc->sc_dmat, siop_cmd->dmamap_cmd,
0, siop_cmd->dmamap_data->dm_mapsize,
BUS_DMASYNC_PREWRITE);
diff --git a/sys/dev/ic/siopvar_common.h b/sys/dev/ic/siopvar_common.h
index a3cb9f9d86a..8d899781ee6 100644
--- a/sys/dev/ic/siopvar_common.h
+++ b/sys/dev/ic/siopvar_common.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: siopvar_common.h,v 1.8 2001/10/30 00:02:55 krw Exp $ */
+/* $OpenBSD: siopvar_common.h,v 1.9 2001/11/05 17:25:58 art Exp $ */
/* $NetBSD: siopvar_common.h,v 1.10 2001/01/26 21:58:56 bouyer Exp $ */
/*
@@ -182,14 +182,6 @@ struct siop_lunsw {
u_int32_t lunsw_size; /* size of this lun sw */
};
-#ifdef __HAS_NEW_BUS_DMAMAP_SYNC
-#define siop_bus_dmamap_sync(tag, map, off, len, op) \
- bus_dmamap_sync((tag), (map), (off), (len), (op))
-#else
-#define siop_bus_dmamap_sync(tag, map, off, len, op) \
- bus_dmamap_sync((tag), (map), (op))
-#endif
-
static __inline__ void siop_table_sync __P((struct siop_cmd *, int));
static __inline__ void
siop_table_sync(siop_cmd, ops)
@@ -201,7 +193,7 @@ siop_table_sync(siop_cmd, ops)
offset = siop_cmd->dsa -
siop_cmd->siop_cbdp->xferdma->dm_segs[0].ds_addr;
- siop_bus_dmamap_sync(sc->sc_dmat, siop_cmd->siop_cbdp->xferdma, offset,
+ bus_dmamap_sync(sc->sc_dmat, siop_cmd->siop_cbdp->xferdma, offset,
sizeof(struct siop_xfer), ops);
}
diff --git a/sys/dev/ic/twe.c b/sys/dev/ic/twe.c
index 2c6e5800706..a9db2c78648 100644
--- a/sys/dev/ic/twe.c
+++ b/sys/dev/ic/twe.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: twe.c,v 1.13 2001/09/24 06:52:33 mickey Exp $ */
+/* $OpenBSD: twe.c,v 1.14 2001/11/05 17:25:58 art Exp $ */
/*
* Copyright (c) 2000, 2001 Michael Shalayeff. All rights reserved.
@@ -496,9 +496,11 @@ twe_cmd(ccb, flags, wait)
}
}
TWE_DPRINTF(TWE_D_DMA, ("> "));
- bus_dmamap_sync(sc->dmat, dmap, BUS_DMASYNC_PREWRITE);
+ bus_dmamap_sync(sc->dmat, dmap, 0, dmap->dm_mapsize,
+ BUS_DMASYNC_PREWRITE);
}
- bus_dmamap_sync(sc->dmat, sc->sc_cmdmap, BUS_DMASYNC_PREWRITE);
+ bus_dmamap_sync(sc->dmat, sc->sc_cmdmap, 0, sc->sc_cmdmap->dm_mapsize,
+ BUS_DMASYNC_PREWRITE);
if ((error = twe_start(ccb, wait))) {
bus_dmamap_unload(sc->dmat, dmap);
@@ -624,8 +626,8 @@ twe_done(sc, idx)
if (xs) {
if (xs->cmd->opcode != PREVENT_ALLOW &&
xs->cmd->opcode != SYNCHRONIZE_CACHE) {
- bus_dmamap_sync(sc->dmat, dmap,
- (xs->flags & SCSI_DATA_IN) ?
+ bus_dmamap_sync(sc->dmat, dmap, 0,
+ dmap->dm_mapsize, (xs->flags & SCSI_DATA_IN) ?
BUS_DMASYNC_POSTREAD : BUS_DMASYNC_POSTWRITE);
bus_dmamap_unload(sc->dmat, dmap);
}
@@ -633,12 +635,14 @@ twe_done(sc, idx)
switch (letoh16(cmd->cmd_op)) {
case TWE_CMD_GPARAM:
case TWE_CMD_READ:
- bus_dmamap_sync(sc->dmat, dmap, BUS_DMASYNC_POSTREAD);
+ bus_dmamap_sync(sc->dmat, dmap, 0,
+ dmap->dm_mapsize, BUS_DMASYNC_POSTREAD);
bus_dmamap_unload(sc->dmat, dmap);
break;
case TWE_CMD_SPARAM:
case TWE_CMD_WRITE:
- bus_dmamap_sync(sc->dmat, dmap, BUS_DMASYNC_POSTWRITE);
+ bus_dmamap_sync(sc->dmat, dmap, 0,
+ dmap->dm_mapsize, BUS_DMASYNC_POSTWRITE);
bus_dmamap_unload(sc->dmat, dmap);
break;
default:
diff --git a/sys/dev/isa/if_tr_isa.c b/sys/dev/isa/if_tr_isa.c
index bfd9bcfe485..48e1452366f 100644
--- a/sys/dev/isa/if_tr_isa.c
+++ b/sys/dev/isa/if_tr_isa.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_tr_isa.c,v 1.1 1999/12/27 21:51:35 fgsch Exp $ */
+/* $OpenBSD: if_tr_isa.c,v 1.2 2001/11/05 17:25:58 art Exp $ */
/* $NetBSD: if_tr_isa.c,v 1.4 1999/04/30 15:29:24 bad Exp $ */
#undef TRISADEBUG
@@ -42,6 +42,7 @@
#include <sys/systm.h>
#include <sys/socket.h>
#include <sys/device.h>
+#include <sys/timeout.h>
#include <net/if.h>
#include <net/if_media.h>
diff --git a/sys/dev/isa/if_tribm_isa.c b/sys/dev/isa/if_tribm_isa.c
index 69f92b688f9..c07d221a102 100644
--- a/sys/dev/isa/if_tribm_isa.c
+++ b/sys/dev/isa/if_tribm_isa.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_tribm_isa.c,v 1.1 1999/12/27 21:51:35 fgsch Exp $ */
+/* $OpenBSD: if_tribm_isa.c,v 1.2 2001/11/05 17:25:58 art Exp $ */
/* $NetBSD: if_tribm_isa.c,v 1.2 1999/03/22 23:01:37 bad Exp $ */
/*
@@ -41,6 +41,7 @@
#include <sys/systm.h>
#include <sys/socket.h>
#include <sys/device.h>
+#include <sys/timeout.h>
#include <net/if.h>
#include <net/if_media.h>
diff --git a/sys/dev/isa/if_trtcm_isa.c b/sys/dev/isa/if_trtcm_isa.c
index 3fb6063b675..cef9b1cfa85 100644
--- a/sys/dev/isa/if_trtcm_isa.c
+++ b/sys/dev/isa/if_trtcm_isa.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_trtcm_isa.c,v 1.1 1999/12/27 21:51:35 fgsch Exp $ */
+/* $OpenBSD: if_trtcm_isa.c,v 1.2 2001/11/05 17:25:58 art Exp $ */
/* $NetBSD: if_trtcm_isa.c,v 1.3 1999/04/30 15:29:24 bad Exp $ */
#undef TRTCMISADEBUG
@@ -43,6 +43,7 @@
#include <sys/socket.h>
#include <sys/device.h>
#include <sys/malloc.h>
+#include <sys/timeout.h>
#include <net/if.h>
#include <net/if_media.h>
diff --git a/sys/dev/isa/isadma.c b/sys/dev/isa/isadma.c
index 80efb570834..b108e4d52ae 100644
--- a/sys/dev/isa/isadma.c
+++ b/sys/dev/isa/isadma.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: isadma.c,v 1.23 2001/10/31 11:00:24 art Exp $ */
+/* $OpenBSD: isadma.c,v 1.24 2001/11/05 17:25:58 art Exp $ */
/* $NetBSD: isadma.c,v 1.32 1997/09/05 01:48:33 thorpej Exp $ */
/*-
@@ -352,10 +352,14 @@ isa_dmastart(isadev, chan, addr, nbytes, p, flags, busdmaflags)
#endif
if (flags & DMAMODE_READ) {
- bus_dmamap_sync(sc->sc_dmat, dmam, BUS_DMASYNC_PREREAD);
+ bus_dmamap_sync(sc->sc_dmat, dmam, 0,
+ dmam->dm_mapsize,
+ BUS_DMASYNC_PREREAD);
sc->sc_dmareads |= (1 << chan);
} else {
- bus_dmamap_sync(sc->sc_dmat, dmam, BUS_DMASYNC_PREWRITE);
+ bus_dmamap_sync(sc->sc_dmat, dmam, 0,
+ dmam->dm_mapsize,
+ BUS_DMASYNC_PREWRITE);
sc->sc_dmareads &= ~(1 << chan);
}
@@ -531,7 +535,8 @@ isa_dmadone(isadev, chan)
printf("%s: isa_dmadone: channel %d not finished\n",
sc->sc_dev.dv_xname, chan);
- bus_dmamap_sync(sc->sc_dmat, dmam,
+ bus_dmamap_sync(sc->sc_dmat, dmam, 0,
+ dmam->dm_mapsize,
(sc->sc_dmareads & (1 << chan)) ? BUS_DMASYNC_POSTREAD :
BUS_DMASYNC_POSTWRITE);
diff --git a/sys/dev/pci/cac_pci.c b/sys/dev/pci/cac_pci.c
index ca88b166a14..f31c79e2a71 100644
--- a/sys/dev/pci/cac_pci.c
+++ b/sys/dev/pci/cac_pci.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: cac_pci.c,v 1.6 2001/10/11 21:03:35 mickey Exp $ */
+/* $OpenBSD: cac_pci.c,v 1.7 2001/11/05 17:25:58 art Exp $ */
/* $NetBSD: cac_pci.c,v 1.10 2001/01/10 16:48:04 ad Exp $ */
/*-
@@ -246,7 +246,8 @@ void
cac_pci_l0_submit(struct cac_softc *sc, struct cac_ccb *ccb)
{
- bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap, 0,
+ sc->sc_dmamap->dm_mapsize,
BUS_DMASYNC_PREWRITE | BUS_DMASYNC_PREREAD);
cac_outl(sc, CAC_42REG_CMD_FIFO, ccb->ccb_paddr);
}
@@ -264,7 +265,8 @@ cac_pci_l0_completed(struct cac_softc *sc)
off = (off & ~3) - sc->sc_ccbs_paddr;
ccb = (struct cac_ccb *)(sc->sc_ccbs + off);
- bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap, 0,
+ sc->sc_dmamap->dm_mapsize,
BUS_DMASYNC_PREWRITE | BUS_DMASYNC_PREREAD);
return (ccb);
diff --git a/sys/dev/pci/hifn7751.c b/sys/dev/pci/hifn7751.c
index 7b34a367722..fb19508249f 100644
--- a/sys/dev/pci/hifn7751.c
+++ b/sys/dev/pci/hifn7751.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: hifn7751.c,v 1.104 2001/11/04 18:31:42 jason Exp $ */
+/* $OpenBSD: hifn7751.c,v 1.105 2001/11/05 17:25:58 art Exp $ */
/*
* Invertex AEON / Hifn 7751 driver
@@ -106,14 +106,6 @@ void hifn_abort __P((struct hifn_softc *));
struct hifn_stats hifnstats;
-#ifdef __HAS_NEW_BUS_DMAMAP_SYNC
-#define hifn_bus_dmamap_sync(t, m, o, l, f) \
- bus_dmamap_sync((t), (m), (o), (l), (f))
-#else
-#define hifn_bus_dmamap_sync(t, m, o, l, f) \
- bus_dmamap_sync((t), (m), (f))
-#endif
-
int
hifn_probe(parent, match, aux)
struct device *parent;
@@ -318,7 +310,7 @@ hifn_attach(parent, self, aux)
NULL, NULL, NULL);
}
- hifn_bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap, 0,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap, 0,
sc->sc_dmamap->dm_mapsize,
BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE);
@@ -874,13 +866,13 @@ hifn_writeramaddr(sc, addr, data, slot)
dma->dstr[slot].l = 4 | masks;
dma->resr[slot].l = 4 | masks;
- hifn_bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap,
0, sc->sc_dmamap->dm_mapsize,
BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE);
DELAY(3000); /* let write command execute */
- hifn_bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap,
0, sc->sc_dmamap->dm_mapsize,
BUS_DMASYNC_POSTREAD | BUS_DMASYNC_POSTWRITE);
@@ -934,13 +926,13 @@ hifn_readramaddr(sc, addr, data, slot)
dma->dstr[slot].l = 8 | masks;
dma->resr[slot].l = HIFN_MAX_RESULT | masks;
- hifn_bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap,
0, sc->sc_dmamap->dm_mapsize,
BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE);
DELAY(3000); /* let read command execute */
- hifn_bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap,
0, sc->sc_dmamap->dm_mapsize,
BUS_DMASYNC_POSTREAD | BUS_DMASYNC_POSTWRITE);
@@ -1350,13 +1342,13 @@ hifn_crypto(sc, cmd, crp)
#endif
if (cmd->src_map == cmd->dst_map)
- hifn_bus_dmamap_sync(sc->sc_dmat, cmd->src_map,
+ bus_dmamap_sync(sc->sc_dmat, cmd->src_map,
0, cmd->src_map->dm_mapsize,
BUS_DMASYNC_PREWRITE|BUS_DMASYNC_PREREAD);
else {
- hifn_bus_dmamap_sync(sc->sc_dmat, cmd->src_map,
+ bus_dmamap_sync(sc->sc_dmat, cmd->src_map,
0, cmd->src_map->dm_mapsize, BUS_DMASYNC_PREWRITE);
- hifn_bus_dmamap_sync(sc->sc_dmat, cmd->dst_map,
+ bus_dmamap_sync(sc->sc_dmat, cmd->dst_map,
0, cmd->dst_map->dm_mapsize, BUS_DMASYNC_PREREAD);
}
@@ -1994,14 +1986,14 @@ hifn_abort(sc)
hifn_callback(sc, cmd, macbuf);
} else {
if (cmd->src_map == cmd->dst_map)
- hifn_bus_dmamap_sync(sc->sc_dmat, cmd->src_map,
+ bus_dmamap_sync(sc->sc_dmat, cmd->src_map,
0, cmd->src_map->dm_mapsize,
BUS_DMASYNC_POSTREAD|BUS_DMASYNC_POSTWRITE);
else {
- hifn_bus_dmamap_sync(sc->sc_dmat, cmd->src_map,
+ bus_dmamap_sync(sc->sc_dmat, cmd->src_map,
0, cmd->src_map->dm_mapsize,
BUS_DMASYNC_POSTWRITE);
- hifn_bus_dmamap_sync(sc->sc_dmat, cmd->dst_map,
+ bus_dmamap_sync(sc->sc_dmat, cmd->dst_map,
0, cmd->dst_map->dm_mapsize,
BUS_DMASYNC_POSTREAD);
}
@@ -2060,13 +2052,13 @@ hifn_callback(sc, cmd, macbuf)
int totlen, i, u;
if (cmd->src_map == cmd->dst_map)
- hifn_bus_dmamap_sync(sc->sc_dmat, cmd->src_map,
+ bus_dmamap_sync(sc->sc_dmat, cmd->src_map,
0, cmd->src_map->dm_mapsize,
BUS_DMASYNC_POSTWRITE | BUS_DMASYNC_POSTREAD);
else {
- hifn_bus_dmamap_sync(sc->sc_dmat, cmd->src_map,
+ bus_dmamap_sync(sc->sc_dmat, cmd->src_map,
0, cmd->src_map->dm_mapsize, BUS_DMASYNC_POSTWRITE);
- hifn_bus_dmamap_sync(sc->sc_dmat, cmd->dst_map,
+ bus_dmamap_sync(sc->sc_dmat, cmd->dst_map,
0, cmd->dst_map->dm_mapsize, BUS_DMASYNC_POSTREAD);
}
@@ -2100,11 +2092,11 @@ hifn_callback(sc, cmd, macbuf)
i = dma->dstk; u = dma->dstu;
while (u != 0) {
- hifn_bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap,
offsetof(struct hifn_dma, dstr[i]), sizeof(struct hifn_desc),
BUS_DMASYNC_POSTREAD | BUS_DMASYNC_POSTWRITE);
if (dma->dstr[i].l & HIFN_D_VALID) {
- hifn_bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap,
offsetof(struct hifn_dma, dstr[i]),
sizeof(struct hifn_desc),
BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE);
diff --git a/sys/dev/pci/hifn7751var.h b/sys/dev/pci/hifn7751var.h
index 5daeae657f0..9445c3a4294 100644
--- a/sys/dev/pci/hifn7751var.h
+++ b/sys/dev/pci/hifn7751var.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: hifn7751var.h,v 1.38 2001/11/04 18:31:42 jason Exp $ */
+/* $OpenBSD: hifn7751var.h,v 1.39 2001/11/05 17:25:58 art Exp $ */
/*
* Invertex AEON / Hifn 7751 driver
@@ -104,7 +104,7 @@ struct hifn_session {
};
#define HIFN_RING_SYNC(sc, r, i, f) \
- hifn_bus_dmamap_sync((sc)->sc_dmat, (sc)->sc_dmamap, \
+ bus_dmamap_sync((sc)->sc_dmat, (sc)->sc_dmamap, \
offsetof(struct hifn_dma, r[i]), sizeof(struct hifn_desc), (f))
#define HIFN_CMDR_SYNC(sc, i, f) HIFN_RING_SYNC((sc), cmdr, (i), (f))
@@ -113,12 +113,12 @@ struct hifn_session {
#define HIFN_DSTR_SYNC(sc, i, f) HIFN_RING_SYNC((sc), dstr, (i), (f))
#define HIFN_CMD_SYNC(sc, i, f) \
- hifn_bus_dmamap_sync((sc)->sc_dmat, (sc)->sc_dmamap, \
+ bus_dmamap_sync((sc)->sc_dmat, (sc)->sc_dmamap, \
offsetof(struct hifn_dma, command_bufs[(i)][0]), \
HIFN_MAX_COMMAND, (f))
#define HIFN_RES_SYNC(sc, i, f) \
- hifn_bus_dmamap_sync((sc)->sc_dmat, (sc)->sc_dmamap, \
+ bus_dmamap_sync((sc)->sc_dmat, (sc)->sc_dmamap, \
offsetof(struct hifn_dma, result_bufs[(i)][0]), \
HIFN_MAX_RESULT, (f))
diff --git a/sys/dev/pci/if_txp.c b/sys/dev/pci/if_txp.c
index 2378defb05a..8a3381fd9c0 100644
--- a/sys/dev/pci/if_txp.c
+++ b/sys/dev/pci/if_txp.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_txp.c,v 1.57 2001/11/02 19:31:00 jason Exp $ */
+/* $OpenBSD: if_txp.c,v 1.58 2001/11/05 17:25:58 art Exp $ */
/*
* Copyright (c) 2001
@@ -512,7 +512,7 @@ txp_download_fw_section(sc, sect, sectnum)
goto bail;
}
- txp_bus_dmamap_sync(sc->sc_dmat, dma.dma_map, 0,
+ bus_dmamap_sync(sc->sc_dmat, dma.dma_map, 0,
dma.dma_map->dm_mapsize, BUS_DMASYNC_PREWRITE);
WRITE_REG(sc, TXP_H2A_1, sect->nbytes);
@@ -528,7 +528,7 @@ txp_download_fw_section(sc, sect, sectnum)
err = -1;
}
- txp_bus_dmamap_sync(sc->sc_dmat, dma.dma_map, 0,
+ bus_dmamap_sync(sc->sc_dmat, dma.dma_map, 0,
dma.dma_map->dm_mapsize, BUS_DMASYNC_POSTWRITE);
bail:
@@ -553,7 +553,7 @@ txp_intr(vsc)
TXP_INT_DMA3 | TXP_INT_DMA2 | TXP_INT_DMA1 | TXP_INT_DMA0 |
TXP_INT_PCI_TABORT | TXP_INT_PCI_MABORT | TXP_INT_LATCH);
- txp_bus_dmamap_sync(sc->sc_dmat, sc->sc_host_dma.dma_map, 0,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_host_dma.dma_map, 0,
sizeof(struct txp_hostvar), BUS_DMASYNC_POSTWRITE|BUS_DMASYNC_POSTREAD);
isr = READ_REG(sc, TXP_ISR);
@@ -580,7 +580,7 @@ txp_intr(vsc)
isr = READ_REG(sc, TXP_ISR);
}
- txp_bus_dmamap_sync(sc->sc_dmat, sc->sc_host_dma.dma_map, 0,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_host_dma.dma_map, 0,
sizeof(struct txp_hostvar), BUS_DMASYNC_POSTWRITE|BUS_DMASYNC_POSTREAD);
/* unmask all interrupts */
@@ -611,7 +611,7 @@ txp_rx_reclaim(sc, r, dma)
while (roff != woff) {
- txp_bus_dmamap_sync(sc->sc_dmat, dma->dma_map,
+ bus_dmamap_sync(sc->sc_dmat, dma->dma_map,
idx * sizeof(struct txp_rx_desc), sizeof(struct txp_rx_desc),
BUS_DMASYNC_POSTREAD);
@@ -625,7 +625,7 @@ txp_rx_reclaim(sc, r, dma)
/* retrieve stashed pointer */
bcopy((u_long *)&rxd->rx_vaddrlo, &sd, sizeof(sd));
- txp_bus_dmamap_sync(sc->sc_dmat, sd->sd_map, 0,
+ bus_dmamap_sync(sc->sc_dmat, sd->sd_map, 0,
sd->sd_map->dm_mapsize, BUS_DMASYNC_POSTREAD);
bus_dmamap_unload(sc->sc_dmat, sd->sd_map);
bus_dmamap_destroy(sc->sc_dmat, sd->sd_map);
@@ -701,7 +701,7 @@ txp_rx_reclaim(sc, r, dma)
ether_input_mbuf(ifp, m);
next:
- txp_bus_dmamap_sync(sc->sc_dmat, dma->dma_map,
+ bus_dmamap_sync(sc->sc_dmat, dma->dma_map,
idx * sizeof(struct txp_rx_desc), sizeof(struct txp_rx_desc),
BUS_DMASYNC_PREREAD);
@@ -762,7 +762,7 @@ txp_rxbuf_reclaim(sc)
goto err_mbuf;
}
- txp_bus_dmamap_sync(sc->sc_dmat, sc->sc_rxbufring_dma.dma_map,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_rxbufring_dma.dma_map,
i * sizeof(struct txp_rxbuf_desc),
sizeof(struct txp_rxbuf_desc), BUS_DMASYNC_POSTWRITE);
@@ -774,10 +774,10 @@ txp_rxbuf_reclaim(sc)
rbd->rb_paddrhi = ((u_int64_t)sd->sd_map->dm_segs[0].ds_addr)
>> 32;
- txp_bus_dmamap_sync(sc->sc_dmat, sd->sd_map, 0,
+ bus_dmamap_sync(sc->sc_dmat, sd->sd_map, 0,
sd->sd_map->dm_mapsize, BUS_DMASYNC_PREREAD);
- txp_bus_dmamap_sync(sc->sc_dmat, sc->sc_rxbufring_dma.dma_map,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_rxbufring_dma.dma_map,
i * sizeof(struct txp_rxbuf_desc),
sizeof(struct txp_rxbuf_desc), BUS_DMASYNC_PREWRITE);
@@ -817,14 +817,14 @@ txp_tx_reclaim(sc, r, dma)
if (cnt == 0)
break;
- txp_bus_dmamap_sync(sc->sc_dmat, dma->dma_map,
+ bus_dmamap_sync(sc->sc_dmat, dma->dma_map,
cons * sizeof(struct txp_tx_desc),
sizeof(struct txp_tx_desc),
BUS_DMASYNC_POSTWRITE);
if ((txd->tx_flags & TX_FLAGS_TYPE_M) ==
TX_FLAGS_TYPE_DATA) {
- txp_bus_dmamap_sync(sc->sc_dmat, sd->sd_map, 0,
+ bus_dmamap_sync(sc->sc_dmat, sd->sd_map, 0,
sd->sd_map->dm_mapsize, BUS_DMASYNC_POSTWRITE);
bus_dmamap_unload(sc->sc_dmat, sd->sd_map);
m = sd->sd_mbuf;
@@ -959,7 +959,7 @@ txp_alloc_rings(sc)
(struct txp_rx_desc *)sc->sc_rxhiring_dma.dma_vaddr;
sc->sc_rxhir.r_roff = &sc->sc_hostvar->hv_rx_hi_read_idx;
sc->sc_rxhir.r_woff = &sc->sc_hostvar->hv_rx_hi_write_idx;
- txp_bus_dmamap_sync(sc->sc_dmat, sc->sc_rxhiring_dma.dma_map,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_rxhiring_dma.dma_map,
0, sc->sc_rxhiring_dma.dma_map->dm_mapsize, BUS_DMASYNC_PREREAD);
/* low priority ring */
@@ -976,7 +976,7 @@ txp_alloc_rings(sc)
(struct txp_rx_desc *)sc->sc_rxloring_dma.dma_vaddr;
sc->sc_rxlor.r_roff = &sc->sc_hostvar->hv_rx_lo_read_idx;
sc->sc_rxlor.r_woff = &sc->sc_hostvar->hv_rx_lo_write_idx;
- txp_bus_dmamap_sync(sc->sc_dmat, sc->sc_rxloring_dma.dma_map,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_rxloring_dma.dma_map,
0, sc->sc_rxloring_dma.dma_map->dm_mapsize, BUS_DMASYNC_PREREAD);
/* command ring */
@@ -1044,7 +1044,7 @@ txp_alloc_rings(sc)
bus_dmamap_destroy(sc->sc_dmat, sd->sd_map);
goto bail_rxbufring;
}
- txp_bus_dmamap_sync(sc->sc_dmat, sd->sd_map, 0,
+ bus_dmamap_sync(sc->sc_dmat, sd->sd_map, 0,
sd->sd_map->dm_mapsize, BUS_DMASYNC_PREREAD);
/* stash away pointer */
@@ -1055,7 +1055,7 @@ txp_alloc_rings(sc)
sc->sc_rxbufs[i].rb_paddrhi =
((u_int64_t)sd->sd_map->dm_segs[0].ds_addr) >> 32;
}
- txp_bus_dmamap_sync(sc->sc_dmat, sc->sc_rxbufring_dma.dma_map,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_rxbufring_dma.dma_map,
0, sc->sc_rxbufring_dma.dma_map->dm_mapsize,
BUS_DMASYNC_PREWRITE);
sc->sc_hostvar->hv_rx_buf_write_idx = (RXBUF_ENTRIES - 1) *
@@ -1414,13 +1414,13 @@ txp_start(ifp)
txd->tx_pflags |= TX_PFLAGS_UDPCKSUM;
#endif
- txp_bus_dmamap_sync(sc->sc_dmat, sd->sd_map, 0,
+ bus_dmamap_sync(sc->sc_dmat, sd->sd_map, 0,
sd->sd_map->dm_mapsize, BUS_DMASYNC_PREWRITE);
fxd = (struct txp_frag_desc *)(r->r_desc + prod);
for (i = 0; i < sd->sd_map->dm_nsegs; i++) {
if (++cnt >= (TX_ENTRIES - 4)) {
- txp_bus_dmamap_sync(sc->sc_dmat, sd->sd_map,
+ bus_dmamap_sync(sc->sc_dmat, sd->sd_map,
0, sd->sd_map->dm_mapsize,
BUS_DMASYNC_POSTWRITE);
goto oactive;
@@ -1438,7 +1438,7 @@ txp_start(ifp)
32;
fxd->frag_rsvd2 = 0;
- txp_bus_dmamap_sync(sc->sc_dmat,
+ bus_dmamap_sync(sc->sc_dmat,
sc->sc_txhiring_dma.dma_map,
prod * sizeof(struct txp_frag_desc),
sizeof(struct txp_frag_desc), BUS_DMASYNC_PREWRITE);
@@ -1459,7 +1459,7 @@ txp_start(ifp)
#endif
txd->tx_flags |= TX_FLAGS_VALID;
- txp_bus_dmamap_sync(sc->sc_dmat, sc->sc_txhiring_dma.dma_map,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_txhiring_dma.dma_map,
txdidx * sizeof(struct txp_tx_desc),
sizeof(struct txp_tx_desc), BUS_DMASYNC_PREWRITE);
@@ -1575,14 +1575,14 @@ txp_command2(sc, id, in1, in2, in3, in_extp, in_extn, rspp, wait)
sc->sc_cmdring.lastwrite = idx;
WRITE_REG(sc, TXP_H2A_2, sc->sc_cmdring.lastwrite);
- txp_bus_dmamap_sync(sc->sc_dmat, sc->sc_host_dma.dma_map, 0,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_host_dma.dma_map, 0,
sizeof(struct txp_hostvar), BUS_DMASYNC_PREREAD);
if (!wait)
return (0);
for (i = 0; i < 10000; i++) {
- txp_bus_dmamap_sync(sc->sc_dmat, sc->sc_host_dma.dma_map, 0,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_host_dma.dma_map, 0,
sizeof(struct txp_hostvar), BUS_DMASYNC_POSTREAD);
idx = hv->hv_resp_read_idx;
if (idx != hv->hv_resp_write_idx) {
@@ -1592,7 +1592,7 @@ txp_command2(sc, id, in1, in2, in3, in_extp, in_extn, rspp, wait)
if (*rspp != NULL)
break;
}
- txp_bus_dmamap_sync(sc->sc_dmat, sc->sc_host_dma.dma_map, 0,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_host_dma.dma_map, 0,
sizeof(struct txp_hostvar), BUS_DMASYNC_PREREAD);
DELAY(50);
}
diff --git a/sys/dev/pci/if_txpreg.h b/sys/dev/pci/if_txpreg.h
index 9aae779d378..701b138af7e 100644
--- a/sys/dev/pci/if_txpreg.h
+++ b/sys/dev/pci/if_txpreg.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_txpreg.h,v 1.33 2001/11/02 19:31:00 jason Exp $ */
+/* $OpenBSD: if_txpreg.h,v 1.34 2001/11/05 17:25:58 art Exp $ */
/*
* Copyright (c) 2001 Aaron Campbell <aaron@monkey.org>.
@@ -621,10 +621,3 @@ struct txp_fw_section_header {
#define READ_REG(sc,reg) \
bus_space_read_4((sc)->sc_bt, (sc)->sc_bh, reg)
-#ifdef __HAS_NEW_BUS_DMAMAP_SYNC
-#define txp_bus_dmamap_sync(tag, map, off, len, op) \
- bus_dmamap_sync((tag), (map), (off), (len), (op))
-#else
-#define txp_bus_dmamap_sync(tag, map, off, len, op) \
- bus_dmamap_sync((tag), (map), (op))
-#endif
diff --git a/sys/dev/pci/ises.c b/sys/dev/pci/ises.c
index d64d54ecda9..6d3a2dc5b52 100644
--- a/sys/dev/pci/ises.c
+++ b/sys/dev/pci/ises.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ises.c,v 1.16 2001/09/21 19:41:13 ho Exp $ */
+/* $OpenBSD: ises.c,v 1.17 2001/11/05 17:25:58 art Exp $ */
/*
* Copyright (c) 2000, 2001 Håkan Olsson (ho@crt.se)
@@ -751,8 +751,8 @@ ises_intr(void *arg)
(dma_status & ISES_DMA_STATUS_R_RUN) == 0) {
DPRINTF(("%s: DMA read complete\n", dv));
- bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap,
- BUS_DMASYNC_POSTREAD);
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap, 0,
+ sc->sc_dmamap->dm_mapsize, BUS_DMASYNC_POSTREAD);
/* XXX Pick up and return the data.*/
@@ -762,8 +762,8 @@ ises_intr(void *arg)
(dma_status & ISES_DMA_STATUS_W_RUN) == 0) {
DPRINTF(("%s: DMA write complete\n", dv));
- bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap,
- BUS_DMASYNC_POSTWRITE);
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap, 0,
+ sc->sc_dmamap->dm_mapsize, BUS_DMASYNC_POSTWRITE);
WRITE_REG(sc, ISES_DMA_RESET, 0);
ises_feed(sc);
@@ -902,7 +902,8 @@ ises_feed(struct ises_softc *sc)
/* ... else */
/* Start writing data to the ises. */
- bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap, BUS_DMASYNC_PREWRITE);
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap, 0,
+ sc->sc_dmamap->dm_mapsize, BUS_DMASYNC_PREWRITE);
DPRINTF(("%s:ises_feed: writing DMA\n", dv));
DELAY(1000000);
@@ -1763,7 +1764,8 @@ ises_read_dma (struct ises_softc *sc)
bus_dma_segment_t *ds = &sc->sc_dmamap->dm_segs[0];
u_int32_t dma_status;
- bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap, BUS_DMASYNC_PREREAD);
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap, 0,
+ sc->sc_dmamap->dm_mapsize, BUS_DMASYNC_PREREAD);
WRITE_REG(sc, ISES_DMA_READ_START, ds->ds_addr);
WRITE_REG(sc, ISES_DMA_READ_START, ISES_DMA_RCOUNT(ds->ds_len));
diff --git a/sys/dev/pci/isp_pci.c b/sys/dev/pci/isp_pci.c
index a28dae32fb1..063c5033aec 100644
--- a/sys/dev/pci/isp_pci.c
+++ b/sys/dev/pci/isp_pci.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: isp_pci.c,v 1.25 2001/10/06 22:45:52 mjacob Exp $ */
+/* $OpenBSD: isp_pci.c,v 1.26 2001/11/05 17:25:58 art Exp $ */
/*
* PCI specific probe and attach routines for Qlogic ISP SCSI adapters.
*
@@ -290,14 +290,6 @@ static struct ispmdvec mdvec_2300 = {
#define BUS_DMA_COHERENT BUS_DMAMEM_NOSYNC
#endif
-#ifdef __HAS_NEW_BUS_DMAMAP_SYNC
-#define isp_bus_dmamap_sync(t, m, o, l, f) \
- bus_dmamap_sync((t), (m), (o), (l), (f))
-#else
-#define isp_bus_dmamap_sync(t, m, o, l, f) \
- bus_dmamap_sync((t), (m), (f))
-#endif
-
static int isp_pci_probe (struct device *, void *, void *);
static void isp_pci_attach (struct device *, struct device *, void *);
@@ -1067,13 +1059,13 @@ isp_pci_dmasetup(struct ispsoftc *isp, XS_T *xs, ispreq_t *rq, u_int16_t *iptrp,
} while (seg < segcnt);
dmasync:
- isp_bus_dmamap_sync(pci->pci_dmat, dmap, 0, dmap->dm_mapsize,
+ bus_dmamap_sync(pci->pci_dmat, dmap, 0, dmap->dm_mapsize,
(xs->flags & SCSI_DATA_IN) ?
BUS_DMASYNC_PREREAD : BUS_DMASYNC_PREWRITE);
mbxsync:
ISP_SWIZZLE_REQUEST(isp, rq);
- isp_bus_dmamap_sync(pci->pci_dmat, pci->pci_rquest_dmap, 0,
+ bus_dmamap_sync(pci->pci_dmat, pci->pci_rquest_dmap, 0,
pci->pci_rquest_dmap->dm_mapsize, BUS_DMASYNC_PREWRITE);
return (CMD_QUEUED);
}
@@ -1090,7 +1082,7 @@ isp_pci_intr(void *arg)
isp->isp_intbogus++;
return (0);
} else {
- isp_bus_dmamap_sync(p->pci_dmat, p->pci_result_dmap, 0,
+ bus_dmamap_sync(p->pci_dmat, p->pci_result_dmap, 0,
p->pci_result_dmap->dm_mapsize, BUS_DMASYNC_POSTREAD);
isp->isp_osinfo.onintstack = 1;
isp_intr(isp, isr, sema, mbox);
@@ -1104,7 +1096,7 @@ isp_pci_dmateardown(struct ispsoftc *isp, XS_T *xs, u_int16_t handle)
{
struct isp_pcisoftc *pci = (struct isp_pcisoftc *)isp;
bus_dmamap_t dmap = pci->pci_xfer_dmap[isp_handle_index(handle)];
- isp_bus_dmamap_sync(pci->pci_dmat, dmap, 0, dmap->dm_mapsize,
+ bus_dmamap_sync(pci->pci_dmat, dmap, 0, dmap->dm_mapsize,
xs->flags & SCSI_DATA_IN ?
BUS_DMASYNC_POSTREAD : BUS_DMASYNC_POSTWRITE);
bus_dmamap_unload(pci->pci_dmat, dmap);
diff --git a/sys/dev/pci/pciide.c b/sys/dev/pci/pciide.c
index 7c8e1a776d3..095dde889c8 100644
--- a/sys/dev/pci/pciide.c
+++ b/sys/dev/pci/pciide.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pciide.c,v 1.71 2001/09/29 04:46:49 jason Exp $ */
+/* $OpenBSD: pciide.c,v 1.72 2001/11/05 17:25:58 art Exp $ */
/* $NetBSD: pciide.c,v 1.127 2001/08/03 01:31:08 tsutsui Exp $ */
/*
@@ -1032,16 +1032,10 @@ pciide_dma_init(v, channel, drive, databuf, datalen, flags)
return error;
}
-#ifdef __HAVE_NEW_BUS_DMAMAP_SYNC
bus_dmamap_sync(sc->sc_dmat, dma_maps->dmamap_xfer, 0,
dma_maps->dmamap_xfer->dm_mapsize,
(flags & WDC_DMA_READ) ?
BUS_DMASYNC_PREREAD : BUS_DMASYNC_PREWRITE);
-#else
- bus_dmamap_sync(sc->sc_dmat, dma_maps->dmamap_xfer,
- (flags & WDC_DMA_READ) ?
- BUS_DMASYNC_PREREAD : BUS_DMASYNC_PREWRITE);
-#endif
for (seg = 0; seg < dma_maps->dmamap_xfer->dm_nsegs; seg++) {
#ifdef DIAGNOSTIC
@@ -1071,14 +1065,9 @@ pciide_dma_init(v, channel, drive, databuf, datalen, flags)
dma_maps->dma_table[dma_maps->dmamap_xfer->dm_nsegs -1].byte_count |=
htole32(IDEDMA_BYTE_COUNT_EOT);
-#ifdef __HAVE_NEW_BUS_DMAMAP_SYNC
bus_dmamap_sync(sc->sc_dmat, dma_maps->dmamap_table, 0,
dma_maps->dmamap_table->dm_mapsize,
BUS_DMASYNC_PREWRITE);
-#else
- bus_dmamap_sync(sc->sc_dmat, dma_maps->dmamap_table,
- BUS_DMASYNC_PREWRITE);
-#endif
/* Maps are ready. Start DMA function */
#ifdef DIAGNOSTIC
@@ -1148,16 +1137,10 @@ pciide_dma_finish(v, channel, drive)
0x00 : IDEDMA_CMD_WRITE);
/* Unload the map of the data buffer */
-#ifdef __HAVE_NEW_BUS_DMAMAP_SYNC
bus_dmamap_sync(sc->sc_dmat, dma_maps->dmamap_xfer, 0,
dma_maps->dmamap_xfer->dm_mapsize,
(dma_maps->dma_flags & WDC_DMA_READ) ?
BUS_DMASYNC_POSTREAD : BUS_DMASYNC_POSTWRITE);
-#else
- bus_dmamap_sync(sc->sc_dmat, dma_maps->dmamap_xfer,
- (dma_maps->dma_flags & WDC_DMA_READ) ?
- BUS_DMASYNC_POSTREAD : BUS_DMASYNC_POSTWRITE);
-#endif
bus_dmamap_unload(sc->sc_dmat, dma_maps->dmamap_xfer);
/* Clear status bits */
diff --git a/sys/dev/pci/pcscp.c b/sys/dev/pci/pcscp.c
index 1f1763d09e4..493fbfe09b7 100644
--- a/sys/dev/pci/pcscp.c
+++ b/sys/dev/pci/pcscp.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pcscp.c,v 1.7 2001/09/27 04:01:42 jason Exp $ */
+/* $OpenBSD: pcscp.c,v 1.8 2001/11/05 17:25:58 art Exp $ */
/* $NetBSD: pcscp.c,v 1.11 2000/11/14 18:42:58 thorpej Exp $ */
/*-
@@ -149,14 +149,6 @@ struct ncr53c9x_glue pcscp_glue = {
NULL, /* gl_clear_latched_intr */
};
-#ifdef __HAS_NEW_BUS_DMAMAP_SYNC
-#define pcscp_bus_dmamap_sync(t, m, o, l, f) \
- bus_dmamap_sync((t), (m), (o), (l), (f))
-#else
-#define pcscp_bus_dmamap_sync(t, m, o, l, f) \
- bus_dmamap_sync((t), (m), (f))
-#endif
-
int
pcscp_match(parent, match, aux)
struct device *parent;
@@ -494,7 +486,7 @@ pcscp_dma_intr(sc)
WRITE_DMAREG(esc, DMA_CMD, DMACMD_IDLE | (datain ? DMACMD_DIR : 0));
- pcscp_bus_dmamap_sync(esc->sc_dmat, dmap, 0, dmap->dm_mapsize,
+ bus_dmamap_sync(esc->sc_dmat, dmap, 0, dmap->dm_mapsize,
datain ? BUS_DMASYNC_POSTREAD : BUS_DMASYNC_POSTWRITE);
bus_dmamap_unload(esc->sc_dmat, dmap);
@@ -643,11 +635,11 @@ pcscp_dma_go(sc)
return;
/* sync transfer buffer */
- pcscp_bus_dmamap_sync(esc->sc_dmat, dmap, 0, dmap->dm_mapsize,
+ bus_dmamap_sync(esc->sc_dmat, dmap, 0, dmap->dm_mapsize,
datain ? BUS_DMASYNC_PREREAD : BUS_DMASYNC_PREWRITE);
/* sync MDL */
- pcscp_bus_dmamap_sync(esc->sc_dmat, mdldmap, 0, mdldmap->dm_mapsize,
+ bus_dmamap_sync(esc->sc_dmat, mdldmap, 0, mdldmap->dm_mapsize,
BUS_DMASYNC_PREWRITE);
/* set Starting MDL Address */
diff --git a/sys/dev/pci/ubsec.c b/sys/dev/pci/ubsec.c
index 137088f98ae..c2a0be5d7fc 100644
--- a/sys/dev/pci/ubsec.c
+++ b/sys/dev/pci/ubsec.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ubsec.c,v 1.70 2001/08/27 22:02:37 jason Exp $ */
+/* $OpenBSD: ubsec.c,v 1.71 2001/11/05 17:25:58 art Exp $ */
/*
* Copyright (c) 2000 Jason L. Wright (jason@thought.net)
@@ -100,14 +100,6 @@ void ubsec_dma_free __P((struct ubsec_softc *, struct ubsec_dma_alloc *));
#define SWAP32(x) (x) = swap32((x))
-#ifdef __HAS_NEW_BUS_DMAMAP_SYNC
-#define ubsec_bus_dmamap_sync(t, m, o, l, f) \
- bus_dmamap_sync((t), (m), (o), (l), (f))
-#else
-#define ubsec_bus_dmamap_sync(t, m, o, l, f) \
- bus_dmamap_sync((t), (m), (f))
-#endif
-
int
ubsec_probe(parent, match, aux)
struct device *parent;
@@ -303,13 +295,13 @@ ubsec_intr(arg)
while (!SIMPLEQ_EMPTY(&sc->sc_qchip2)) {
q2 = SIMPLEQ_FIRST(&sc->sc_qchip2);
- ubsec_bus_dmamap_sync(sc->sc_dmat, q2->q_mcr.dma_map,
+ bus_dmamap_sync(sc->sc_dmat, q2->q_mcr.dma_map,
0, q2->q_mcr.dma_map->dm_mapsize,
BUS_DMASYNC_POSTREAD|BUS_DMASYNC_POSTWRITE);
mcr = (struct ubsec_mcr *)q2->q_mcr.dma_vaddr;
if ((mcr->mcr_flags & UBS_MCR_DONE) == 0) {
- ubsec_bus_dmamap_sync(sc->sc_dmat,
+ bus_dmamap_sync(sc->sc_dmat,
q2->q_mcr.dma_map, 0,
q2->q_mcr.dma_map->dm_mapsize,
BUS_DMASYNC_PREREAD|BUS_DMASYNC_PREWRITE);
@@ -1046,7 +1038,7 @@ ubsec_process(crp)
bcopy(&ctx, dmap->d_alloc.dma_vaddr +
offsetof(struct ubsec_dmachunk, d_ctx),
sizeof(struct ubsec_pktctx));
- ubsec_bus_dmamap_sync(sc->sc_dmat, dmap->d_alloc.dma_map, 0,
+ bus_dmamap_sync(sc->sc_dmat, dmap->d_alloc.dma_map, 0,
dmap->d_alloc.dma_map->dm_mapsize,
BUS_DMASYNC_PREREAD|BUS_DMASYNC_PREWRITE);
@@ -1084,7 +1076,7 @@ ubsec_callback(sc, q)
struct cryptodesc *crd;
struct ubsec_dma *dmap = q->q_dma;
- ubsec_bus_dmamap_sync(sc->sc_dmat, dmap->d_alloc.dma_map, 0,
+ bus_dmamap_sync(sc->sc_dmat, dmap->d_alloc.dma_map, 0,
dmap->d_alloc.dma_map->dm_mapsize,
BUS_DMASYNC_POSTREAD|BUS_DMASYNC_POSTWRITE);
@@ -1189,10 +1181,10 @@ ubsec_feed2(sc)
break;
q = SIMPLEQ_FIRST(&sc->sc_queue2);
- ubsec_bus_dmamap_sync(sc->sc_dmat, q->q_mcr.dma_map, 0,
+ bus_dmamap_sync(sc->sc_dmat, q->q_mcr.dma_map, 0,
q->q_mcr.dma_map->dm_mapsize,
BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE);
- ubsec_bus_dmamap_sync(sc->sc_dmat, q->q_ctx.dma_map, 0,
+ bus_dmamap_sync(sc->sc_dmat, q->q_ctx.dma_map, 0,
q->q_ctx.dma_map->dm_mapsize,
BUS_DMASYNC_PREWRITE);
@@ -1212,7 +1204,7 @@ ubsec_callback2(sc, q)
struct ubsec_ctx_keyop *ctx;
ctx = (struct ubsec_ctx_keyop *)q->q_ctx.dma_vaddr;
- ubsec_bus_dmamap_sync(sc->sc_dmat, q->q_ctx.dma_map, 0,
+ bus_dmamap_sync(sc->sc_dmat, q->q_ctx.dma_map, 0,
q->q_ctx.dma_map->dm_mapsize, BUS_DMASYNC_POSTWRITE);
switch (ctx->ctx_op) {
@@ -1221,7 +1213,7 @@ ubsec_callback2(sc, q)
u_int32_t *p;
int i;
- ubsec_bus_dmamap_sync(sc->sc_dmat, rng->rng_buf.dma_map, 0,
+ bus_dmamap_sync(sc->sc_dmat, rng->rng_buf.dma_map, 0,
rng->rng_buf.dma_map->dm_mapsize, BUS_DMASYNC_POSTREAD);
p = (u_int32_t *)rng->rng_buf.dma_vaddr;
for (i = 0; i < UBSEC_RNG_BUFSIZ; p++, i++)
@@ -1290,7 +1282,7 @@ ubsec_rng(vsc)
ctx->rbp_len = sizeof(struct ubsec_ctx_rngbypass);
ctx->rbp_op = UBS_CTXOP_RNGBYPASS;
- ubsec_bus_dmamap_sync(sc->sc_dmat, rng->rng_buf.dma_map, 0,
+ bus_dmamap_sync(sc->sc_dmat, rng->rng_buf.dma_map, 0,
rng->rng_buf.dma_map->dm_mapsize, BUS_DMASYNC_PREREAD);
SIMPLEQ_INSERT_TAIL(&sc->sc_queue2, (struct ubsec_q2 *)rng, q_next);
diff --git a/sys/dev/pci/yds.c b/sys/dev/pci/yds.c
index 7b0663d125d..5c29a73f8f6 100644
--- a/sys/dev/pci/yds.c
+++ b/sys/dev/pci/yds.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: yds.c,v 1.7 2001/10/31 11:00:24 art Exp $ */
+/* $OpenBSD: yds.c,v 1.8 2001/11/05 17:25:58 art Exp $ */
/* $NetBSD: yds.c,v 1.5 2001/05/21 23:55:04 minoura Exp $ */
/*
@@ -42,6 +42,7 @@
#include <sys/param.h>
#include <sys/systm.h>
#include <sys/kernel.h>
+#include <sys/fcntl.h>
#include <sys/malloc.h>
#include <sys/device.h>
#include <sys/proc.h>
@@ -90,18 +91,11 @@ int yds_match __P((struct device *, void *, void *));
void yds_attach __P((struct device *, struct device *, void *));
int yds_intr __P((void *));
-#ifdef __HAS_NEW_BUS_DMAMAP_SYNC
-#define yds_bus_dmamap_sync(t, m, o, l, f) \
- bus_dmamap_sync((t), (m), (o), (l), (f))
-#else
-#define yds_bus_dmamap_sync(t, m, o, l, f) \
- bus_dmamap_sync((t), (m), (f))
-#endif
-
#define DMAADDR(p) ((p)->map->dm_segs[0].ds_addr)
#define KERNADDR(p) ((void *)((p)->addr))
-int yds_allocmem __P((struct yds_softc *, size_t, size_t, struct yds_dma *));
+int yds_allocmem __P((struct yds_softc *, size_t, size_t,
+ struct yds_dma *));
int yds_freemem __P((struct yds_softc *, struct yds_dma *));
#ifndef AUDIO_DEBUG
@@ -149,18 +143,19 @@ void YWRITE4(struct yds_softc *sc,bus_size_t r,u_int32_t x)
#define YWRITEREGION4(sc, r, x, c) \
bus_space_write_region_4((sc)->memt, (sc)->memh, (r), (x), (c) / 4)
-struct cfdriver yds_cd = {
- NULL, "yds", DV_DULL
-};
-
struct cfattach yds_ca = {
sizeof(struct yds_softc), yds_match, yds_attach
};
+struct cfdriver yds_cd = {
+ NULL, "yds", DV_DULL
+};
+
int yds_open __P((void *, int));
void yds_close __P((void *));
int yds_query_encoding __P((void *, struct audio_encoding *));
-int yds_set_params __P((void *, int, int, struct audio_params *, struct audio_params *));
+int yds_set_params __P((void *, int, int,
+ struct audio_params *, struct audio_params *));
int yds_round_blocksize __P((void *, int));
int yds_trigger_output __P((void *, void *, void *, int, void (*)(void *),
void *, struct audio_params *));
@@ -183,7 +178,7 @@ int yds_read_codec __P((void *sc, u_int8_t a, u_int16_t *d));
int yds_write_codec __P((void *sc, u_int8_t a, u_int16_t d));
void yds_reset_codec __P((void *sc));
int yds_get_portnum_by_name __P((struct yds_softc *, char *, char *,
- char *));
+ char *));
static u_int yds_get_dstype __P((int));
static int yds_download_mcode __P((struct yds_softc *));
@@ -231,7 +226,7 @@ static struct audio_hw_if yds_hw_if = {
yds_mappage,
yds_get_props,
yds_trigger_output,
- yds_trigger_input,
+ yds_trigger_input
};
struct audio_device yds_device = {
@@ -485,9 +480,9 @@ yds_allocate_slots(sc)
cb += pcs;
}
/* Sync play control data table */
- yds_bus_dmamap_sync(sc->sc_dmatag, p->map, sc->ptbloff,
- (N_PLAY_SLOT_CTRL+1) * sizeof(u_int32_t),
- BUS_DMASYNC_PREWRITE);
+ bus_dmamap_sync(sc->sc_dmatag, p->map,
+ sc->ptbloff, (N_PLAY_SLOT_CTRL+1) * sizeof(u_int32_t),
+ BUS_DMASYNC_PREWRITE);
return 0;
}
@@ -661,10 +656,16 @@ yds_attach(parent, self, aux)
pci_intr_handle_t ih;
pcireg_t reg;
struct yds_codec_softc *codec;
+ char devinfo[256];
mixer_ctrl_t ctl;
int i, r, to;
+ int revision;
int ac97_id2;
+ pci_devinfo(pa->pa_id, pa->pa_class, 0, devinfo);
+ revision = PCI_REVISION(pa->pa_class);
+ printf(": %s (rev. 0x%02x)\n", devinfo, revision);
+
/* Map register to memory */
if (pci_mapreg_map(pa, YDS_PCI_MBA, PCI_MAPREG_TYPE_MEM, 0,
&sc->memt, &sc->memh, NULL, NULL, 0)) {
@@ -1004,11 +1005,13 @@ yds_intr(p)
u_int dma, cpu, blk, len;
/* Sync play slot control data */
- yds_bus_dmamap_sync(sc->sc_dmatag, sc->sc_ctrldata.map,
- sc->pbankoff,
- sizeof(struct play_slot_ctrl_bank) * (*sc->ptbl)*
- N_PLAY_SLOT_CTRL_BANK,
- BUS_DMASYNC_POSTWRITE|BUS_DMASYNC_POSTREAD);
+ bus_dmamap_sync(sc->sc_dmatag, sc->sc_ctrldata.map,
+ sc->pbankoff,
+ sizeof(struct play_slot_ctrl_bank)*
+ (*sc->ptbl)*
+ N_PLAY_SLOT_CTRL_BANK,
+ BUS_DMASYNC_POSTWRITE|
+ BUS_DMASYNC_POSTREAD);
dma = sc->pbankp[nbank]->pgstart * sc->sc_play.factor;
cpu = sc->sc_play.offset;
blk = sc->sc_play.blksize;
@@ -1017,11 +1020,11 @@ yds_intr(p)
if (((dma > cpu) && (dma - cpu > blk * 2)) ||
((cpu > dma) && (dma + len - cpu > blk * 2))) {
/* We can fill the next block */
- /* Sync ring buffer first for previous write */
- yds_bus_dmamap_sync(sc->sc_dmatag,
- sc->sc_play.dma->map,
- cpu, blk,
- BUS_DMASYNC_POSTWRITE);
+ /* Sync ring buffer for previous write */
+ bus_dmamap_sync(sc->sc_dmatag,
+ sc->sc_play.dma->map,
+ cpu, blk,
+ BUS_DMASYNC_POSTWRITE);
sc->sc_play.intr(sc->sc_play.intr_arg);
sc->sc_play.offset += blk;
if (sc->sc_play.offset >= len) {
@@ -1032,19 +1035,23 @@ yds_intr(p)
#endif
}
/* Sync ring buffer for next write */
- yds_bus_dmamap_sync(sc->sc_dmatag,
- sc->sc_play.dma->map, cpu, blk,
- BUS_DMASYNC_PREWRITE);
+ bus_dmamap_sync(sc->sc_dmatag,
+ sc->sc_play.dma->map,
+ cpu, blk,
+ BUS_DMASYNC_PREWRITE);
}
}
if (sc->sc_rec.intr) {
u_int dma, cpu, blk, len;
/* Sync rec slot control data */
- yds_bus_dmamap_sync(sc->sc_dmatag, sc->sc_ctrldata.map,
- sc->rbankoff, sizeof(struct rec_slot_ctrl_bank)*
- N_REC_SLOT_CTRL * N_REC_SLOT_CTRL_BANK,
- BUS_DMASYNC_POSTWRITE|BUS_DMASYNC_POSTREAD);
+ bus_dmamap_sync(sc->sc_dmatag, sc->sc_ctrldata.map,
+ sc->rbankoff,
+ sizeof(struct rec_slot_ctrl_bank)*
+ N_REC_SLOT_CTRL*
+ N_REC_SLOT_CTRL_BANK,
+ BUS_DMASYNC_POSTWRITE|
+ BUS_DMASYNC_POSTREAD);
dma = sc->rbank[YDS_INPUT_SLOT*2 + nbank].pgstartadr;
cpu = sc->sc_rec.offset;
blk = sc->sc_rec.blksize;
@@ -1054,9 +1061,10 @@ yds_intr(p)
((cpu > dma) && (dma + len - cpu > blk * 2))) {
/* We can drain the current block */
/* Sync ring buffer first */
- yds_bus_dmamap_sync(sc->sc_dmatag,
- sc->sc_rec.dma->map, cpu, blk,
- BUS_DMASYNC_POSTREAD);
+ bus_dmamap_sync(sc->sc_dmatag,
+ sc->sc_rec.dma->map,
+ cpu, blk,
+ BUS_DMASYNC_POSTREAD);
sc->sc_rec.intr(sc->sc_rec.intr_arg);
sc->sc_rec.offset += blk;
if (sc->sc_rec.offset >= len) {
@@ -1067,9 +1075,10 @@ yds_intr(p)
#endif
}
/* Sync ring buffer for next read */
- yds_bus_dmamap_sync(sc->sc_dmatag,
- sc->sc_rec.dma->map, cpu, blk,
- BUS_DMASYNC_PREREAD);
+ bus_dmamap_sync(sc->sc_dmatag,
+ sc->sc_rec.dma->map,
+ cpu, blk,
+ BUS_DMASYNC_PREREAD);
}
}
}
@@ -1489,12 +1498,14 @@ yds_trigger_output(addr, start, end, blksize, intr, arg, param)
/* Now the play slot for the next frame is set up!! */
/* Sync play slot control data for both directions */
- yds_bus_dmamap_sync(sc->sc_dmatag, sc->sc_ctrldata.map,
- sc->ptbloff, sizeof(struct play_slot_ctrl_bank) * channels *
- N_PLAY_SLOT_CTRL_BANK, BUS_DMASYNC_PREWRITE|BUS_DMASYNC_PREREAD);
+ bus_dmamap_sync(sc->sc_dmatag, sc->sc_ctrldata.map,
+ sc->ptbloff,
+ sizeof(struct play_slot_ctrl_bank) *
+ channels * N_PLAY_SLOT_CTRL_BANK,
+ BUS_DMASYNC_PREWRITE|BUS_DMASYNC_PREREAD);
/* Sync ring buffer */
- yds_bus_dmamap_sync(sc->sc_dmatag, p->map, 0, blksize,
- BUS_DMASYNC_PREWRITE);
+ bus_dmamap_sync(sc->sc_dmatag, p->map, 0, blksize,
+ BUS_DMASYNC_PREWRITE);
/* HERE WE GO!! */
YWRITE4(sc, YDS_MODE,
YREAD4(sc, YDS_MODE) | YDS_MODE_ACTV | YDS_MODE_ACTV2);
@@ -1589,11 +1600,15 @@ yds_trigger_input(addr, start, end, blksize, intr, arg, param)
#endif
/* Now the rec slot for the next frame is set up!! */
/* Sync record slot control data */
- yds_bus_dmamap_sync(sc->sc_dmatag, sc->sc_ctrldata.map, sc->rbankoff,
- sizeof(struct rec_slot_ctrl_bank) * N_REC_SLOT_CTRL *
- N_REC_SLOT_CTRL_BANK, BUS_DMASYNC_PREWRITE|BUS_DMASYNC_PREREAD);
+ bus_dmamap_sync(sc->sc_dmatag, sc->sc_ctrldata.map,
+ sc->rbankoff,
+ sizeof(struct rec_slot_ctrl_bank)*
+ N_REC_SLOT_CTRL*
+ N_REC_SLOT_CTRL_BANK,
+ BUS_DMASYNC_PREWRITE|BUS_DMASYNC_PREREAD);
/* Sync ring buffer */
- yds_bus_dmamap_sync(sc->sc_dmatag, p->map, 0, blksize, BUS_DMASYNC_PREREAD);
+ bus_dmamap_sync(sc->sc_dmatag, p->map, 0, blksize,
+ BUS_DMASYNC_PREREAD);
/* HERE WE GO!! */
YWRITE4(sc, YDS_MODE,
YREAD4(sc, YDS_MODE) | YDS_MODE_ACTV | YDS_MODE_ACTV2);
@@ -1632,18 +1647,19 @@ yds_halt_output(addr)
if (sc->sc_play.intr) {
sc->sc_play.intr = 0;
/* Sync play slot control data */
- yds_bus_dmamap_sync(sc->sc_dmatag, sc->sc_ctrldata.map,
- sc->pbankoff, sizeof(struct play_slot_ctrl_bank) *
- (*sc->ptbl)*N_PLAY_SLOT_CTRL_BANK,
- BUS_DMASYNC_POSTWRITE|BUS_DMASYNC_POSTREAD);
+ bus_dmamap_sync(sc->sc_dmatag, sc->sc_ctrldata.map,
+ sc->pbankoff,
+ sizeof(struct play_slot_ctrl_bank)*
+ (*sc->ptbl)*N_PLAY_SLOT_CTRL_BANK,
+ BUS_DMASYNC_POSTWRITE|BUS_DMASYNC_POSTREAD);
/* Stop the play slot operation */
sc->pbankp[0]->status =
sc->pbankp[1]->status =
sc->pbankp[2]->status =
sc->pbankp[3]->status = 1;
/* Sync ring buffer */
- yds_bus_dmamap_sync(sc->sc_dmatag, sc->sc_play.dma->map, 0,
- sc->sc_play.length, BUS_DMASYNC_POSTWRITE);
+ bus_dmamap_sync(sc->sc_dmatag, sc->sc_play.dma->map,
+ 0, sc->sc_play.length, BUS_DMASYNC_POSTWRITE);
}
return 0;
@@ -1662,13 +1678,14 @@ yds_halt_input(addr)
YWRITE4(sc, YDS_MAPOF_REC, 0);
sc->sc_rec.intr = 0;
/* Sync rec slot control data */
- yds_bus_dmamap_sync(sc->sc_dmatag, sc->sc_ctrldata.map,
- sc->rbankoff, sizeof(struct rec_slot_ctrl_bank)*
- N_REC_SLOT_CTRL*N_REC_SLOT_CTRL_BANK,
- BUS_DMASYNC_POSTWRITE|BUS_DMASYNC_POSTREAD);
+ bus_dmamap_sync(sc->sc_dmatag, sc->sc_ctrldata.map,
+ sc->rbankoff,
+ sizeof(struct rec_slot_ctrl_bank)*
+ N_REC_SLOT_CTRL*N_REC_SLOT_CTRL_BANK,
+ BUS_DMASYNC_POSTWRITE|BUS_DMASYNC_POSTREAD);
/* Sync ring buffer */
- yds_bus_dmamap_sync(sc->sc_dmatag, sc->sc_rec.dma->map, 0,
- sc->sc_rec.length, BUS_DMASYNC_POSTREAD);
+ bus_dmamap_sync(sc->sc_dmatag, sc->sc_rec.dma->map,
+ 0, sc->sc_rec.length, BUS_DMASYNC_POSTREAD);
}
return 0;