2008-08-30 14:10:21 +08:00
|
|
|
#ifndef __ASM_SPARC_EBUS_DMA_H
|
|
|
|
#define __ASM_SPARC_EBUS_DMA_H
|
|
|
|
|
|
|
|
struct ebus_dma_info {
|
|
|
|
spinlock_t lock;
|
|
|
|
void __iomem *regs;
|
|
|
|
|
|
|
|
unsigned int flags;
|
|
|
|
#define EBUS_DMA_FLAG_USE_EBDMA_HANDLER 0x00000001
|
|
|
|
#define EBUS_DMA_FLAG_TCI_DISABLE 0x00000002
|
|
|
|
|
|
|
|
/* These are only valid is EBUS_DMA_FLAG_USE_EBDMA_HANDLER is
|
|
|
|
* set.
|
|
|
|
*/
|
|
|
|
void (*callback)(struct ebus_dma_info *p, int event, void *cookie);
|
|
|
|
void *client_cookie;
|
|
|
|
unsigned int irq;
|
|
|
|
#define EBUS_DMA_EVENT_ERROR 1
|
|
|
|
#define EBUS_DMA_EVENT_DMA 2
|
|
|
|
#define EBUS_DMA_EVENT_DEVICE 4
|
|
|
|
|
|
|
|
unsigned char name[64];
|
|
|
|
};
|
|
|
|
|
2014-05-17 05:25:50 +08:00
|
|
|
int ebus_dma_register(struct ebus_dma_info *p);
|
|
|
|
int ebus_dma_irq_enable(struct ebus_dma_info *p, int on);
|
|
|
|
void ebus_dma_unregister(struct ebus_dma_info *p);
|
|
|
|
int ebus_dma_request(struct ebus_dma_info *p, dma_addr_t bus_addr,
|
2008-08-30 14:10:21 +08:00
|
|
|
size_t len);
|
2014-05-17 05:25:50 +08:00
|
|
|
void ebus_dma_prepare(struct ebus_dma_info *p, int write);
|
|
|
|
unsigned int ebus_dma_residue(struct ebus_dma_info *p);
|
|
|
|
unsigned int ebus_dma_addr(struct ebus_dma_info *p);
|
|
|
|
void ebus_dma_enable(struct ebus_dma_info *p, int on);
|
2008-08-30 14:10:21 +08:00
|
|
|
|
|
|
|
#endif /* __ASM_SPARC_EBUS_DMA_H */
|