diff options
author | Sanjeev Premi <premi@ti.com> | 2009-11-22 13:10:58 -0500 |
---|---|---|
committer | Tony Lindgren <tony@atomide.com> | 2009-11-22 13:24:32 -0500 |
commit | 4cac60180649b83e094d4ea5c440229814488431 (patch) | |
tree | a5adbdcb0cd085d497727ba152407745ed06a607 /arch/arm/plat-omap/include | |
parent | f18af0a847f9e1a843bcb8ba69697ccbba2d03e9 (diff) |
omap3: AM35xx: Runtime detection of the device
Add support to detect AM3505/AM3517 devices at runtime.
Also updates the CPU names printed during boot.
Signed-off-by: Sanjeev Premi <premi@ti.com>
Signed-off-by: Tony Lindgren <tony@atomide.com>
Diffstat (limited to 'arch/arm/plat-omap/include')
-rw-r--r-- | arch/arm/plat-omap/include/plat/cpu.h | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/arch/arm/plat-omap/include/plat/cpu.h b/arch/arm/plat-omap/include/plat/cpu.h index 7babefce62e1..2e1789001dfe 100644 --- a/arch/arm/plat-omap/include/plat/cpu.h +++ b/arch/arm/plat-omap/include/plat/cpu.h | |||
@@ -284,6 +284,8 @@ IS_OMAP_SUBCLASS(363x, 0x363) | |||
284 | * cpu_is_omap2423(): True for OMAP2423 | 284 | * cpu_is_omap2423(): True for OMAP2423 |
285 | * cpu_is_omap2430(): True for OMAP2430 | 285 | * cpu_is_omap2430(): True for OMAP2430 |
286 | * cpu_is_omap3430(): True for OMAP3430 | 286 | * cpu_is_omap3430(): True for OMAP3430 |
287 | * cpu_is_omap3505(): True for OMAP3505 | ||
288 | * cpu_is_omap3517(): True for OMAP3517 | ||
287 | */ | 289 | */ |
288 | #define GET_OMAP_TYPE ((omap_rev() >> 16) & 0xffff) | 290 | #define GET_OMAP_TYPE ((omap_rev() >> 16) & 0xffff) |
289 | 291 | ||
@@ -307,6 +309,8 @@ IS_OMAP_TYPE(2422, 0x2422) | |||
307 | IS_OMAP_TYPE(2423, 0x2423) | 309 | IS_OMAP_TYPE(2423, 0x2423) |
308 | IS_OMAP_TYPE(2430, 0x2430) | 310 | IS_OMAP_TYPE(2430, 0x2430) |
309 | IS_OMAP_TYPE(3430, 0x3430) | 311 | IS_OMAP_TYPE(3430, 0x3430) |
312 | IS_OMAP_TYPE(3505, 0x3505) | ||
313 | IS_OMAP_TYPE(3517, 0x3517) | ||
310 | 314 | ||
311 | #define cpu_is_omap310() 0 | 315 | #define cpu_is_omap310() 0 |
312 | #define cpu_is_omap730() 0 | 316 | #define cpu_is_omap730() 0 |
@@ -325,6 +329,8 @@ IS_OMAP_TYPE(3430, 0x3430) | |||
325 | #define cpu_is_omap3515() 0 | 329 | #define cpu_is_omap3515() 0 |
326 | #define cpu_is_omap3525() 0 | 330 | #define cpu_is_omap3525() 0 |
327 | #define cpu_is_omap3530() 0 | 331 | #define cpu_is_omap3530() 0 |
332 | #define cpu_is_omap3505() 0 | ||
333 | #define cpu_is_omap3517() 0 | ||
328 | #define cpu_is_omap3430() 0 | 334 | #define cpu_is_omap3430() 0 |
329 | #define cpu_is_omap3630() 0 | 335 | #define cpu_is_omap3630() 0 |
330 | 336 | ||
@@ -380,6 +386,8 @@ IS_OMAP_TYPE(3430, 0x3430) | |||
380 | # undef cpu_is_omap3515 | 386 | # undef cpu_is_omap3515 |
381 | # undef cpu_is_omap3525 | 387 | # undef cpu_is_omap3525 |
382 | # undef cpu_is_omap3530 | 388 | # undef cpu_is_omap3530 |
389 | # undef cpu_is_omap3505 | ||
390 | # undef cpu_is_omap3517 | ||
383 | # define cpu_is_omap3430() is_omap3430() | 391 | # define cpu_is_omap3430() is_omap3430() |
384 | # define cpu_is_omap3503() (cpu_is_omap3430() && \ | 392 | # define cpu_is_omap3503() (cpu_is_omap3430() && \ |
385 | (!omap3_has_iva()) && \ | 393 | (!omap3_has_iva()) && \ |
@@ -391,6 +399,8 @@ IS_OMAP_TYPE(3430, 0x3430) | |||
391 | (omap3_has_sgx()) && \ | 399 | (omap3_has_sgx()) && \ |
392 | (!omap3_has_iva())) | 400 | (!omap3_has_iva())) |
393 | # define cpu_is_omap3530() (cpu_is_omap3430()) | 401 | # define cpu_is_omap3530() (cpu_is_omap3430()) |
402 | # define cpu_is_omap3505() is_omap3505() | ||
403 | # define cpu_is_omap3517() is_omap3517() | ||
394 | # undef cpu_is_omap3630 | 404 | # undef cpu_is_omap3630 |
395 | # define cpu_is_omap3630() is_omap363x() | 405 | # define cpu_is_omap3630() is_omap363x() |
396 | #endif | 406 | #endif |
@@ -430,6 +440,8 @@ IS_OMAP_TYPE(3430, 0x3430) | |||
430 | #define OMAP3515_REV(v) (OMAP35XX_CLASS | (0x3515 << 16) | (v << 12)) | 440 | #define OMAP3515_REV(v) (OMAP35XX_CLASS | (0x3515 << 16) | (v << 12)) |
431 | #define OMAP3525_REV(v) (OMAP35XX_CLASS | (0x3525 << 16) | (v << 12)) | 441 | #define OMAP3525_REV(v) (OMAP35XX_CLASS | (0x3525 << 16) | (v << 12)) |
432 | #define OMAP3530_REV(v) (OMAP35XX_CLASS | (0x3530 << 16) | (v << 12)) | 442 | #define OMAP3530_REV(v) (OMAP35XX_CLASS | (0x3530 << 16) | (v << 12)) |
443 | #define OMAP3505_REV(v) (OMAP35XX_CLASS | (0x3505 << 16) | (v << 12)) | ||
444 | #define OMAP3517_REV(v) (OMAP35XX_CLASS | (0x3517 << 16) | (v << 12)) | ||
433 | 445 | ||
434 | #define OMAP443X_CLASS 0x44300034 | 446 | #define OMAP443X_CLASS 0x44300034 |
435 | 447 | ||