1*ad80da65SXuelin Shi /* 2*ad80da65SXuelin Shi * drivers/dma/fsl_raid.h 3*ad80da65SXuelin Shi * 4*ad80da65SXuelin Shi * Freescale RAID Engine device driver 5*ad80da65SXuelin Shi * 6*ad80da65SXuelin Shi * Author: 7*ad80da65SXuelin Shi * Harninder Rai <harninder.rai@freescale.com> 8*ad80da65SXuelin Shi * Naveen Burmi <naveenburmi@freescale.com> 9*ad80da65SXuelin Shi * 10*ad80da65SXuelin Shi * Rewrite: 11*ad80da65SXuelin Shi * Xuelin Shi <xuelin.shi@freescale.com> 12*ad80da65SXuelin Shi 13*ad80da65SXuelin Shi * Copyright (c) 2010-2012 Freescale Semiconductor, Inc. 14*ad80da65SXuelin Shi * 15*ad80da65SXuelin Shi * Redistribution and use in source and binary forms, with or without 16*ad80da65SXuelin Shi * modification, are permitted provided that the following conditions are met: 17*ad80da65SXuelin Shi * * Redistributions of source code must retain the above copyright 18*ad80da65SXuelin Shi * notice, this list of conditions and the following disclaimer. 19*ad80da65SXuelin Shi * * Redistributions in binary form must reproduce the above copyright 20*ad80da65SXuelin Shi * notice, this list of conditions and the following disclaimer in the 21*ad80da65SXuelin Shi * documentation and/or other materials provided with the distribution. 22*ad80da65SXuelin Shi * * Neither the name of Freescale Semiconductor nor the 23*ad80da65SXuelin Shi * names of its contributors may be used to endorse or promote products 24*ad80da65SXuelin Shi * derived from this software without specific prior written permission. 25*ad80da65SXuelin Shi * 26*ad80da65SXuelin Shi * ALTERNATIVELY, this software may be distributed under the terms of the 27*ad80da65SXuelin Shi * GNU General Public License ("GPL") as published by the Free Software 28*ad80da65SXuelin Shi * Foundation, either version 2 of that License or (at your option) any 29*ad80da65SXuelin Shi * later version. 30*ad80da65SXuelin Shi * 31*ad80da65SXuelin Shi * THIS SOFTWARE IS PROVIDED BY Freescale Semiconductor ``AS IS'' AND ANY 32*ad80da65SXuelin Shi * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 33*ad80da65SXuelin Shi * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 34*ad80da65SXuelin Shi * DISCLAIMED. IN NO EVENT SHALL Freescale Semiconductor BE LIABLE FOR ANY 35*ad80da65SXuelin Shi * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 36*ad80da65SXuelin Shi * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 37*ad80da65SXuelin Shi * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND 38*ad80da65SXuelin Shi * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 39*ad80da65SXuelin Shi * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 40*ad80da65SXuelin Shi * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 41*ad80da65SXuelin Shi * 42*ad80da65SXuelin Shi */ 43*ad80da65SXuelin Shi 44*ad80da65SXuelin Shi #define FSL_RE_MAX_CHANS 4 45*ad80da65SXuelin Shi #define FSL_RE_DPAA_MODE BIT(30) 46*ad80da65SXuelin Shi #define FSL_RE_NON_DPAA_MODE BIT(31) 47*ad80da65SXuelin Shi #define FSL_RE_GFM_POLY 0x1d000000 48*ad80da65SXuelin Shi #define FSL_RE_ADD_JOB(x) ((x) << 16) 49*ad80da65SXuelin Shi #define FSL_RE_RMVD_JOB(x) ((x) << 16) 50*ad80da65SXuelin Shi #define FSL_RE_CFG1_CBSI 0x08000000 51*ad80da65SXuelin Shi #define FSL_RE_CFG1_CBS0 0x00080000 52*ad80da65SXuelin Shi #define FSL_RE_SLOT_FULL_SHIFT 8 53*ad80da65SXuelin Shi #define FSL_RE_SLOT_FULL(x) ((x) >> FSL_RE_SLOT_FULL_SHIFT) 54*ad80da65SXuelin Shi #define FSL_RE_SLOT_AVAIL_SHIFT 8 55*ad80da65SXuelin Shi #define FSL_RE_SLOT_AVAIL(x) ((x) >> FSL_RE_SLOT_AVAIL_SHIFT) 56*ad80da65SXuelin Shi #define FSL_RE_PQ_OPCODE 0x1B 57*ad80da65SXuelin Shi #define FSL_RE_XOR_OPCODE 0x1A 58*ad80da65SXuelin Shi #define FSL_RE_MOVE_OPCODE 0x8 59*ad80da65SXuelin Shi #define FSL_RE_FRAME_ALIGN 16 60*ad80da65SXuelin Shi #define FSL_RE_BLOCK_SIZE 0x3 /* 4096 bytes */ 61*ad80da65SXuelin Shi #define FSL_RE_CACHEABLE_IO 0x0 62*ad80da65SXuelin Shi #define FSL_RE_BUFFER_OUTPUT 0x0 63*ad80da65SXuelin Shi #define FSL_RE_INTR_ON_ERROR 0x1 64*ad80da65SXuelin Shi #define FSL_RE_DATA_DEP 0x1 65*ad80da65SXuelin Shi #define FSL_RE_ENABLE_DPI 0x0 66*ad80da65SXuelin Shi #define FSL_RE_RING_SIZE 0x400 67*ad80da65SXuelin Shi #define FSL_RE_RING_SIZE_MASK (FSL_RE_RING_SIZE - 1) 68*ad80da65SXuelin Shi #define FSL_RE_RING_SIZE_SHIFT 8 69*ad80da65SXuelin Shi #define FSL_RE_ADDR_BIT_SHIFT 4 70*ad80da65SXuelin Shi #define FSL_RE_ADDR_BIT_MASK (BIT(FSL_RE_ADDR_BIT_SHIFT) - 1) 71*ad80da65SXuelin Shi #define FSL_RE_ERROR 0x40000000 72*ad80da65SXuelin Shi #define FSL_RE_INTR 0x80000000 73*ad80da65SXuelin Shi #define FSL_RE_CLR_INTR 0x80000000 74*ad80da65SXuelin Shi #define FSL_RE_PAUSE 0x80000000 75*ad80da65SXuelin Shi #define FSL_RE_ENABLE 0x80000000 76*ad80da65SXuelin Shi #define FSL_RE_REG_LIODN_MASK 0x00000FFF 77*ad80da65SXuelin Shi 78*ad80da65SXuelin Shi #define FSL_RE_CDB_OPCODE_MASK 0xF8000000 79*ad80da65SXuelin Shi #define FSL_RE_CDB_OPCODE_SHIFT 27 80*ad80da65SXuelin Shi #define FSL_RE_CDB_EXCLEN_MASK 0x03000000 81*ad80da65SXuelin Shi #define FSL_RE_CDB_EXCLEN_SHIFT 24 82*ad80da65SXuelin Shi #define FSL_RE_CDB_EXCLQ1_MASK 0x00F00000 83*ad80da65SXuelin Shi #define FSL_RE_CDB_EXCLQ1_SHIFT 20 84*ad80da65SXuelin Shi #define FSL_RE_CDB_EXCLQ2_MASK 0x000F0000 85*ad80da65SXuelin Shi #define FSL_RE_CDB_EXCLQ2_SHIFT 16 86*ad80da65SXuelin Shi #define FSL_RE_CDB_BLKSIZE_MASK 0x0000C000 87*ad80da65SXuelin Shi #define FSL_RE_CDB_BLKSIZE_SHIFT 14 88*ad80da65SXuelin Shi #define FSL_RE_CDB_CACHE_MASK 0x00003000 89*ad80da65SXuelin Shi #define FSL_RE_CDB_CACHE_SHIFT 12 90*ad80da65SXuelin Shi #define FSL_RE_CDB_BUFFER_MASK 0x00000800 91*ad80da65SXuelin Shi #define FSL_RE_CDB_BUFFER_SHIFT 11 92*ad80da65SXuelin Shi #define FSL_RE_CDB_ERROR_MASK 0x00000400 93*ad80da65SXuelin Shi #define FSL_RE_CDB_ERROR_SHIFT 10 94*ad80da65SXuelin Shi #define FSL_RE_CDB_NRCS_MASK 0x0000003C 95*ad80da65SXuelin Shi #define FSL_RE_CDB_NRCS_SHIFT 6 96*ad80da65SXuelin Shi #define FSL_RE_CDB_DEPEND_MASK 0x00000008 97*ad80da65SXuelin Shi #define FSL_RE_CDB_DEPEND_SHIFT 3 98*ad80da65SXuelin Shi #define FSL_RE_CDB_DPI_MASK 0x00000004 99*ad80da65SXuelin Shi #define FSL_RE_CDB_DPI_SHIFT 2 100*ad80da65SXuelin Shi 101*ad80da65SXuelin Shi /* 102*ad80da65SXuelin Shi * the largest cf block is 19*sizeof(struct cmpnd_frame), which is 304 bytes. 103*ad80da65SXuelin Shi * here 19 = 1(cdb)+2(dest)+16(src), align to 64bytes, that is 320 bytes. 104*ad80da65SXuelin Shi * the largest cdb block: struct pq_cdb which is 180 bytes, adding to cf block 105*ad80da65SXuelin Shi * 320+180=500, align to 64bytes, that is 512 bytes. 106*ad80da65SXuelin Shi */ 107*ad80da65SXuelin Shi #define FSL_RE_CF_DESC_SIZE 320 108*ad80da65SXuelin Shi #define FSL_RE_CF_CDB_SIZE 512 109*ad80da65SXuelin Shi #define FSL_RE_CF_CDB_ALIGN 64 110*ad80da65SXuelin Shi 111*ad80da65SXuelin Shi struct fsl_re_ctrl { 112*ad80da65SXuelin Shi /* General Configuration Registers */ 113*ad80da65SXuelin Shi __be32 global_config; /* Global Configuration Register */ 114*ad80da65SXuelin Shi u8 rsvd1[4]; 115*ad80da65SXuelin Shi __be32 galois_field_config; /* Galois Field Configuration Register */ 116*ad80da65SXuelin Shi u8 rsvd2[4]; 117*ad80da65SXuelin Shi __be32 jq_wrr_config; /* WRR Configuration register */ 118*ad80da65SXuelin Shi u8 rsvd3[4]; 119*ad80da65SXuelin Shi __be32 crc_config; /* CRC Configuration register */ 120*ad80da65SXuelin Shi u8 rsvd4[228]; 121*ad80da65SXuelin Shi __be32 system_reset; /* System Reset Register */ 122*ad80da65SXuelin Shi u8 rsvd5[252]; 123*ad80da65SXuelin Shi __be32 global_status; /* Global Status Register */ 124*ad80da65SXuelin Shi u8 rsvd6[832]; 125*ad80da65SXuelin Shi __be32 re_liodn_base; /* LIODN Base Register */ 126*ad80da65SXuelin Shi u8 rsvd7[1712]; 127*ad80da65SXuelin Shi __be32 re_version_id; /* Version ID register of RE */ 128*ad80da65SXuelin Shi __be32 re_version_id_2; /* Version ID 2 register of RE */ 129*ad80da65SXuelin Shi u8 rsvd8[512]; 130*ad80da65SXuelin Shi __be32 host_config; /* Host I/F Configuration Register */ 131*ad80da65SXuelin Shi }; 132*ad80da65SXuelin Shi 133*ad80da65SXuelin Shi struct fsl_re_chan_cfg { 134*ad80da65SXuelin Shi /* Registers for JR interface */ 135*ad80da65SXuelin Shi __be32 jr_config_0; /* Job Queue Configuration 0 Register */ 136*ad80da65SXuelin Shi __be32 jr_config_1; /* Job Queue Configuration 1 Register */ 137*ad80da65SXuelin Shi __be32 jr_interrupt_status; /* Job Queue Interrupt Status Register */ 138*ad80da65SXuelin Shi u8 rsvd1[4]; 139*ad80da65SXuelin Shi __be32 jr_command; /* Job Queue Command Register */ 140*ad80da65SXuelin Shi u8 rsvd2[4]; 141*ad80da65SXuelin Shi __be32 jr_status; /* Job Queue Status Register */ 142*ad80da65SXuelin Shi u8 rsvd3[228]; 143*ad80da65SXuelin Shi 144*ad80da65SXuelin Shi /* Input Ring */ 145*ad80da65SXuelin Shi __be32 inbring_base_h; /* Inbound Ring Base Address Register - High */ 146*ad80da65SXuelin Shi __be32 inbring_base_l; /* Inbound Ring Base Address Register - Low */ 147*ad80da65SXuelin Shi __be32 inbring_size; /* Inbound Ring Size Register */ 148*ad80da65SXuelin Shi u8 rsvd4[4]; 149*ad80da65SXuelin Shi __be32 inbring_slot_avail; /* Inbound Ring Slot Available Register */ 150*ad80da65SXuelin Shi u8 rsvd5[4]; 151*ad80da65SXuelin Shi __be32 inbring_add_job; /* Inbound Ring Add Job Register */ 152*ad80da65SXuelin Shi u8 rsvd6[4]; 153*ad80da65SXuelin Shi __be32 inbring_cnsmr_indx; /* Inbound Ring Consumer Index Register */ 154*ad80da65SXuelin Shi u8 rsvd7[220]; 155*ad80da65SXuelin Shi 156*ad80da65SXuelin Shi /* Output Ring */ 157*ad80da65SXuelin Shi __be32 oubring_base_h; /* Outbound Ring Base Address Register - High */ 158*ad80da65SXuelin Shi __be32 oubring_base_l; /* Outbound Ring Base Address Register - Low */ 159*ad80da65SXuelin Shi __be32 oubring_size; /* Outbound Ring Size Register */ 160*ad80da65SXuelin Shi u8 rsvd8[4]; 161*ad80da65SXuelin Shi __be32 oubring_job_rmvd; /* Outbound Ring Job Removed Register */ 162*ad80da65SXuelin Shi u8 rsvd9[4]; 163*ad80da65SXuelin Shi __be32 oubring_slot_full; /* Outbound Ring Slot Full Register */ 164*ad80da65SXuelin Shi u8 rsvd10[4]; 165*ad80da65SXuelin Shi __be32 oubring_prdcr_indx; /* Outbound Ring Producer Index */ 166*ad80da65SXuelin Shi }; 167*ad80da65SXuelin Shi 168*ad80da65SXuelin Shi /* 169*ad80da65SXuelin Shi * Command Descriptor Block (CDB) for unicast move command. 170*ad80da65SXuelin Shi * In RAID Engine terms, memcpy is done through move command 171*ad80da65SXuelin Shi */ 172*ad80da65SXuelin Shi struct fsl_re_move_cdb { 173*ad80da65SXuelin Shi __be32 cdb32; 174*ad80da65SXuelin Shi }; 175*ad80da65SXuelin Shi 176*ad80da65SXuelin Shi /* Data protection/integrity related fields */ 177*ad80da65SXuelin Shi #define FSL_RE_DPI_APPS_MASK 0xC0000000 178*ad80da65SXuelin Shi #define FSL_RE_DPI_APPS_SHIFT 30 179*ad80da65SXuelin Shi #define FSL_RE_DPI_REF_MASK 0x30000000 180*ad80da65SXuelin Shi #define FSL_RE_DPI_REF_SHIFT 28 181*ad80da65SXuelin Shi #define FSL_RE_DPI_GUARD_MASK 0x0C000000 182*ad80da65SXuelin Shi #define FSL_RE_DPI_GUARD_SHIFT 26 183*ad80da65SXuelin Shi #define FSL_RE_DPI_ATTR_MASK 0x03000000 184*ad80da65SXuelin Shi #define FSL_RE_DPI_ATTR_SHIFT 24 185*ad80da65SXuelin Shi #define FSL_RE_DPI_META_MASK 0x0000FFFF 186*ad80da65SXuelin Shi 187*ad80da65SXuelin Shi struct fsl_re_dpi { 188*ad80da65SXuelin Shi __be32 dpi32; 189*ad80da65SXuelin Shi __be32 ref; 190*ad80da65SXuelin Shi }; 191*ad80da65SXuelin Shi 192*ad80da65SXuelin Shi /* 193*ad80da65SXuelin Shi * CDB for GenQ command. In RAID Engine terminology, XOR is 194*ad80da65SXuelin Shi * done through this command 195*ad80da65SXuelin Shi */ 196*ad80da65SXuelin Shi struct fsl_re_xor_cdb { 197*ad80da65SXuelin Shi __be32 cdb32; 198*ad80da65SXuelin Shi u8 gfm[16]; 199*ad80da65SXuelin Shi struct fsl_re_dpi dpi_dest_spec; 200*ad80da65SXuelin Shi struct fsl_re_dpi dpi_src_spec[16]; 201*ad80da65SXuelin Shi }; 202*ad80da65SXuelin Shi 203*ad80da65SXuelin Shi /* CDB for no-op command */ 204*ad80da65SXuelin Shi struct fsl_re_noop_cdb { 205*ad80da65SXuelin Shi __be32 cdb32; 206*ad80da65SXuelin Shi }; 207*ad80da65SXuelin Shi 208*ad80da65SXuelin Shi /* 209*ad80da65SXuelin Shi * CDB for GenQQ command. In RAID Engine terminology, P/Q is 210*ad80da65SXuelin Shi * done through this command 211*ad80da65SXuelin Shi */ 212*ad80da65SXuelin Shi struct fsl_re_pq_cdb { 213*ad80da65SXuelin Shi __be32 cdb32; 214*ad80da65SXuelin Shi u8 gfm_q1[16]; 215*ad80da65SXuelin Shi u8 gfm_q2[16]; 216*ad80da65SXuelin Shi struct fsl_re_dpi dpi_dest_spec[2]; 217*ad80da65SXuelin Shi struct fsl_re_dpi dpi_src_spec[16]; 218*ad80da65SXuelin Shi }; 219*ad80da65SXuelin Shi 220*ad80da65SXuelin Shi /* Compound frame */ 221*ad80da65SXuelin Shi #define FSL_RE_CF_ADDR_HIGH_MASK 0x000000FF 222*ad80da65SXuelin Shi #define FSL_RE_CF_EXT_MASK 0x80000000 223*ad80da65SXuelin Shi #define FSL_RE_CF_EXT_SHIFT 31 224*ad80da65SXuelin Shi #define FSL_RE_CF_FINAL_MASK 0x40000000 225*ad80da65SXuelin Shi #define FSL_RE_CF_FINAL_SHIFT 30 226*ad80da65SXuelin Shi #define FSL_RE_CF_LENGTH_MASK 0x000FFFFF 227*ad80da65SXuelin Shi #define FSL_RE_CF_BPID_MASK 0x00FF0000 228*ad80da65SXuelin Shi #define FSL_RE_CF_BPID_SHIFT 16 229*ad80da65SXuelin Shi #define FSL_RE_CF_OFFSET_MASK 0x00001FFF 230*ad80da65SXuelin Shi 231*ad80da65SXuelin Shi struct fsl_re_cmpnd_frame { 232*ad80da65SXuelin Shi __be32 addr_high; 233*ad80da65SXuelin Shi __be32 addr_low; 234*ad80da65SXuelin Shi __be32 efrl32; 235*ad80da65SXuelin Shi __be32 rbro32; 236*ad80da65SXuelin Shi }; 237*ad80da65SXuelin Shi 238*ad80da65SXuelin Shi /* Frame descriptor */ 239*ad80da65SXuelin Shi #define FSL_RE_HWDESC_LIODN_MASK 0x3F000000 240*ad80da65SXuelin Shi #define FSL_RE_HWDESC_LIODN_SHIFT 24 241*ad80da65SXuelin Shi #define FSL_RE_HWDESC_BPID_MASK 0x00FF0000 242*ad80da65SXuelin Shi #define FSL_RE_HWDESC_BPID_SHIFT 16 243*ad80da65SXuelin Shi #define FSL_RE_HWDESC_ELIODN_MASK 0x0000F000 244*ad80da65SXuelin Shi #define FSL_RE_HWDESC_ELIODN_SHIFT 12 245*ad80da65SXuelin Shi #define FSL_RE_HWDESC_FMT_SHIFT 29 246*ad80da65SXuelin Shi #define FSL_RE_HWDESC_FMT_MASK (0x3 << FSL_RE_HWDESC_FMT_SHIFT) 247*ad80da65SXuelin Shi 248*ad80da65SXuelin Shi struct fsl_re_hw_desc { 249*ad80da65SXuelin Shi __be32 lbea32; 250*ad80da65SXuelin Shi __be32 addr_low; 251*ad80da65SXuelin Shi __be32 fmt32; 252*ad80da65SXuelin Shi __be32 status; 253*ad80da65SXuelin Shi }; 254*ad80da65SXuelin Shi 255*ad80da65SXuelin Shi /* Raid Engine device private data */ 256*ad80da65SXuelin Shi struct fsl_re_drv_private { 257*ad80da65SXuelin Shi u8 total_chans; 258*ad80da65SXuelin Shi struct dma_device dma_dev; 259*ad80da65SXuelin Shi struct fsl_re_ctrl *re_regs; 260*ad80da65SXuelin Shi struct fsl_re_chan *re_jrs[FSL_RE_MAX_CHANS]; 261*ad80da65SXuelin Shi struct dma_pool *cf_desc_pool; 262*ad80da65SXuelin Shi struct dma_pool *hw_desc_pool; 263*ad80da65SXuelin Shi }; 264*ad80da65SXuelin Shi 265*ad80da65SXuelin Shi /* Per job ring data structure */ 266*ad80da65SXuelin Shi struct fsl_re_chan { 267*ad80da65SXuelin Shi char name[16]; 268*ad80da65SXuelin Shi spinlock_t desc_lock; /* queue lock */ 269*ad80da65SXuelin Shi struct list_head ack_q; /* wait to acked queue */ 270*ad80da65SXuelin Shi struct list_head active_q; /* already issued on hw, not completed */ 271*ad80da65SXuelin Shi struct list_head submit_q; 272*ad80da65SXuelin Shi struct list_head free_q; /* alloc available queue */ 273*ad80da65SXuelin Shi struct device *dev; 274*ad80da65SXuelin Shi struct fsl_re_drv_private *re_dev; 275*ad80da65SXuelin Shi struct dma_chan chan; 276*ad80da65SXuelin Shi struct fsl_re_chan_cfg *jrregs; 277*ad80da65SXuelin Shi int irq; 278*ad80da65SXuelin Shi struct tasklet_struct irqtask; 279*ad80da65SXuelin Shi u32 alloc_count; 280*ad80da65SXuelin Shi 281*ad80da65SXuelin Shi /* hw descriptor ring for inbound queue*/ 282*ad80da65SXuelin Shi dma_addr_t inb_phys_addr; 283*ad80da65SXuelin Shi struct fsl_re_hw_desc *inb_ring_virt_addr; 284*ad80da65SXuelin Shi u32 inb_count; 285*ad80da65SXuelin Shi 286*ad80da65SXuelin Shi /* hw descriptor ring for outbound queue */ 287*ad80da65SXuelin Shi dma_addr_t oub_phys_addr; 288*ad80da65SXuelin Shi struct fsl_re_hw_desc *oub_ring_virt_addr; 289*ad80da65SXuelin Shi u32 oub_count; 290*ad80da65SXuelin Shi }; 291*ad80da65SXuelin Shi 292*ad80da65SXuelin Shi /* Async transaction descriptor */ 293*ad80da65SXuelin Shi struct fsl_re_desc { 294*ad80da65SXuelin Shi struct dma_async_tx_descriptor async_tx; 295*ad80da65SXuelin Shi struct list_head node; 296*ad80da65SXuelin Shi struct fsl_re_hw_desc hwdesc; 297*ad80da65SXuelin Shi struct fsl_re_chan *re_chan; 298*ad80da65SXuelin Shi 299*ad80da65SXuelin Shi /* hwdesc will point to cf_addr */ 300*ad80da65SXuelin Shi void *cf_addr; 301*ad80da65SXuelin Shi dma_addr_t cf_paddr; 302*ad80da65SXuelin Shi 303*ad80da65SXuelin Shi void *cdb_addr; 304*ad80da65SXuelin Shi dma_addr_t cdb_paddr; 305*ad80da65SXuelin Shi int status; 306*ad80da65SXuelin Shi }; 307