]> git.sur5r.net Git - u-boot/blob - arch/arm/mach-uniphier/cpu_info.c
ARM: UniPhier: replace <asm/io.h> with <linux/io.h>
[u-boot] / arch / arm / mach-uniphier / cpu_info.c
1 /*
2  * Copyright (C) 2013-2015 Masahiro Yamada <yamada.masahiro@socionext.com>
3  *
4  * SPDX-License-Identifier:     GPL-2.0+
5  */
6
7 #include <common.h>
8 #include <linux/io.h>
9 #include <mach/sg-regs.h>
10
11 int print_cpuinfo(void)
12 {
13         u32 revision, type, model, rev, required_model = 1, required_rev = 1;
14
15         revision = readl(SG_REVISION);
16         type = (revision & SG_REVISION_TYPE_MASK) >> SG_REVISION_TYPE_SHIFT;
17         model = (revision & SG_REVISION_MODEL_MASK) >> SG_REVISION_MODEL_SHIFT;
18         rev = (revision & SG_REVISION_REV_MASK) >> SG_REVISION_REV_SHIFT;
19
20         puts("CPU:   ");
21
22         switch (type) {
23         case 0x25:
24                 puts("PH1-sLD3 (MN2WS0220)");
25                 required_model = 2;
26                 break;
27         case 0x26:
28                 puts("PH1-LD4 (MN2WS0250)");
29                 required_rev = 2;
30                 break;
31         case 0x28:
32                 puts("PH1-Pro4 (MN2WS0230)");
33                 break;
34         case 0x29:
35                 puts("PH1-sLD8 (MN2WS0270)");
36                 break;
37         default:
38                 printf("Unknown Processor ID (0x%x)\n", revision);
39                 return -1;
40         }
41
42         if (model > 1)
43                 printf(" model %d", model);
44
45         printf(" (rev. %d)\n", rev);
46
47         if (model < required_model) {
48                 printf("Sorry, this model is not supported.\n");
49                 printf("Required model is %d.", required_model);
50                 return -1;
51         } else if (rev < required_rev) {
52                 printf("Sorry, this revision is not supported.\n");
53                 printf("Required revision is %d.", required_rev);
54                 return -1;
55         }
56
57         return 0;
58 }