xref: /openbmc/linux/arch/arm/include/asm/mach/dma.h (revision 8569c914)
1 /*
2  *  arch/arm/include/asm/mach/dma.h
3  *
4  *  Copyright (C) 1998-2000 Russell King
5  *
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License version 2 as
8  * published by the Free Software Foundation.
9  *
10  *  This header file describes the interface between the generic DMA handler
11  *  (dma.c) and the architecture-specific DMA backends (dma-*.c)
12  */
13 
14 struct dma_struct;
15 typedef struct dma_struct dma_t;
16 
17 struct dma_ops {
18 	int	(*request)(dmach_t, dma_t *);		/* optional */
19 	void	(*free)(dmach_t, dma_t *);		/* optional */
20 	void	(*enable)(dmach_t, dma_t *);		/* mandatory */
21 	void 	(*disable)(dmach_t, dma_t *);		/* mandatory */
22 	int	(*residue)(dmach_t, dma_t *);		/* optional */
23 	int	(*setspeed)(dmach_t, dma_t *, int);	/* optional */
24 	char	*type;
25 };
26 
27 struct dma_struct {
28 	void		*addr;		/* single DMA address		*/
29 	unsigned long	count;		/* single DMA size		*/
30 	struct scatterlist buf;		/* single DMA			*/
31 	int		sgcount;	/* number of DMA SG		*/
32 	struct scatterlist *sg;		/* DMA Scatter-Gather List	*/
33 
34 	unsigned int	active:1;	/* Transfer active		*/
35 	unsigned int	invalid:1;	/* Address/Count changed	*/
36 
37 	dmamode_t	dma_mode;	/* DMA mode			*/
38 	int		speed;		/* DMA speed			*/
39 
40 	unsigned int	lock;		/* Device is allocated		*/
41 	const char	*device_id;	/* Device name			*/
42 
43 	unsigned int	dma_base;	/* Controller base address	*/
44 	int		dma_irq;	/* Controller IRQ		*/
45 	struct scatterlist cur_sg;	/* Current controller buffer	*/
46 	unsigned int	state;
47 
48 	struct dma_ops	*d_ops;
49 };
50 
51 /* Prototype: void arch_dma_init(dma)
52  * Purpose  : Initialise architecture specific DMA
53  * Params   : dma - pointer to array of DMA structures
54  */
55 extern void arch_dma_init(dma_t *dma);
56 
57 extern void isa_init_dma(dma_t *dma);
58