Stephan Gerhold | 4f1170f | 2020-01-04 18:45:17 +0100 | [diff] [blame] | 1 | // SPDX-License-Identifier: GPL-2.0-or-later |
| 2 | /* |
| 3 | * Copyright (C) 2019 Stephan Gerhold <stephan@gerhold.net> |
| 4 | */ |
| 5 | |
Simon Glass | 9758973 | 2020-05-10 11:40:02 -0600 | [diff] [blame] | 6 | #include <init.h> |
Stephan Gerhold | 4f1170f | 2020-01-04 18:45:17 +0100 | [diff] [blame] | 7 | #include <asm/io.h> |
| 8 | |
| 9 | #define U8500_BOOTROM_BASE 0x90000000 |
| 10 | #define U8500_ASIC_ID_LOC_V2 (U8500_BOOTROM_BASE + 0x1DBF4) |
| 11 | |
| 12 | int print_cpuinfo(void) |
| 13 | { |
| 14 | /* Convert ASIC ID to display string, e.g. 0x8520A0 => DB8520 V1.0 */ |
| 15 | u32 asicid = readl(U8500_ASIC_ID_LOC_V2); |
| 16 | u32 cpu = (asicid >> 8) & 0xffff; |
| 17 | u32 rev = asicid & 0xff; |
| 18 | |
| 19 | /* 0xA0 => 0x10 (V1.0) */ |
| 20 | if (rev >= 0xa0) |
| 21 | rev -= 0x90; |
| 22 | |
| 23 | printf("CPU: ST-Ericsson DB%x V%d.%d\n", cpu, rev >> 4, rev & 0xf); |
| 24 | return 0; |
| 25 | } |