diff options
author | R Sricharan <r.sricharan@ti.com> | 2012-04-19 08:12:19 -0400 |
---|---|---|
committer | Santosh Shilimkar <santosh.shilimkar@ti.com> | 2012-07-09 09:44:39 -0400 |
commit | b13e80a8bfe442406495a2fc9e7cbb79d33df48a (patch) | |
tree | 96158952517112c0fc77470af9e049a57453878d /arch/arm/mach-omap2/id.c | |
parent | b009366f285d03e69aeea5f8cc466782dd6f0004 (diff) |
ARM: OMAP5: id: Add cpu id for ES versions
Adding the OMAP5 ES1.0, 2.0 and OMAP5432 cpu revision
detection support.
Signed-off-by: R Sricharan <r.sricharan@ti.com>
Signed-off-by: Santosh Shilimkar <santosh.shilimkar@ti.com>
Diffstat (limited to 'arch/arm/mach-omap2/id.c')
-rw-r--r-- | arch/arm/mach-omap2/id.c | 42 |
1 files changed, 41 insertions, 1 deletions
diff --git a/arch/arm/mach-omap2/id.c b/arch/arm/mach-omap2/id.c index 37eb95aaf2f6..40373db649aa 100644 --- a/arch/arm/mach-omap2/id.c +++ b/arch/arm/mach-omap2/id.c | |||
@@ -50,6 +50,11 @@ int omap_type(void) | |||
50 | val = omap_ctrl_readl(OMAP343X_CONTROL_STATUS); | 50 | val = omap_ctrl_readl(OMAP343X_CONTROL_STATUS); |
51 | } else if (cpu_is_omap44xx()) { | 51 | } else if (cpu_is_omap44xx()) { |
52 | val = omap_ctrl_readl(OMAP4_CTRL_MODULE_CORE_STATUS); | 52 | val = omap_ctrl_readl(OMAP4_CTRL_MODULE_CORE_STATUS); |
53 | } else if (soc_is_omap54xx()) { | ||
54 | val = omap_ctrl_readl(OMAP5XXX_CONTROL_STATUS); | ||
55 | val &= OMAP5_DEVICETYPE_MASK; | ||
56 | val >>= 6; | ||
57 | goto out; | ||
53 | } else { | 58 | } else { |
54 | pr_err("Cannot detect omap type!\n"); | 59 | pr_err("Cannot detect omap type!\n"); |
55 | goto out; | 60 | goto out; |
@@ -100,7 +105,7 @@ static u16 tap_prod_id; | |||
100 | 105 | ||
101 | void omap_get_die_id(struct omap_die_id *odi) | 106 | void omap_get_die_id(struct omap_die_id *odi) |
102 | { | 107 | { |
103 | if (cpu_is_omap44xx()) { | 108 | if (cpu_is_omap44xx() || soc_is_omap54xx()) { |
104 | odi->id_0 = read_tap_reg(OMAP_TAP_DIE_ID_44XX_0); | 109 | odi->id_0 = read_tap_reg(OMAP_TAP_DIE_ID_44XX_0); |
105 | odi->id_1 = read_tap_reg(OMAP_TAP_DIE_ID_44XX_1); | 110 | odi->id_1 = read_tap_reg(OMAP_TAP_DIE_ID_44XX_1); |
106 | odi->id_2 = read_tap_reg(OMAP_TAP_DIE_ID_44XX_2); | 111 | odi->id_2 = read_tap_reg(OMAP_TAP_DIE_ID_44XX_2); |
@@ -513,6 +518,41 @@ void __init omap4xxx_check_revision(void) | |||
513 | ((omap_rev() >> 12) & 0xf), ((omap_rev() >> 8) & 0xf)); | 518 | ((omap_rev() >> 12) & 0xf), ((omap_rev() >> 8) & 0xf)); |
514 | } | 519 | } |
515 | 520 | ||
521 | void __init omap5xxx_check_revision(void) | ||
522 | { | ||
523 | u32 idcode; | ||
524 | u16 hawkeye; | ||
525 | u8 rev; | ||
526 | |||
527 | idcode = read_tap_reg(OMAP_TAP_IDCODE); | ||
528 | hawkeye = (idcode >> 12) & 0xffff; | ||
529 | rev = (idcode >> 28) & 0xff; | ||
530 | switch (hawkeye) { | ||
531 | case 0xb942: | ||
532 | switch (rev) { | ||
533 | case 0: | ||
534 | default: | ||
535 | omap_revision = OMAP5430_REV_ES1_0; | ||
536 | } | ||
537 | break; | ||
538 | |||
539 | case 0xb998: | ||
540 | switch (rev) { | ||
541 | case 0: | ||
542 | default: | ||
543 | omap_revision = OMAP5432_REV_ES1_0; | ||
544 | } | ||
545 | break; | ||
546 | |||
547 | default: | ||
548 | /* Unknown default to latest silicon rev as default*/ | ||
549 | omap_revision = OMAP5430_REV_ES1_0; | ||
550 | } | ||
551 | |||
552 | pr_info("OMAP%04x ES%d.0\n", | ||
553 | omap_rev() >> 16, ((omap_rev() >> 12) & 0xf)); | ||
554 | } | ||
555 | |||
516 | /* | 556 | /* |
517 | * Set up things for map_io and processor detection later on. Gets called | 557 | * Set up things for map_io and processor detection later on. Gets called |
518 | * pretty much first thing from board init. For multi-omap, this gets | 558 | * pretty much first thing from board init. For multi-omap, this gets |