summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
Diffstat (limited to 'sys')
-rw-r--r--sys/arch/arm/xscale/pxa2x0_i2s.c30
-rw-r--r--sys/arch/arm/xscale/pxa2x0_i2s.h4
2 files changed, 32 insertions, 2 deletions
diff --git a/sys/arch/arm/xscale/pxa2x0_i2s.c b/sys/arch/arm/xscale/pxa2x0_i2s.c
index e00d58deae7..e4baef152fb 100644
--- a/sys/arch/arm/xscale/pxa2x0_i2s.c
+++ b/sys/arch/arm/xscale/pxa2x0_i2s.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pxa2x0_i2s.c,v 1.6 2006/04/04 09:16:15 pascoe Exp $ */
+/* $OpenBSD: pxa2x0_i2s.c,v 1.7 2006/04/04 11:45:40 pascoe Exp $ */
/*
* Copyright (c) 2005 Christopher Pascoe <pascoe@openbsd.org>
@@ -316,3 +316,31 @@ pxa2x0_i2s_start_output(struct pxa2x0_i2s_softc *sc, void *block, int bsize,
return 0;
}
+
+int
+pxa2x0_i2s_start_input(struct pxa2x0_i2s_softc *sc, void *block, int bsize,
+ void (*intr)(void *), void *intrarg)
+{
+ struct pxa2x0_i2s_dma *p;
+ int offset;
+
+ /* Find mapping which contains block completely */
+ for (p = sc->sc_dmas; p && (((caddr_t)block < p->addr) ||
+ ((caddr_t)block + bsize > p->addr + p->size)); p = p->next)
+ ; /* Nothing */
+
+ if (!p) {
+ printf("pxa2x0_i2s_start_input: request with bad start "
+ "address: %p, size: %d)\n", block, bsize);
+ return ENXIO;
+ }
+
+ /* Offset into block to use in mapped block */
+ offset = (caddr_t)block - p->addr;
+
+ /* Start DMA */
+ pxa2x0_dma_from_fifo(2, 2, 0x40400080, 4, 32,
+ p->map->dm_segs[0].ds_addr + offset, bsize, intr, intrarg);
+
+ return 0;
+}
diff --git a/sys/arch/arm/xscale/pxa2x0_i2s.h b/sys/arch/arm/xscale/pxa2x0_i2s.h
index b5c0380bdb3..09aed24746d 100644
--- a/sys/arch/arm/xscale/pxa2x0_i2s.h
+++ b/sys/arch/arm/xscale/pxa2x0_i2s.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: pxa2x0_i2s.h,v 1.2 2005/05/26 03:52:07 pascoe Exp $ */
+/* $OpenBSD: pxa2x0_i2s.h,v 1.3 2006/04/04 11:45:40 pascoe Exp $ */
/*
* Copyright (c) 2005 Uwe Stuehler <uwe@bsdx.de>
@@ -52,5 +52,7 @@ size_t pxa2x0_i2s_round_buffersize(void *, int, size_t);
int pxa2x0_i2s_start_output(struct pxa2x0_i2s_softc *, void *, int,
void (*)(void *), void *);
+int pxa2x0_i2s_start_input(struct pxa2x0_i2s_softc *, void *, int,
+ void (*)(void *), void *);
#endif