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 #define FSL_RE_MAX_CHANS                4
  45 #define FSL_RE_DPAA_MODE                BIT(30)
  46 #define FSL_RE_NON_DPAA_MODE            BIT(31)
  47 #define FSL_RE_GFM_POLY                 0x1d000000
  48 #define FSL_RE_ADD_JOB(x)               ((x) << 16)
  49 #define FSL_RE_RMVD_JOB(x)              ((x) << 16)
  50 #define FSL_RE_CFG1_CBSI                0x08000000
  51 #define FSL_RE_CFG1_CBS0                0x00080000
  52 #define FSL_RE_SLOT_FULL_SHIFT          8
  53 #define FSL_RE_SLOT_FULL(x)             ((x) >> FSL_RE_SLOT_FULL_SHIFT)
  54 #define FSL_RE_SLOT_AVAIL_SHIFT         8
  55 #define FSL_RE_SLOT_AVAIL(x)            ((x) >> FSL_RE_SLOT_AVAIL_SHIFT)
  56 #define FSL_RE_PQ_OPCODE                0x1B
  57 #define FSL_RE_XOR_OPCODE               0x1A
  58 #define FSL_RE_MOVE_OPCODE              0x8
  59 #define FSL_RE_FRAME_ALIGN              16
  60 #define FSL_RE_BLOCK_SIZE               0x3 
  61 #define FSL_RE_CACHEABLE_IO             0x0
  62 #define FSL_RE_BUFFER_OUTPUT            0x0
  63 #define FSL_RE_INTR_ON_ERROR            0x1
  64 #define FSL_RE_DATA_DEP                 0x1
  65 #define FSL_RE_ENABLE_DPI               0x0
  66 #define FSL_RE_RING_SIZE                0x400
  67 #define FSL_RE_RING_SIZE_MASK           (FSL_RE_RING_SIZE - 1)
  68 #define FSL_RE_RING_SIZE_SHIFT          8
  69 #define FSL_RE_ADDR_BIT_SHIFT           4
  70 #define FSL_RE_ADDR_BIT_MASK            (BIT(FSL_RE_ADDR_BIT_SHIFT) - 1)
  71 #define FSL_RE_ERROR                    0x40000000
  72 #define FSL_RE_INTR                     0x80000000
  73 #define FSL_RE_CLR_INTR                 0x80000000
  74 #define FSL_RE_PAUSE                    0x80000000
  75 #define FSL_RE_ENABLE                   0x80000000
  76 #define FSL_RE_REG_LIODN_MASK           0x00000FFF
  77 
  78 #define FSL_RE_CDB_OPCODE_MASK          0xF8000000
  79 #define FSL_RE_CDB_OPCODE_SHIFT         27
  80 #define FSL_RE_CDB_EXCLEN_MASK          0x03000000
  81 #define FSL_RE_CDB_EXCLEN_SHIFT         24
  82 #define FSL_RE_CDB_EXCLQ1_MASK          0x00F00000
  83 #define FSL_RE_CDB_EXCLQ1_SHIFT         20
  84 #define FSL_RE_CDB_EXCLQ2_MASK          0x000F0000
  85 #define FSL_RE_CDB_EXCLQ2_SHIFT         16
  86 #define FSL_RE_CDB_BLKSIZE_MASK         0x0000C000
  87 #define FSL_RE_CDB_BLKSIZE_SHIFT        14
  88 #define FSL_RE_CDB_CACHE_MASK           0x00003000
  89 #define FSL_RE_CDB_CACHE_SHIFT          12
  90 #define FSL_RE_CDB_BUFFER_MASK          0x00000800
  91 #define FSL_RE_CDB_BUFFER_SHIFT         11
  92 #define FSL_RE_CDB_ERROR_MASK           0x00000400
  93 #define FSL_RE_CDB_ERROR_SHIFT          10
  94 #define FSL_RE_CDB_NRCS_MASK            0x0000003C
  95 #define FSL_RE_CDB_NRCS_SHIFT           6
  96 #define FSL_RE_CDB_DEPEND_MASK          0x00000008
  97 #define FSL_RE_CDB_DEPEND_SHIFT         3
  98 #define FSL_RE_CDB_DPI_MASK             0x00000004
  99 #define FSL_RE_CDB_DPI_SHIFT            2
 100 
 101 
 102 
 103 
 104 
 105 
 106 
 107 #define FSL_RE_CF_DESC_SIZE             320
 108 #define FSL_RE_CF_CDB_SIZE              512
 109 #define FSL_RE_CF_CDB_ALIGN             64
 110 
 111 struct fsl_re_ctrl {
 112         
 113         __be32 global_config;   
 114         u8     rsvd1[4];
 115         __be32 galois_field_config; 
 116         u8     rsvd2[4];
 117         __be32 jq_wrr_config;   
 118         u8     rsvd3[4];
 119         __be32 crc_config;      
 120         u8     rsvd4[228];
 121         __be32 system_reset;    
 122         u8     rsvd5[252];
 123         __be32 global_status;   
 124         u8     rsvd6[832];
 125         __be32 re_liodn_base;   
 126         u8     rsvd7[1712];
 127         __be32 re_version_id;   
 128         __be32 re_version_id_2; 
 129         u8     rsvd8[512];
 130         __be32 host_config;     
 131 };
 132 
 133 struct fsl_re_chan_cfg {
 134         
 135         __be32 jr_config_0;     
 136         __be32 jr_config_1;     
 137         __be32 jr_interrupt_status; 
 138         u8     rsvd1[4];
 139         __be32 jr_command;      
 140         u8     rsvd2[4];
 141         __be32 jr_status;       
 142         u8     rsvd3[228];
 143 
 144         
 145         __be32 inbring_base_h;  
 146         __be32 inbring_base_l;  
 147         __be32 inbring_size;    
 148         u8     rsvd4[4];
 149         __be32 inbring_slot_avail; 
 150         u8     rsvd5[4];
 151         __be32 inbring_add_job; 
 152         u8     rsvd6[4];
 153         __be32 inbring_cnsmr_indx; 
 154         u8     rsvd7[220];
 155 
 156         
 157         __be32 oubring_base_h;  
 158         __be32 oubring_base_l;  
 159         __be32 oubring_size;    
 160         u8     rsvd8[4];
 161         __be32 oubring_job_rmvd; 
 162         u8     rsvd9[4];
 163         __be32 oubring_slot_full; 
 164         u8     rsvd10[4];
 165         __be32 oubring_prdcr_indx; 
 166 };
 167 
 168 
 169 
 170 
 171 
 172 struct fsl_re_move_cdb {
 173         __be32 cdb32;
 174 };
 175 
 176 
 177 #define FSL_RE_DPI_APPS_MASK            0xC0000000
 178 #define FSL_RE_DPI_APPS_SHIFT           30
 179 #define FSL_RE_DPI_REF_MASK             0x30000000
 180 #define FSL_RE_DPI_REF_SHIFT            28
 181 #define FSL_RE_DPI_GUARD_MASK           0x0C000000
 182 #define FSL_RE_DPI_GUARD_SHIFT          26
 183 #define FSL_RE_DPI_ATTR_MASK            0x03000000
 184 #define FSL_RE_DPI_ATTR_SHIFT           24
 185 #define FSL_RE_DPI_META_MASK            0x0000FFFF
 186 
 187 struct fsl_re_dpi {
 188         __be32 dpi32;
 189         __be32 ref;
 190 };
 191 
 192 
 193 
 194 
 195 
 196 struct fsl_re_xor_cdb {
 197         __be32 cdb32;
 198         u8 gfm[16];
 199         struct fsl_re_dpi dpi_dest_spec;
 200         struct fsl_re_dpi dpi_src_spec[16];
 201 };
 202 
 203 
 204 struct fsl_re_noop_cdb {
 205         __be32 cdb32;
 206 };
 207 
 208 
 209 
 210 
 211 
 212 struct fsl_re_pq_cdb {
 213         __be32 cdb32;
 214         u8 gfm_q1[16];
 215         u8 gfm_q2[16];
 216         struct fsl_re_dpi dpi_dest_spec[2];
 217         struct fsl_re_dpi dpi_src_spec[16];
 218 };
 219 
 220 
 221 #define FSL_RE_CF_ADDR_HIGH_MASK        0x000000FF
 222 #define FSL_RE_CF_EXT_MASK              0x80000000
 223 #define FSL_RE_CF_EXT_SHIFT             31
 224 #define FSL_RE_CF_FINAL_MASK            0x40000000
 225 #define FSL_RE_CF_FINAL_SHIFT           30
 226 #define FSL_RE_CF_LENGTH_MASK           0x000FFFFF
 227 #define FSL_RE_CF_BPID_MASK             0x00FF0000
 228 #define FSL_RE_CF_BPID_SHIFT            16
 229 #define FSL_RE_CF_OFFSET_MASK           0x00001FFF
 230 
 231 struct fsl_re_cmpnd_frame {
 232         __be32 addr_high;
 233         __be32 addr_low;
 234         __be32 efrl32;
 235         __be32 rbro32;
 236 };
 237 
 238 
 239 #define FSL_RE_HWDESC_LIODN_MASK        0x3F000000
 240 #define FSL_RE_HWDESC_LIODN_SHIFT       24
 241 #define FSL_RE_HWDESC_BPID_MASK         0x00FF0000
 242 #define FSL_RE_HWDESC_BPID_SHIFT        16
 243 #define FSL_RE_HWDESC_ELIODN_MASK       0x0000F000
 244 #define FSL_RE_HWDESC_ELIODN_SHIFT      12
 245 #define FSL_RE_HWDESC_FMT_SHIFT         29
 246 #define FSL_RE_HWDESC_FMT_MASK          (0x3 << FSL_RE_HWDESC_FMT_SHIFT)
 247 
 248 struct fsl_re_hw_desc {
 249         __be32 lbea32;
 250         __be32 addr_low;
 251         __be32 fmt32;
 252         __be32 status;
 253 };
 254 
 255 
 256 struct fsl_re_drv_private {
 257         u8 total_chans;
 258         struct dma_device dma_dev;
 259         struct fsl_re_ctrl *re_regs;
 260         struct fsl_re_chan *re_jrs[FSL_RE_MAX_CHANS];
 261         struct dma_pool *cf_desc_pool;
 262         struct dma_pool *hw_desc_pool;
 263 };
 264 
 265 
 266 struct fsl_re_chan {
 267         char name[16];
 268         spinlock_t desc_lock; 
 269         struct list_head ack_q;  
 270         struct list_head active_q; 
 271         struct list_head submit_q;
 272         struct list_head free_q; 
 273         struct device *dev;
 274         struct fsl_re_drv_private *re_dev;
 275         struct dma_chan chan;
 276         struct fsl_re_chan_cfg *jrregs;
 277         int irq;
 278         struct tasklet_struct irqtask;
 279         u32 alloc_count;
 280 
 281         
 282         dma_addr_t inb_phys_addr;
 283         struct fsl_re_hw_desc *inb_ring_virt_addr;
 284         u32 inb_count;
 285 
 286         
 287         dma_addr_t oub_phys_addr;
 288         struct fsl_re_hw_desc *oub_ring_virt_addr;
 289         u32 oub_count;
 290 };
 291 
 292 
 293 struct fsl_re_desc {
 294         struct dma_async_tx_descriptor async_tx;
 295         struct list_head node;
 296         struct fsl_re_hw_desc hwdesc;
 297         struct fsl_re_chan *re_chan;
 298 
 299         
 300         void *cf_addr;
 301         dma_addr_t cf_paddr;
 302 
 303         void *cdb_addr;
 304         dma_addr_t cdb_paddr;
 305         int status;
 306 };