aboutsummaryrefslogtreecommitdiff
path: root/arch/arm/mach-ux500/include/mach/dma.h
blob: 69c6f4c2216334cd06c764b777e2bc22e8260f2d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
/*
 * Copyright 2009 ST-Ericsson SA
 * Copyright 2009 STMicroelectronics.
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2
 * as published by the Free Software Foundation.
 */
#ifndef __INC_ASM_ARCH_DMA_H
#define __INC_ASM_ARCH_DMA_H

#define MAX_DMA_CHANNELS 32
#ifndef __ASSEMBLY__
#include <asm/scatterlist.h>

typedef unsigned int dmach_t;
typedef unsigned int dmamode_t;

enum dma_flow_controller {
	DMA_IS_FLOW_CNTLR,
	PERIPH_IS_FLOW_CNTLR
};
enum {
	DMA_FALSE,
	DMA_TRUE
};

enum dma_xfer_dir {
	MEM_TO_MEM,
	MEM_TO_PERIPH,
	PERIPH_TO_MEM,
	PERIPH_TO_PERIPH
};

enum dma_endianess {
	DMA_LITTLE_ENDIAN,
	DMA_BIG_ENDIAN
};
enum dma_event {
	XFER_COMPLETE,
	XFER_ERROR
};
typedef void (*dma_callback_t)(void *data, enum dma_event event);

#include <mach/dma_40-8500.h>

/**
 * struct stm_dma_pipe_info - Structure to be filled by client drivers.
 *
 * @reserve_channel: Whether you want to reserve the channel
 * @dir:	MEM 2 MEM, PERIPH 2 MEM , MEM 2 PERIPH, PERIPH 2 PERIPH
 * @flow_cntlr: who is flow controller (Device or DMA)
 * @phys_chan_id: physical channel ID on which this channel will execute
 * @data:	data of callback handler
 * @callback:	callback handler registered by client
 * @channel_type: std/ext, basic/log/operational, priority, security
 * @src_dev_type: Src device type
 * @dst_dev_type: Dest device type
 * @src_addr: Source address
 * @dst_addr: Dest address
 * @src_info: Parameters for Source half channel
 * @dst_info: Parameters for Dest half channel
 *
 *
 * This structure has to be filled by the client drivers, before requesting
 * a DMA pipe. This information is used by the Driver to allocate or
 * reserve an appropriate DMA channel for this client.
 *
 */
struct stm_dma_pipe_info {
	unsigned int reserve_channel;
	enum dma_xfer_dir dir;
	enum dma_flow_controller flow_cntlr;
	enum dma_chan_id phys_chan_id;
	void *data;
	dma_callback_t callback;
	unsigned int channel_type;
	enum dma_src_dev_type src_dev_type;
	enum dma_dest_dev_type dst_dev_type;
	void *src_addr;
	void *dst_addr;
	struct dma_half_channel_info  src_info;
	struct dma_half_channel_info  dst_info;
};

extern int stm_configure_dma_channel(int channel,
		struct stm_dma_pipe_info *info);
extern int stm_request_dma(int  *channel, struct stm_dma_pipe_info *info);
extern void stm_free_dma(int channel);
extern int stm_set_callback_handler(int channel, void *callback_handler,
		void *data);
extern int stm_enable_dma(int channel);
extern void stm_disable_dma(int channel);
extern int stm_pause_dma(int channel);
extern void stm_unpause_dma(int channel);
extern void stm_set_dma_addr(int channel, void *src_addr , void *dst_addr);
extern void stm_set_dma_count(int channel, int count);
extern void stm_set_dma_sg(int channel, struct scatterlist *sg,
		int nr_sg, int type);

extern int stm_dma_residue(int channel);

#endif 	/*__ASSEMBLY__*/
#endif	/* __INC_ASM_ARCH_DMA_H */
/* End of file - dma.h */