31
31
#include <linux/mmc/sdio.h>
32
32
#include <linux/mmc/slot-gpio.h>
33
33
34
+ #include "cqhci.h"
35
+
34
36
#define MAX_BD_NUM 1024
35
37
36
38
/*--------------------------------------------------------------------------*/
152
154
#define MSDC_INT_DMA_BDCSERR (0x1 << 17) /* W1C */
153
155
#define MSDC_INT_DMA_GPDCSERR (0x1 << 18) /* W1C */
154
156
#define MSDC_INT_DMA_PROTECT (0x1 << 19) /* W1C */
157
+ #define MSDC_INT_CMDQ (0x1 << 28) /* W1C */
155
158
156
159
/* MSDC_INTEN mask */
157
160
#define MSDC_INTEN_MMCIRQ (0x1 << 0) /* RW */
182
185
/* SDC_CFG mask */
183
186
#define SDC_CFG_SDIOINTWKUP (0x1 << 0) /* RW */
184
187
#define SDC_CFG_INSWKUP (0x1 << 1) /* RW */
188
+ #define SDC_CFG_WRDTOC (0x1fff << 2) /* RW */
185
189
#define SDC_CFG_BUSWIDTH (0x3 << 16) /* RW */
186
190
#define SDC_CFG_SDIO (0x1 << 19) /* RW */
187
191
#define SDC_CFG_SDIOIDE (0x1 << 20) /* RW */
230
234
#define MSDC_PATCH_BIT_DECRCTMO (0x1 << 30) /* RW */
231
235
232
236
#define MSDC_PATCH_BIT1_CMDTA (0x7 << 3) /* RW */
237
+ #define MSDC_PB1_BUSY_CHECK_SEL (0x1 << 7) /* RW */
233
238
#define MSDC_PATCH_BIT1_STOP_DLY (0xf << 8) /* RW */
234
239
235
240
#define MSDC_PATCH_BIT2_CFGRESP (0x1 << 15) /* RW */
@@ -431,9 +436,11 @@ struct msdc_host {
431
436
/* cmd response sample selection for HS400 */
432
437
bool hs400_mode ; /* current eMMC will run at hs400 mode */
433
438
bool internal_cd ; /* Use internal card-detect logic */
439
+ bool cqhci ; /* support eMMC hw cmdq */
434
440
struct msdc_save_para save_para ; /* used when gate HCLK */
435
441
struct msdc_tune_para def_tune_para ; /* default tune setting */
436
442
struct msdc_tune_para saved_tune_para ; /* tune result of CMD21/CMD19 */
443
+ struct cqhci_host * cq_host ;
437
444
};
438
445
439
446
static const struct mtk_mmc_compatible mt8135_compat = {
@@ -764,6 +771,15 @@ static void msdc_set_timeout(struct msdc_host *host, u64 ns, u64 clks)
764
771
(u32 )(timeout > 255 ? 255 : timeout ));
765
772
}
766
773
774
+ static void msdc_set_busy_timeout (struct msdc_host * host , u64 ns , u64 clks )
775
+ {
776
+ u64 timeout ;
777
+
778
+ timeout = msdc_timeout_cal (host , ns , clks );
779
+ sdr_set_field (host -> base + SDC_CFG , SDC_CFG_WRDTOC ,
780
+ (u32 )(timeout > 8191 ? 8191 : timeout ));
781
+ }
782
+
767
783
static void msdc_gate_clock (struct msdc_host * host )
768
784
{
769
785
clk_disable_unprepare (host -> src_clk_cg );
@@ -1480,6 +1496,34 @@ static void msdc_enable_sdio_irq(struct mmc_host *mmc, int enb)
1480
1496
pm_runtime_put_noidle (host -> dev );
1481
1497
}
1482
1498
1499
+ static irqreturn_t msdc_cmdq_irq (struct msdc_host * host , u32 intsts )
1500
+ {
1501
+ int cmd_err = 0 , dat_err = 0 ;
1502
+
1503
+ if (intsts & MSDC_INT_RSPCRCERR ) {
1504
+ cmd_err = - EILSEQ ;
1505
+ dev_err (host -> dev , "%s: CMD CRC ERR" , __func__ );
1506
+ } else if (intsts & MSDC_INT_CMDTMO ) {
1507
+ cmd_err = - ETIMEDOUT ;
1508
+ dev_err (host -> dev , "%s: CMD TIMEOUT ERR" , __func__ );
1509
+ }
1510
+
1511
+ if (intsts & MSDC_INT_DATCRCERR ) {
1512
+ dat_err = - EILSEQ ;
1513
+ dev_err (host -> dev , "%s: DATA CRC ERR" , __func__ );
1514
+ } else if (intsts & MSDC_INT_DATTMO ) {
1515
+ dat_err = - ETIMEDOUT ;
1516
+ dev_err (host -> dev , "%s: DATA TIMEOUT ERR" , __func__ );
1517
+ }
1518
+
1519
+ if (cmd_err || dat_err ) {
1520
+ dev_err (host -> dev , "cmd_err = %d, dat_err =%d, intsts = 0x%x" ,
1521
+ cmd_err , dat_err , intsts );
1522
+ }
1523
+
1524
+ return cqhci_irq (host -> mmc , 0 , cmd_err , dat_err );
1525
+ }
1526
+
1483
1527
static irqreturn_t msdc_irq (int irq , void * dev_id )
1484
1528
{
1485
1529
struct msdc_host * host = (struct msdc_host * ) dev_id ;
@@ -1516,6 +1560,14 @@ static irqreturn_t msdc_irq(int irq, void *dev_id)
1516
1560
if (!(events & (event_mask & ~MSDC_INT_SDIOIRQ )))
1517
1561
break ;
1518
1562
1563
+ if ((host -> mmc -> caps2 & MMC_CAP2_CQE ) &&
1564
+ (events & MSDC_INT_CMDQ )) {
1565
+ msdc_cmdq_irq (host , events );
1566
+ /* clear interrupts */
1567
+ writel (events , host -> base + MSDC_INT );
1568
+ return IRQ_HANDLED ;
1569
+ }
1570
+
1519
1571
if (!mrq ) {
1520
1572
dev_err (host -> dev ,
1521
1573
"%s: MRQ=NULL; events=%08X; event_mask=%08X\n" ,
@@ -2200,6 +2252,36 @@ static int msdc_get_cd(struct mmc_host *mmc)
2200
2252
return !val ;
2201
2253
}
2202
2254
2255
+ static void msdc_cqe_enable (struct mmc_host * mmc )
2256
+ {
2257
+ struct msdc_host * host = mmc_priv (mmc );
2258
+
2259
+ /* enable cmdq irq */
2260
+ writel (MSDC_INT_CMDQ , host -> base + MSDC_INTEN );
2261
+ /* enable busy check */
2262
+ sdr_set_bits (host -> base + MSDC_PATCH_BIT1 , MSDC_PB1_BUSY_CHECK_SEL );
2263
+ /* default write data / busy timeout 20s */
2264
+ msdc_set_busy_timeout (host , 20 * 1000000000ULL , 0 );
2265
+ /* default read data timeout 1s */
2266
+ msdc_set_timeout (host , 1000000000ULL , 0 );
2267
+ }
2268
+
2269
+ void msdc_cqe_disable (struct mmc_host * mmc , bool recovery )
2270
+ {
2271
+ struct msdc_host * host = mmc_priv (mmc );
2272
+
2273
+ /* disable cmdq irq */
2274
+ sdr_clr_bits (host -> base + MSDC_INTEN , MSDC_INT_CMDQ );
2275
+ /* disable busy check */
2276
+ sdr_clr_bits (host -> base + MSDC_PATCH_BIT1 , MSDC_PB1_BUSY_CHECK_SEL );
2277
+
2278
+ if (recovery ) {
2279
+ sdr_set_field (host -> base + MSDC_DMA_CTRL ,
2280
+ MSDC_DMA_CTRL_STOP , 1 );
2281
+ msdc_reset_hw (host );
2282
+ }
2283
+ }
2284
+
2203
2285
static const struct mmc_host_ops mt_msdc_ops = {
2204
2286
.post_req = msdc_post_req ,
2205
2287
.pre_req = msdc_pre_req ,
@@ -2216,6 +2298,11 @@ static const struct mmc_host_ops mt_msdc_ops = {
2216
2298
.hw_reset = msdc_hw_reset ,
2217
2299
};
2218
2300
2301
+ static const struct cqhci_host_ops msdc_cmdq_ops = {
2302
+ .enable = msdc_cqe_enable ,
2303
+ .disable = msdc_cqe_disable ,
2304
+ };
2305
+
2219
2306
static void msdc_of_property_parse (struct platform_device * pdev ,
2220
2307
struct msdc_host * host )
2221
2308
{
@@ -2236,6 +2323,12 @@ static void msdc_of_property_parse(struct platform_device *pdev,
2236
2323
host -> hs400_cmd_resp_sel_rising = true;
2237
2324
else
2238
2325
host -> hs400_cmd_resp_sel_rising = false;
2326
+
2327
+ if (of_property_read_bool (pdev -> dev .of_node ,
2328
+ "supports-cqe" ))
2329
+ host -> cqhci = true;
2330
+ else
2331
+ host -> cqhci = false;
2239
2332
}
2240
2333
2241
2334
static int msdc_drv_probe (struct platform_device * pdev )
@@ -2351,6 +2444,8 @@ static int msdc_drv_probe(struct platform_device *pdev)
2351
2444
mmc -> caps2 |= MMC_CAP2_SDIO_IRQ_NOTHREAD ;
2352
2445
2353
2446
mmc -> caps |= MMC_CAP_CMD23 ;
2447
+ if (host -> cqhci )
2448
+ mmc -> caps2 |= MMC_CAP2_CQE | MMC_CAP2_CQE_DCMD ;
2354
2449
/* MMC core transfer sizes tunable parameters */
2355
2450
mmc -> max_segs = MAX_BD_NUM ;
2356
2451
if (host -> dev_comp -> support_64g )
@@ -2366,6 +2461,26 @@ static int msdc_drv_probe(struct platform_device *pdev)
2366
2461
host -> dma_mask = DMA_BIT_MASK (32 );
2367
2462
mmc_dev (mmc )-> dma_mask = & host -> dma_mask ;
2368
2463
2464
+ if (mmc -> caps2 & MMC_CAP2_CQE ) {
2465
+ host -> cq_host = devm_kzalloc (host -> mmc -> parent ,
2466
+ sizeof (* host -> cq_host ),
2467
+ GFP_KERNEL );
2468
+ if (!host -> cq_host ) {
2469
+ ret = - ENOMEM ;
2470
+ goto host_free ;
2471
+ }
2472
+ host -> cq_host -> caps |= CQHCI_TASK_DESC_SZ_128 ;
2473
+ host -> cq_host -> mmio = host -> base + 0x800 ;
2474
+ host -> cq_host -> ops = & msdc_cmdq_ops ;
2475
+ ret = cqhci_init (host -> cq_host , mmc , true);
2476
+ if (ret )
2477
+ goto host_free ;
2478
+ mmc -> max_segs = 128 ;
2479
+ /* cqhci 16bit length */
2480
+ /* 0 size, means 65536 so we don't have to -1 here */
2481
+ mmc -> max_seg_size = 64 * 1024 ;
2482
+ }
2483
+
2369
2484
host -> timeout_clks = 3 * 1048576 ;
2370
2485
host -> dma .gpd = dma_alloc_coherent (& pdev -> dev ,
2371
2486
2 * sizeof (struct mt_gpdma_desc ),
0 commit comments