aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/dma/ste_dma40.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/dma/ste_dma40.c')
-rw-r--r--drivers/dma/ste_dma40.c72
1 files changed, 26 insertions, 46 deletions
diff --git a/drivers/dma/ste_dma40.c b/drivers/dma/ste_dma40.c
index 35b078d688d5..2797f64e5e48 100644
--- a/drivers/dma/ste_dma40.c
+++ b/drivers/dma/ste_dma40.c
@@ -13,6 +13,7 @@
13#include <linux/clk.h> 13#include <linux/clk.h>
14#include <linux/delay.h> 14#include <linux/delay.h>
15#include <linux/err.h> 15#include <linux/err.h>
16#include <linux/amba/bus.h>
16 17
17#include <plat/ste_dma40.h> 18#include <plat/ste_dma40.h>
18 19
@@ -44,9 +45,6 @@
44#define D40_ALLOC_PHY (1 << 30) 45#define D40_ALLOC_PHY (1 << 30)
45#define D40_ALLOC_LOG_FREE 0 46#define D40_ALLOC_LOG_FREE 0
46 47
47/* Hardware designer of the block */
48#define D40_HW_DESIGNER 0x8
49
50/** 48/**
51 * enum 40_command - The different commands and/or statuses. 49 * enum 40_command - The different commands and/or statuses.
52 * 50 *
@@ -2525,25 +2523,6 @@ static int __init d40_phy_res_init(struct d40_base *base)
2525 2523
2526static struct d40_base * __init d40_hw_detect_init(struct platform_device *pdev) 2524static struct d40_base * __init d40_hw_detect_init(struct platform_device *pdev)
2527{ 2525{
2528 static const struct d40_reg_val dma_id_regs[] = {
2529 /* Peripheral Id */
2530 { .reg = D40_DREG_PERIPHID0, .val = 0x0040},
2531 { .reg = D40_DREG_PERIPHID1, .val = 0x0000},
2532 /*
2533 * D40_DREG_PERIPHID2 Depends on HW revision:
2534 * DB8500ed has 0x0008,
2535 * ? has 0x0018,
2536 * DB8500v1 has 0x0028
2537 * DB8500v2 has 0x0038
2538 */
2539 { .reg = D40_DREG_PERIPHID3, .val = 0x0000},
2540
2541 /* PCell Id */
2542 { .reg = D40_DREG_CELLID0, .val = 0x000d},
2543 { .reg = D40_DREG_CELLID1, .val = 0x00f0},
2544 { .reg = D40_DREG_CELLID2, .val = 0x0005},
2545 { .reg = D40_DREG_CELLID3, .val = 0x00b1}
2546 };
2547 struct stedma40_platform_data *plat_data; 2526 struct stedma40_platform_data *plat_data;
2548 struct clk *clk = NULL; 2527 struct clk *clk = NULL;
2549 void __iomem *virtbase = NULL; 2528 void __iomem *virtbase = NULL;
@@ -2552,8 +2531,9 @@ static struct d40_base * __init d40_hw_detect_init(struct platform_device *pdev)
2552 int num_log_chans = 0; 2531 int num_log_chans = 0;
2553 int num_phy_chans; 2532 int num_phy_chans;
2554 int i; 2533 int i;
2555 u32 val; 2534 u32 pid;
2556 u32 rev; 2535 u32 cid;
2536 u8 rev;
2557 2537
2558 clk = clk_get(&pdev->dev, NULL); 2538 clk = clk_get(&pdev->dev, NULL);
2559 2539
@@ -2577,32 +2557,32 @@ static struct d40_base * __init d40_hw_detect_init(struct platform_device *pdev)
2577 if (!virtbase) 2557 if (!virtbase)
2578 goto failure; 2558 goto failure;
2579 2559
2580 /* HW version check */ 2560 /* This is just a regular AMBA PrimeCell ID actually */
2581 for (i = 0; i < ARRAY_SIZE(dma_id_regs); i++) { 2561 for (pid = 0, i = 0; i < 4; i++)
2582 if (dma_id_regs[i].val != 2562 pid |= (readl(virtbase + resource_size(res) - 0x20 + 4 * i)
2583 readl(virtbase + dma_id_regs[i].reg)) { 2563 & 255) << (i * 8);
2584 d40_err(&pdev->dev, 2564 for (cid = 0, i = 0; i < 4; i++)
2585 "Unknown hardware! Expected 0x%x at 0x%x but got 0x%x\n", 2565 cid |= (readl(virtbase + resource_size(res) - 0x10 + 4 * i)
2586 dma_id_regs[i].val, 2566 & 255) << (i * 8);
2587 dma_id_regs[i].reg,
2588 readl(virtbase + dma_id_regs[i].reg));
2589 goto failure;
2590 }
2591 }
2592
2593 /* Get silicon revision and designer */
2594 val = readl(virtbase + D40_DREG_PERIPHID2);
2595 2567
2596 if ((val & D40_DREG_PERIPHID2_DESIGNER_MASK) != 2568 if (cid != AMBA_CID) {
2597 D40_HW_DESIGNER) { 2569 d40_err(&pdev->dev, "Unknown hardware! No PrimeCell ID\n");
2570 goto failure;
2571 }
2572 if (AMBA_MANF_BITS(pid) != AMBA_VENDOR_ST) {
2598 d40_err(&pdev->dev, "Unknown designer! Got %x wanted %x\n", 2573 d40_err(&pdev->dev, "Unknown designer! Got %x wanted %x\n",
2599 val & D40_DREG_PERIPHID2_DESIGNER_MASK, 2574 AMBA_MANF_BITS(pid),
2600 D40_HW_DESIGNER); 2575 AMBA_VENDOR_ST);
2601 goto failure; 2576 goto failure;
2602 } 2577 }
2603 2578 /*
2604 rev = (val & D40_DREG_PERIPHID2_REV_MASK) >> 2579 * HW revision:
2605 D40_DREG_PERIPHID2_REV_POS; 2580 * DB8500ed has revision 0
2581 * ? has revision 1
2582 * DB8500v1 has revision 2
2583 * DB8500v2 has revision 3
2584 */
2585 rev = AMBA_REV_BITS(pid);
2606 2586
2607 /* The number of physical channels on this HW */ 2587 /* The number of physical channels on this HW */
2608 num_phy_chans = 4 * (readl(virtbase + D40_DREG_ICFG) & 0x7) + 4; 2588 num_phy_chans = 4 * (readl(virtbase + D40_DREG_ICFG) & 0x7) + 4;