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
|
|