| 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
 | | // SPDX-License-Identifier: GPL-2.0-or-later |  | /* |  |  * Copyright 2012-2013 Freescale Semiconductor, Inc. |  |  */ |  |   |  | #include <linux/of_address.h> |  | #include <linux/of_platform.h> |  | #include <linux/io.h> |  |   |  | #include <linux/irqchip.h> |  | #include <asm/mach/arch.h> |  | #include <asm/hardware/cache-l2x0.h> |  |   |  | #include "common.h" |  | #include "hardware.h" |  |   |  | #define MSCM_CPxCOUNT        0x00c |  | #define MSCM_CPxCFG1        0x014 |  |   |  | static void __init vf610_detect_cpu(void) |  | { |  |     struct device_node *np; |  |     u32 cpxcount, cpxcfg1; |  |     unsigned int cpu_type; |  |     void __iomem *mscm; |  |   |  |     np = of_find_compatible_node(NULL, NULL, "fsl,vf610-mscm-cpucfg"); |  |     if (WARN_ON(!np)) |  |         return; |  |   |  |     mscm = of_iomap(np, 0); |  |     of_node_put(np); |  |   |  |     if (WARN_ON(!mscm)) |  |         return; |  |   |  |     cpxcount = readl_relaxed(mscm + MSCM_CPxCOUNT); |  |     cpxcfg1  = readl_relaxed(mscm + MSCM_CPxCFG1); |  |   |  |     iounmap(mscm); |  |   |  |     cpu_type = cpxcount ? MXC_CPU_VF600 : MXC_CPU_VF500; |  |   |  |     if (cpxcfg1) |  |         cpu_type |= MXC_CPU_VFx10; |  |   |  |     mxc_set_cpu_type(cpu_type); |  | } |  |   |  | static void __init vf610_init_machine(void) |  | { |  |     vf610_detect_cpu(); |  |   |  |     of_platform_default_populate(NULL, NULL, NULL); |  | } |  |   |  | static const char * const vf610_dt_compat[] __initconst = { |  |     "fsl,vf500", |  |     "fsl,vf510", |  |     "fsl,vf600", |  |     "fsl,vf610", |  |     "fsl,vf610m4", |  |     NULL, |  | }; |  |   |  | DT_MACHINE_START(VYBRID_VF610, "Freescale Vybrid VF5xx/VF6xx (Device Tree)") |  |     .l2c_aux_val    = 0, |  |     .l2c_aux_mask    = ~0, |  |     .init_machine   = vf610_init_machine, |  |     .dt_compat    = vf610_dt_compat, |  | MACHINE_END | 
 |