Commit f609c29d authored by H Hartley Sweeten's avatar H Hartley Sweeten Committed by Greg Kroah-Hartman

staging: comedi: dt282x: introduce dt282x_isadma_program()

Introduce a helper function to program the ISA DMA controller. Program
the ISA DMA as described in Documentation/DMA-ISA-LPC.txt.
Signed-off-by: default avatarH Hartley Sweeten <hsweeten@visionengravers.com>
Reviewed-by: default avatarIan Abbott <abbotti@mev.co.uk>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 65fdfedb
...@@ -305,6 +305,7 @@ struct dt282x_dma_desc { ...@@ -305,6 +305,7 @@ struct dt282x_dma_desc {
void *virt_addr; /* virtual address of DMA buffer */ void *virt_addr; /* virtual address of DMA buffer */
dma_addr_t hw_addr; /* hardware (bus) address of DMA buffer */ dma_addr_t hw_addr; /* hardware (bus) address of DMA buffer */
unsigned int size; /* transfer size (in bytes) */ unsigned int size; /* transfer size (in bytes) */
char mode; /* DMA_MODE_* */
}; };
struct dt282x_private { struct dt282x_private {
...@@ -325,11 +326,23 @@ struct dt282x_private { ...@@ -325,11 +326,23 @@ struct dt282x_private {
int dma_dir; int dma_dir;
}; };
static void dt282x_isadma_program(struct dt282x_dma_desc *dma)
{
unsigned long flags;
flags = claim_dma_lock();
clear_dma_ff(dma->chan);
set_dma_mode(dma->chan, dma->mode);
set_dma_addr(dma->chan, dma->hw_addr);
set_dma_count(dma->chan, dma->size);
enable_dma(dma->chan);
release_dma_lock(flags);
}
static int dt282x_prep_ai_dma(struct comedi_device *dev, int dma_index, int n) static int dt282x_prep_ai_dma(struct comedi_device *dev, int dma_index, int n)
{ {
struct dt282x_private *devpriv = dev->private; struct dt282x_private *devpriv = dev->private;
struct dt282x_dma_desc *dma = &devpriv->dma_desc[dma_index]; struct dt282x_dma_desc *dma = &devpriv->dma_desc[dma_index];
unsigned long flags;
if (!devpriv->ntrig) if (!devpriv->ntrig)
return 0; return 0;
...@@ -341,15 +354,9 @@ static int dt282x_prep_ai_dma(struct comedi_device *dev, int dma_index, int n) ...@@ -341,15 +354,9 @@ static int dt282x_prep_ai_dma(struct comedi_device *dev, int dma_index, int n)
devpriv->ntrig -= n / 2; devpriv->ntrig -= n / 2;
dma->size = n; dma->size = n;
dma->mode = DMA_MODE_READ;
set_dma_mode(dma->chan, DMA_MODE_READ); dt282x_isadma_program(dma);
flags = claim_dma_lock();
clear_dma_ff(dma->chan);
set_dma_addr(dma->chan, dma->hw_addr);
set_dma_count(dma->chan, dma->size);
release_dma_lock(flags);
enable_dma(dma->chan);
return n; return n;
} }
...@@ -358,18 +365,11 @@ static int dt282x_prep_ao_dma(struct comedi_device *dev, int dma_index, int n) ...@@ -358,18 +365,11 @@ static int dt282x_prep_ao_dma(struct comedi_device *dev, int dma_index, int n)
{ {
struct dt282x_private *devpriv = dev->private; struct dt282x_private *devpriv = dev->private;
struct dt282x_dma_desc *dma = &devpriv->dma_desc[dma_index]; struct dt282x_dma_desc *dma = &devpriv->dma_desc[dma_index];
unsigned long flags;
dma->size = n; dma->size = n;
dma->mode = DMA_MODE_WRITE;
set_dma_mode(dma->chan, DMA_MODE_WRITE); dt282x_isadma_program(dma);
flags = claim_dma_lock();
clear_dma_ff(dma->chan);
set_dma_addr(dma->chan, dma->hw_addr);
set_dma_count(dma->chan, dma->size);
release_dma_lock(flags);
enable_dma(dma->chan);
return n; return n;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment