1 /* SPDX-License-Identifier: GPL-2.0 */ 1 /* SPDX-License-Identifier: GPL-2.0 */ 2 2 3 #ifndef _SPRD_DMA_H_ 3 #ifndef _SPRD_DMA_H_ 4 #define _SPRD_DMA_H_ 4 #define _SPRD_DMA_H_ 5 5 6 #define SPRD_DMA_REQ_SHIFT 8 6 #define SPRD_DMA_REQ_SHIFT 8 7 #define SPRD_DMA_TRG_MODE_SHIFT 16 7 #define SPRD_DMA_TRG_MODE_SHIFT 16 8 #define SPRD_DMA_CHN_MODE_SHIFT 24 8 #define SPRD_DMA_CHN_MODE_SHIFT 24 9 #define SPRD_DMA_FLAGS(chn_mode, trg_mode, req 9 #define SPRD_DMA_FLAGS(chn_mode, trg_mode, req_mode, int_type) \ 10 ((chn_mode) << SPRD_DMA_CHN_MODE_SHIFT 10 ((chn_mode) << SPRD_DMA_CHN_MODE_SHIFT | \ 11 (trg_mode) << SPRD_DMA_TRG_MODE_SHIFT 11 (trg_mode) << SPRD_DMA_TRG_MODE_SHIFT | \ 12 (req_mode) << SPRD_DMA_REQ_SHIFT | (in 12 (req_mode) << SPRD_DMA_REQ_SHIFT | (int_type)) 13 13 14 /* 14 /* 15 * The Spreadtrum DMA controller supports chan 15 * The Spreadtrum DMA controller supports channel 2-stage tansfer, that means 16 * we can request 2 dma channels, one for sour 16 * we can request 2 dma channels, one for source channel, and another one for 17 * destination channel. Each channel is indepe 17 * destination channel. Each channel is independent, and has its own 18 * configurations. Once the source channel's t 18 * configurations. Once the source channel's transaction is done, it will 19 * trigger the destination channel's transacti 19 * trigger the destination channel's transaction automatically by hardware 20 * signal. 20 * signal. 21 * 21 * 22 * To support 2-stage tansfer, we must configu 22 * To support 2-stage tansfer, we must configure the channel mode and trigger 23 * mode as below definition. 23 * mode as below definition. 24 */ 24 */ 25 25 26 /* 26 /* 27 * enum sprd_dma_chn_mode: define the DMA chan 27 * enum sprd_dma_chn_mode: define the DMA channel mode for 2-stage transfer 28 * @SPRD_DMA_CHN_MODE_NONE: No channel mode se 28 * @SPRD_DMA_CHN_MODE_NONE: No channel mode setting which means channel doesn't 29 * support the 2-stage transfer. 29 * support the 2-stage transfer. 30 * @SPRD_DMA_SRC_CHN0: Channel used as source 30 * @SPRD_DMA_SRC_CHN0: Channel used as source channel 0. 31 * @SPRD_DMA_SRC_CHN1: Channel used as source 31 * @SPRD_DMA_SRC_CHN1: Channel used as source channel 1. 32 * @SPRD_DMA_DST_CHN0: Channel used as destina 32 * @SPRD_DMA_DST_CHN0: Channel used as destination channel 0. 33 * @SPRD_DMA_DST_CHN1: Channel used as destina 33 * @SPRD_DMA_DST_CHN1: Channel used as destination channel 1. 34 * 34 * 35 * Now the DMA controller can supports 2 group 35 * Now the DMA controller can supports 2 groups 2-stage transfer. 36 */ 36 */ 37 enum sprd_dma_chn_mode { 37 enum sprd_dma_chn_mode { 38 SPRD_DMA_CHN_MODE_NONE, 38 SPRD_DMA_CHN_MODE_NONE, 39 SPRD_DMA_SRC_CHN0, 39 SPRD_DMA_SRC_CHN0, 40 SPRD_DMA_SRC_CHN1, 40 SPRD_DMA_SRC_CHN1, 41 SPRD_DMA_DST_CHN0, 41 SPRD_DMA_DST_CHN0, 42 SPRD_DMA_DST_CHN1, 42 SPRD_DMA_DST_CHN1, 43 }; 43 }; 44 44 45 /* 45 /* 46 * enum sprd_dma_trg_mode: define the DMA chan 46 * enum sprd_dma_trg_mode: define the DMA channel trigger mode for 2-stage 47 * transfer 47 * transfer 48 * @SPRD_DMA_NO_TRG: No trigger setting. 48 * @SPRD_DMA_NO_TRG: No trigger setting. 49 * @SPRD_DMA_FRAG_DONE_TRG: Trigger the transa 49 * @SPRD_DMA_FRAG_DONE_TRG: Trigger the transaction of destination channel 50 * automatically once the source channel's fra 50 * automatically once the source channel's fragment request is done. 51 * @SPRD_DMA_BLOCK_DONE_TRG: Trigger the trans 51 * @SPRD_DMA_BLOCK_DONE_TRG: Trigger the transaction of destination channel 52 * automatically once the source channel's blo 52 * automatically once the source channel's block request is done. 53 * @SPRD_DMA_TRANS_DONE_TRG: Trigger the trans 53 * @SPRD_DMA_TRANS_DONE_TRG: Trigger the transaction of destination channel 54 * automatically once the source channel's tra 54 * automatically once the source channel's transfer request is done. 55 * @SPRD_DMA_LIST_DONE_TRG: Trigger the transa 55 * @SPRD_DMA_LIST_DONE_TRG: Trigger the transaction of destination channel 56 * automatically once the source channel's lin 56 * automatically once the source channel's link-list request is done. 57 */ 57 */ 58 enum sprd_dma_trg_mode { 58 enum sprd_dma_trg_mode { 59 SPRD_DMA_NO_TRG, 59 SPRD_DMA_NO_TRG, 60 SPRD_DMA_FRAG_DONE_TRG, 60 SPRD_DMA_FRAG_DONE_TRG, 61 SPRD_DMA_BLOCK_DONE_TRG, 61 SPRD_DMA_BLOCK_DONE_TRG, 62 SPRD_DMA_TRANS_DONE_TRG, 62 SPRD_DMA_TRANS_DONE_TRG, 63 SPRD_DMA_LIST_DONE_TRG, 63 SPRD_DMA_LIST_DONE_TRG, 64 }; 64 }; 65 65 66 /* 66 /* 67 * enum sprd_dma_req_mode: define the DMA requ 67 * enum sprd_dma_req_mode: define the DMA request mode 68 * @SPRD_DMA_FRAG_REQ: fragment request mode 68 * @SPRD_DMA_FRAG_REQ: fragment request mode 69 * @SPRD_DMA_BLK_REQ: block request mode 69 * @SPRD_DMA_BLK_REQ: block request mode 70 * @SPRD_DMA_TRANS_REQ: transaction request mo 70 * @SPRD_DMA_TRANS_REQ: transaction request mode 71 * @SPRD_DMA_LIST_REQ: link-list request mode 71 * @SPRD_DMA_LIST_REQ: link-list request mode 72 * 72 * 73 * We have 4 types request mode: fragment mode 73 * We have 4 types request mode: fragment mode, block mode, transaction mode 74 * and linklist mode. One transaction can cont 74 * and linklist mode. One transaction can contain several blocks, one block can 75 * contain several fragments. Link-list mode m 75 * contain several fragments. Link-list mode means we can save several DMA 76 * configuration into one reserved memory, the 76 * configuration into one reserved memory, then DMA can fetch each DMA 77 * configuration automatically to start transf 77 * configuration automatically to start transfer. 78 */ 78 */ 79 enum sprd_dma_req_mode { 79 enum sprd_dma_req_mode { 80 SPRD_DMA_FRAG_REQ, 80 SPRD_DMA_FRAG_REQ, 81 SPRD_DMA_BLK_REQ, 81 SPRD_DMA_BLK_REQ, 82 SPRD_DMA_TRANS_REQ, 82 SPRD_DMA_TRANS_REQ, 83 SPRD_DMA_LIST_REQ, 83 SPRD_DMA_LIST_REQ, 84 }; 84 }; 85 85 86 /* 86 /* 87 * enum sprd_dma_int_type: define the DMA inte 87 * enum sprd_dma_int_type: define the DMA interrupt type 88 * @SPRD_DMA_NO_INT: do not need generate DMA 88 * @SPRD_DMA_NO_INT: do not need generate DMA interrupts. 89 * @SPRD_DMA_FRAG_INT: fragment done interrupt 89 * @SPRD_DMA_FRAG_INT: fragment done interrupt when one fragment request 90 * is done. 90 * is done. 91 * @SPRD_DMA_BLK_INT: block done interrupt whe 91 * @SPRD_DMA_BLK_INT: block done interrupt when one block request is done. 92 * @SPRD_DMA_BLK_FRAG_INT: block and fragment 92 * @SPRD_DMA_BLK_FRAG_INT: block and fragment interrupt when one fragment 93 * or one block request is done. 93 * or one block request is done. 94 * @SPRD_DMA_TRANS_INT: tansaction done interr 94 * @SPRD_DMA_TRANS_INT: tansaction done interrupt when one transaction 95 * request is done. 95 * request is done. 96 * @SPRD_DMA_TRANS_FRAG_INT: transaction and f 96 * @SPRD_DMA_TRANS_FRAG_INT: transaction and fragment interrupt when one 97 * transaction request or fragment request is 97 * transaction request or fragment request is done. 98 * @SPRD_DMA_TRANS_BLK_INT: transaction and bl 98 * @SPRD_DMA_TRANS_BLK_INT: transaction and block interrupt when one 99 * transaction request or block request is don 99 * transaction request or block request is done. 100 * @SPRD_DMA_LIST_INT: link-list done interrup 100 * @SPRD_DMA_LIST_INT: link-list done interrupt when one link-list request 101 * is done. 101 * is done. 102 * @SPRD_DMA_CFGERR_INT: configure error inter 102 * @SPRD_DMA_CFGERR_INT: configure error interrupt when configuration is 103 * incorrect. 103 * incorrect. 104 */ 104 */ 105 enum sprd_dma_int_type { 105 enum sprd_dma_int_type { 106 SPRD_DMA_NO_INT, 106 SPRD_DMA_NO_INT, 107 SPRD_DMA_FRAG_INT, 107 SPRD_DMA_FRAG_INT, 108 SPRD_DMA_BLK_INT, 108 SPRD_DMA_BLK_INT, 109 SPRD_DMA_BLK_FRAG_INT, 109 SPRD_DMA_BLK_FRAG_INT, 110 SPRD_DMA_TRANS_INT, 110 SPRD_DMA_TRANS_INT, 111 SPRD_DMA_TRANS_FRAG_INT, 111 SPRD_DMA_TRANS_FRAG_INT, 112 SPRD_DMA_TRANS_BLK_INT, 112 SPRD_DMA_TRANS_BLK_INT, 113 SPRD_DMA_LIST_INT, 113 SPRD_DMA_LIST_INT, 114 SPRD_DMA_CFGERR_INT, 114 SPRD_DMA_CFGERR_INT, 115 }; 115 }; 116 116 117 /* 117 /* 118 * struct sprd_dma_linklist - DMA link-list ad 118 * struct sprd_dma_linklist - DMA link-list address structure 119 * @virt_addr: link-list virtual address to co 119 * @virt_addr: link-list virtual address to configure link-list node 120 * @phy_addr: link-list physical address to li 120 * @phy_addr: link-list physical address to link DMA transfer 121 * @wrap_addr: the wrap address for link-list << 122 * transfer address reaches the wrap address, << 123 * will jump to the address specified by wrap_ << 124 * 121 * 125 * The Spreadtrum DMA controller supports the 122 * The Spreadtrum DMA controller supports the link-list mode, that means slaves 126 * can supply several groups configurations (e 123 * can supply several groups configurations (each configuration represents one 127 * DMA transfer) saved in memory, and DMA cont 124 * DMA transfer) saved in memory, and DMA controller will link these groups 128 * configurations by writing the physical addr 125 * configurations by writing the physical address of each configuration into the 129 * link-list register. 126 * link-list register. 130 * 127 * 131 * Just as shown below, the link-list pointer 128 * Just as shown below, the link-list pointer register will be pointed to the 132 * physical address of 'configuration 1', and 129 * physical address of 'configuration 1', and the 'configuration 1' link-list 133 * pointer will be pointed to 'configuration 2 130 * pointer will be pointed to 'configuration 2', and so on. 134 * Once trigger the DMA transfer, the DMA cont 131 * Once trigger the DMA transfer, the DMA controller will load 'configuration 135 * 1' to its registers automatically, after 'c 132 * 1' to its registers automatically, after 'configuration 1' transaction is 136 * done, DMA controller will load 'configurati 133 * done, DMA controller will load 'configuration 2' automatically, until all 137 * DMA transactions are done. 134 * DMA transactions are done. 138 * 135 * 139 * Note: The last link-list pointer should poi 136 * Note: The last link-list pointer should point to the physical address 140 * of 'configuration 1', which can avoid DMA c 137 * of 'configuration 1', which can avoid DMA controller loads incorrect 141 * configuration when the last configuration t 138 * configuration when the last configuration transaction is done. 142 * 139 * 143 * DMA controller linkl 140 * DMA controller linklist memory 144 * ====================== -------- 141 * ====================== ----------------------- 145 *| | | conf 142 *| | | configuration 1 |<--- 146 *| DMA controller | ------->| 143 *| DMA controller | ------->| | | 147 *| | | | 144 *| | | | | | 148 *| | | | 145 *| | | | | | 149 *| | | | 146 *| | | | | | 150 *| linklist pointer reg |---- ----| link 147 *| linklist pointer reg |---- ----| linklist pointer | | 151 * ====================== | -------- 148 * ====================== | ----------------------- | 152 * | 149 * | | 153 * | -------- 150 * | ----------------------- | 154 * | | conf 151 * | | configuration 2 | | 155 * --->| 152 * --->| | | 156 * | 153 * | | | 157 * | 154 * | | | 158 * | 155 * | | | 159 * ----| link 156 * ----| linklist pointer | | 160 * | -------- 157 * | ----------------------- | 161 * | 158 * | | 162 * | -------- 159 * | ----------------------- | 163 * | | conf 160 * | | configuration 3 | | 164 * --->| 161 * --->| | | 165 * | 162 * | | | 166 * | 163 * | . | | 167 * 164 * . | 168 * 165 * . | 169 * 166 * . | 170 * | 167 * | . | 171 * | -------- 168 * | ----------------------- | 172 * | | conf 169 * | | configuration n | | 173 * --->| 170 * --->| | | 174 * | 171 * | | | 175 * | 172 * | | | 176 * | 173 * | | | 177 * | link 174 * | linklist pointer |---- 178 * -------- 175 * ----------------------- 179 * 176 * 180 * To support the link-list mode, DMA slaves s 177 * To support the link-list mode, DMA slaves should allocate one segment memory 181 * from always-on IRAM or dma coherent memory 178 * from always-on IRAM or dma coherent memory to store these groups of DMA 182 * configuration, and pass the virtual and phy 179 * configuration, and pass the virtual and physical address to DMA controller. 183 */ 180 */ 184 struct sprd_dma_linklist { 181 struct sprd_dma_linklist { 185 unsigned long virt_addr; 182 unsigned long virt_addr; 186 phys_addr_t phy_addr; 183 phys_addr_t phy_addr; 187 phys_addr_t wrap_addr; << 188 }; 184 }; 189 185 190 #endif 186 #endif 191 187
Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.