diff options
author | Paul Walmsley <paul@pwsan.com> | 2011-09-13 21:52:13 -0400 |
---|---|---|
committer | Paul Walmsley <paul@pwsan.com> | 2011-09-13 21:52:13 -0400 |
commit | 1f1b0353aa3ba5dfc35641452484ea4158ee3c9c (patch) | |
tree | f8673543eeb41f47ef7ac4dba736bf538a726ca3 /arch/arm/mach-omap2 | |
parent | 876355014ce3a7ba8ca299522b215365b4a3fb61 (diff) |
OMAP3: id: remove identification codes that only correspond to marketing names
The OMAP3505/AM3505 appears to be based on the same silicon as the
OMAP3517/AM3517, with some features disabled via eFuse bits. Follow
the same practice as OMAP3430 and identify these devices internally as
part of the OMAP3517/AM3517 family.
The OMAP3503/3515/3525/3530 chips appear to be based on the same silicon
as the OMAP3430, with some features disabled via eFuse bits. Identify
these devices internally as part of the OMAP3430 family.
Remove the old OMAP35XX_CLASS, which actually covered two very different
chip families. The OMAP3503/3515/3525/3530 chips will now be covered by
OMAP343X_CLASS, since the silicon appears to be identical. For the
OMAP3517/AM3517 family, create a new class, OMAP3517_CLASS.
Thanks to Tony Lindgren <tony@atomide.com> for some help with the second
revision of this patch.
Signed-off-by: Paul Walmsley <paul@pwsan.com>
Cc: Sanjeev Premi <premi@ti.com>
Cc: Tony Lindgren <tony@atomide.com>
Tested-by: Igor Grinberg <grinberg@compulab.co.il>
Tested-by: Abhilash Koyamangalath <abhilash.kv@ti.com>
Diffstat (limited to 'arch/arm/mach-omap2')
-rw-r--r-- | arch/arm/mach-omap2/clock3xxx_data.c | 11 | ||||
-rw-r--r-- | arch/arm/mach-omap2/id.c | 19 |
2 files changed, 17 insertions, 13 deletions
diff --git a/arch/arm/mach-omap2/clock3xxx_data.c b/arch/arm/mach-omap2/clock3xxx_data.c index b9b844683147..dadb8c6c0115 100644 --- a/arch/arm/mach-omap2/clock3xxx_data.c +++ b/arch/arm/mach-omap2/clock3xxx_data.c | |||
@@ -3472,7 +3472,16 @@ int __init omap3xxx_clk_init(void) | |||
3472 | struct omap_clk *c; | 3472 | struct omap_clk *c; |
3473 | u32 cpu_clkflg = 0; | 3473 | u32 cpu_clkflg = 0; |
3474 | 3474 | ||
3475 | if (cpu_is_omap3517()) { | 3475 | /* |
3476 | * 3505 must be tested before 3517, since 3517 returns true | ||
3477 | * for both AM3517 chips and AM3517 family chips, which | ||
3478 | * includes 3505. Unfortunately there's no obvious family | ||
3479 | * test for 3517/3505 :-( | ||
3480 | */ | ||
3481 | if (cpu_is_omap3505()) { | ||
3482 | cpu_mask = RATE_IN_34XX; | ||
3483 | cpu_clkflg = CK_3505; | ||
3484 | } else if (cpu_is_omap3517()) { | ||
3476 | cpu_mask = RATE_IN_34XX; | 3485 | cpu_mask = RATE_IN_34XX; |
3477 | cpu_clkflg = CK_3517; | 3486 | cpu_clkflg = CK_3517; |
3478 | } else if (cpu_is_omap3505()) { | 3487 | } else if (cpu_is_omap3505()) { |
diff --git a/arch/arm/mach-omap2/id.c b/arch/arm/mach-omap2/id.c index 37efb8696927..3f3f998c89e0 100644 --- a/arch/arm/mach-omap2/id.c +++ b/arch/arm/mach-omap2/id.c | |||
@@ -304,14 +304,15 @@ static void __init omap3_check_revision(void) | |||
304 | } | 304 | } |
305 | break; | 305 | break; |
306 | case 0xb868: | 306 | case 0xb868: |
307 | /* Handle OMAP35xx/AM35xx devices | 307 | /* |
308 | * Handle OMAP/AM 3505/3517 devices | ||
308 | * | 309 | * |
309 | * Set the device to be OMAP3505 here. Actual device | 310 | * Set the device to be OMAP3517 here. Actual device |
310 | * is identified later based on the features. | 311 | * is identified later based on the features. |
311 | * | 312 | * |
312 | * REVISIT: AM3505/AM3517 should have their own CHIP_IS | 313 | * REVISIT: AM3505/AM3517 should have their own CHIP_IS |
313 | */ | 314 | */ |
314 | omap_revision = OMAP3505_REV(rev); | 315 | omap_revision = OMAP3517_REV(rev); |
315 | omap_chip.oc |= CHIP_IS_OMAP3430ES3_1; | 316 | omap_chip.oc |= CHIP_IS_OMAP3430ES3_1; |
316 | break; | 317 | break; |
317 | case 0xb891: | 318 | case 0xb891: |
@@ -438,30 +439,24 @@ static void __init omap3_cpuinfo(void) | |||
438 | */ | 439 | */ |
439 | if (cpu_is_omap3630()) { | 440 | if (cpu_is_omap3630()) { |
440 | strcpy(cpu_name, "OMAP3630"); | 441 | strcpy(cpu_name, "OMAP3630"); |
441 | } else if (cpu_is_omap3505()) { | 442 | } else if (cpu_is_omap3517()) { |
442 | /* | 443 | /* |
443 | * AM35xx devices | 444 | * AM35xx devices |
444 | */ | 445 | */ |
445 | if (omap3_has_sgx()) { | 446 | if (omap3_has_sgx()) |
446 | omap_revision = OMAP3517_REV(rev); | ||
447 | strcpy(cpu_name, "AM3517"); | 447 | strcpy(cpu_name, "AM3517"); |
448 | } else { | 448 | else |
449 | /* Already set in omap3_check_revision() */ | ||
450 | strcpy(cpu_name, "AM3505"); | 449 | strcpy(cpu_name, "AM3505"); |
451 | } | ||
452 | } else if (cpu_is_ti816x()) { | 450 | } else if (cpu_is_ti816x()) { |
453 | strcpy(cpu_name, "TI816X"); | 451 | strcpy(cpu_name, "TI816X"); |
454 | } else if (omap3_has_iva() && omap3_has_sgx()) { | 452 | } else if (omap3_has_iva() && omap3_has_sgx()) { |
455 | /* OMAP3430, OMAP3525, OMAP3515, OMAP3503 devices */ | 453 | /* OMAP3430, OMAP3525, OMAP3515, OMAP3503 devices */ |
456 | strcpy(cpu_name, "OMAP3430/3530"); | 454 | strcpy(cpu_name, "OMAP3430/3530"); |
457 | } else if (omap3_has_iva()) { | 455 | } else if (omap3_has_iva()) { |
458 | omap_revision = OMAP3525_REV(rev); | ||
459 | strcpy(cpu_name, "OMAP3525"); | 456 | strcpy(cpu_name, "OMAP3525"); |
460 | } else if (omap3_has_sgx()) { | 457 | } else if (omap3_has_sgx()) { |
461 | omap_revision = OMAP3515_REV(rev); | ||
462 | strcpy(cpu_name, "OMAP3515"); | 458 | strcpy(cpu_name, "OMAP3515"); |
463 | } else { | 459 | } else { |
464 | omap_revision = OMAP3503_REV(rev); | ||
465 | strcpy(cpu_name, "OMAP3503"); | 460 | strcpy(cpu_name, "OMAP3503"); |
466 | } | 461 | } |
467 | 462 | ||