hc
2024-08-09 29cd05754af6ef0435c257049290243810d81e26
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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
/*
 * Device Tree Source for IBM Embedded PPC 476 Platform
 *
 * Copyright 2010 Torez Smith, IBM Corporation.
 *
 * Based on earlier code:
 *     Copyright (c) 2006, 2007 IBM Corp.
 *     Josh Boyer <jwboyer@linux.vnet.ibm.com>, David Gibson <dwg@au1.ibm.com>
 *
 * This file is licensed under the terms of the GNU General Public
 * License version 2.  This program is licensed "as is" without
 * any warranty of any kind, whether express or implied.
 */
 
/dts-v1/;
 
/memreserve/ 0x01f00000 0x00100000;
 
/ {
   #address-cells = <2>;
   #size-cells = <1>;
   model = "ibm,iss-4xx";
   compatible = "ibm,iss-4xx";
   dcr-parent = <&{/cpus/cpu@0}>;
 
   aliases {
       serial0 = &UART0;
   };
 
   cpus {
       #address-cells = <1>;
       #size-cells = <0>;
 
       cpu@0 {
           device_type = "cpu";
           model = "PowerPC,4xx"; // real CPU changed in sim
           reg = <0>;
           clock-frequency = <100000000>; // 100Mhz :-)
           timebase-frequency = <100000000>;
           i-cache-line-size = <32>;
           d-cache-line-size = <32>;
           i-cache-size = <32768>;
           d-cache-size = <32768>;
           dcr-controller;
           dcr-access-method = "native";
           status = "okay";
       };
       cpu@1 {
           device_type = "cpu";
           model = "PowerPC,4xx"; // real CPU changed in sim
           reg = <1>;
           clock-frequency = <100000000>; // 100Mhz :-)
           timebase-frequency = <100000000>;
           i-cache-line-size = <32>;
           d-cache-line-size = <32>;
           i-cache-size = <32768>;
           d-cache-size = <32768>;
           dcr-controller;
           dcr-access-method = "native";
           status = "disabled";
           enable-method = "spin-table";
           cpu-release-addr = <0 0x01f00100>;
       };
       cpu@2 {
           device_type = "cpu";
           model = "PowerPC,4xx"; // real CPU changed in sim
           reg = <2>;
           clock-frequency = <100000000>; // 100Mhz :-)
           timebase-frequency = <100000000>;
           i-cache-line-size = <32>;
           d-cache-line-size = <32>;
           i-cache-size = <32768>;
           d-cache-size = <32768>;
           dcr-controller;
           dcr-access-method = "native";
           status = "disabled";
           enable-method = "spin-table";
           cpu-release-addr = <0 0x01f00200>;
       };
       cpu@3 {
           device_type = "cpu";
           model = "PowerPC,4xx"; // real CPU changed in sim
           reg = <3>;
           clock-frequency = <100000000>; // 100Mhz :-)
           timebase-frequency = <100000000>;
           i-cache-line-size = <32>;
           d-cache-line-size = <32>;
           i-cache-size = <32768>;
           d-cache-size = <32768>;
           dcr-controller;
           dcr-access-method = "native";
           status = "disabled";
           enable-method = "spin-table";
           cpu-release-addr = <0 0x01f00300>;
       };
   };
 
   memory {
       device_type = "memory";
       reg =  <0x00000000 0x00000000 0x00000000>; // Filled in by zImage
 
   };
 
   MPIC: interrupt-controller {
       compatible = "chrp,open-pic";
       interrupt-controller;
       dcr-reg = <0xffc00000 0x00030000>;
       #address-cells = <0>;
       #size-cells = <0>;
       #interrupt-cells = <2>;
 
   };
 
   plb {
       compatible = "ibm,plb-4xx", "ibm,plb4"; /* Could be PLB6, doesn't matter */
       #address-cells = <2>;
       #size-cells = <1>;
       ranges;
       clock-frequency = <0>; // Filled in by zImage
 
       POB0: opb {
           compatible = "ibm,opb-4xx", "ibm,opb";
           #address-cells = <1>;
           #size-cells = <1>;
           /* Wish there was a nicer way of specifying a full 32-bit
              range */
           ranges = <0x00000000 0x00000001 0x00000000 0x80000000
                 0x80000000 0x00000001 0x80000000 0x80000000>;
           clock-frequency = <0>; // Filled in by zImage
           UART0: serial@40000200 {
               device_type = "serial";
               compatible = "ns16550a";
               reg = <0x40000200 0x00000008>;
               virtual-reg = <0xe0000200>;
               clock-frequency = <11059200>;
               current-speed = <115200>;
               interrupt-parent = <&MPIC>;
               interrupts = <0x0 0x2>;
           };
       };
   };
 
   nvrtc {
       compatible = "ds1743-nvram", "ds1743", "rtc-ds1743";
       reg = <0 0xEF703000 0x2000>;
   };
   iss-block {
       compatible = "ibm,iss-sim-block-device";
       reg = <0 0xEF701000 0x1000>;
   };
 
   chosen {
       stdout-path = "/plb/opb/serial@40000200";
   };
};