| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
 | | /* |  |  * (C) Copyright 2012 Nobuhiro Iwamatsu <nobuhiro.iwamatsu.yj@renesas.com> |  |  * (C) Copyright 2012 Renesas Solutions Corp. |  |  * |  |  * SPDX-License-Identifier:    GPL-2.0+ |  |  */ |  | #include <common.h> |  | #include <asm/io.h> |  |   |  | #ifdef CONFIG_ARCH_CPU_INIT |  | int arch_cpu_init(void) |  | { |  |     icache_enable(); |  |     return 0; |  | } |  | #endif |  |   |  | #ifndef CONFIG_SYS_DCACHE_OFF |  | void enable_caches(void) |  | { |  |     dcache_enable(); |  | } |  | #endif |  |   |  | #ifdef CONFIG_DISPLAY_CPUINFO |  | static u32 __rmobile_get_cpu_type(void) |  | { |  |     return 0x0; |  | } |  | u32 rmobile_get_cpu_type(void) |  |         __attribute__((weak, alias("__rmobile_get_cpu_type"))); |  |   |  | static u32 __rmobile_get_cpu_rev_integer(void) |  | { |  |     return 0; |  | } |  | u32 rmobile_get_cpu_rev_integer(void) |  |         __attribute__((weak, alias("__rmobile_get_cpu_rev_integer"))); |  |   |  | static u32 __rmobile_get_cpu_rev_fraction(void) |  | { |  |     return 0; |  | } |  | u32 rmobile_get_cpu_rev_fraction(void) |  |         __attribute__((weak, alias("__rmobile_get_cpu_rev_fraction"))); |  |   |  | /* CPU infomation table */ |  | static const struct { |  |     u16 cpu_type; |  |     u8 cpu_name[10]; |  | } rmobile_cpuinfo[] = { |  |     { 0x37, "SH73A0" }, |  |     { 0x40, "R8A7740" }, |  |     { 0x45, "R8A7790" }, |  |     { 0x47, "R8A7791" }, |  |     { 0x4A, "R8A7792" }, |  |     { 0x4B, "R8A7793" }, |  |     { 0x4C, "R8A7794" }, |  |     { 0x4F, "R8A7795" }, |  |     { 0x52, "R8A7796" }, |  |     { 0x0, "CPU" }, |  | }; |  |   |  | int print_cpuinfo(void) |  | { |  |     int i = 0; |  |     u32 cpu_type = rmobile_get_cpu_type(); |  |     for (; i < ARRAY_SIZE(rmobile_cpuinfo); i++) { |  |         if (rmobile_cpuinfo[i].cpu_type == cpu_type) { |  |             printf("CPU: Renesas Electronics %s rev %d.%d\n", |  |                    rmobile_cpuinfo[i].cpu_name, |  |                    rmobile_get_cpu_rev_integer(), |  |                    rmobile_get_cpu_rev_fraction()); |  |             break; |  |         } |  |     } |  |     return 0; |  | } |  | #endif /* CONFIG_DISPLAY_CPUINFO */ | 
 |