1 // SPDX-License-Identifier: GPL-2.0
2
3 /*
4 * Microcode patches for the CPM as supplied by Motorola.
5 * This is the one for IIC/SPI. There is a newer one that
6 * also relocates SMC2, but this would require additional changes
7 * to uart.c, so I am holding off on that for a moment.
8 */
9 #include <linux/init.h>
10 #include <linux/errno.h>
11 #include <linux/sched.h>
12 #include <linux/kernel.h>
13 #include <linux/param.h>
14 #include <linux/string.h>
15 #include <linux/mm.h>
16 #include <linux/interrupt.h>
17 #include <asm/irq.h>
18 #include <asm/page.h>
19 #include <asm/pgtable.h>
20 #include <asm/8xx_immap.h>
21 #include <asm/cpm.h>
22 #include <asm/cpm1.h>
23
24 struct patch_params {
25 ushort rccr;
26 ushort cpmcr1;
27 ushort cpmcr2;
28 ushort cpmcr3;
29 ushort cpmcr4;
30 };
31
32 /*
33 * I2C/SPI relocation patch arrays.
34 */
35
36 #ifdef CONFIG_I2C_SPI_UCODE_PATCH
37
38 static char patch_name[] __initdata = "I2C/SPI";
39
40 static struct patch_params patch_params __initdata = {
41 1, 0x802a, 0x8028, 0x802e, 0x802c,
42 };
43
44 static uint patch_2000[] __initdata = {
45 0x7FFFEFD9, 0x3FFD0000, 0x7FFB49F7, 0x7FF90000,
46 0x5FEFADF7, 0x5F89ADF7, 0x5FEFAFF7, 0x5F89AFF7,
47 0x3A9CFBC8, 0xE7C0EDF0, 0x77C1E1BB, 0xF4DC7F1D,
48 0xABAD932F, 0x4E08FDCF, 0x6E0FAFF8, 0x7CCF76CF,
49 0xFD1FF9CF, 0xABF88DC6, 0xAB5679F7, 0xB0937383,
50 0xDFCE79F7, 0xB091E6BB, 0xE5BBE74F, 0xB3FA6F0F,
51 0x6FFB76CE, 0xEE0DF9CF, 0x2BFBEFEF, 0xCFEEF9CF,
52 0x76CEAD24, 0x90B2DF9A, 0x7FDDD0BF, 0x4BF847FD,
53 0x7CCF76CE, 0xCFEF7E1F, 0x7F1D7DFD, 0xF0B6EF71,
54 0x7FC177C1, 0xFBC86079, 0xE722FBC8, 0x5FFFDFFF,
55 0x5FB2FFFB, 0xFBC8F3C8, 0x94A67F01, 0x7F1D5F39,
56 0xAFE85F5E, 0xFFDFDF96, 0xCB9FAF7D, 0x5FC1AFED,
57 0x8C1C5FC1, 0xAFDD5FC3, 0xDF9A7EFD, 0xB0B25FB2,
58 0xFFFEABAD, 0x5FB2FFFE, 0x5FCE600B, 0xE6BB600B,
59 0x5FCEDFC6, 0x27FBEFDF, 0x5FC8CFDE, 0x3A9CE7C0,
60 0xEDF0F3C8, 0x7F0154CD, 0x7F1D2D3D, 0x363A7570,
61 0x7E0AF1CE, 0x37EF2E68, 0x7FEE10EC, 0xADF8EFDE,
62 0xCFEAE52F, 0x7D0FE12B, 0xF1CE5F65, 0x7E0A4DF8,
63 0xCFEA5F72, 0x7D0BEFEE, 0xCFEA5F74, 0xE522EFDE,
64 0x5F74CFDA, 0x0B627385, 0xDF627E0A, 0x30D8145B,
65 0xBFFFF3C8, 0x5FFFDFFF, 0xA7F85F5E, 0xBFFE7F7D,
66 0x10D31450, 0x5F36BFFF, 0xAF785F5E, 0xBFFDA7F8,
67 0x5F36BFFE, 0x77FD30C0, 0x4E08FDCF, 0xE5FF6E0F,
68 0xAFF87E1F, 0x7E0FFD1F, 0xF1CF5F1B, 0xABF80D5E,
69 0x5F5EFFEF, 0x79F730A2, 0xAFDD5F34, 0x47F85F34,
70 0xAFED7FDD, 0x50B24978, 0x47FD7F1D, 0x7DFD70AD,
71 0xEF717EC1, 0x6BA47F01, 0x2D267EFD, 0x30DE5F5E,
72 0xFFFD5F5E, 0xFFEF5F5E, 0xFFDF0CA0, 0xAFED0A9E,
73 0xAFDD0C3A, 0x5F3AAFBD, 0x7FBDB082, 0x5F8247F8
74 };
75
76 static uint patch_2f00[] __initdata = {
77 0x3E303430, 0x34343737, 0xABF7BF9B, 0x994B4FBD,
78 0xBD599493, 0x349FFF37, 0xFB9B177D, 0xD9936956,
79 0xBBFDD697, 0xBDD2FD11, 0x31DB9BB3, 0x63139637,
80 0x93733693, 0x193137F7, 0x331737AF, 0x7BB9B999,
81 0xBB197957, 0x7FDFD3D5, 0x73B773F7, 0x37933B99,
82 0x1D115316, 0x99315315, 0x31694BF4, 0xFBDBD359,
83 0x31497353, 0x76956D69, 0x7B9D9693, 0x13131979,
84 0x79376935
85 };
86
87 static uint patch_2e00[] __initdata = {};
88 #endif
89
90 /*
91 * I2C/SPI/SMC1 relocation patch arrays.
92 */
93
94 #ifdef CONFIG_I2C_SPI_SMC1_UCODE_PATCH
95
96 static char patch_name[] __initdata = "I2C/SPI/SMC1";
97
98 static struct patch_params patch_params __initdata = {
99 3, 0x8080, 0x808a, 0x8028, 0x802a,
100 };
101
102 static uint patch_2000[] __initdata = {
103 0x3fff0000, 0x3ffd0000, 0x3ffb0000, 0x3ff90000,
104 0x5f13eff8, 0x5eb5eff8, 0x5f88adf7, 0x5fefadf7,
105 0x3a9cfbc8, 0x77cae1bb, 0xf4de7fad, 0xabae9330,
106 0x4e08fdcf, 0x6e0faff8, 0x7ccf76cf, 0xfdaff9cf,
107 0xabf88dc8, 0xab5879f7, 0xb0925d8d, 0xdfd079f7,
108 0xb090e6bb, 0xe5bbe74f, 0x9e046f0f, 0x6ffb76ce,
109 0xee0cf9cf, 0x2bfbefef, 0xcfeef9cf, 0x76cead23,
110 0x90b3df99, 0x7fddd0c1, 0x4bf847fd, 0x7ccf76ce,
111 0xcfef77ca, 0x7eaf7fad, 0x7dfdf0b7, 0xef7a7fca,
112 0x77cafbc8, 0x6079e722, 0xfbc85fff, 0xdfff5fb3,
113 0xfffbfbc8, 0xf3c894a5, 0xe7c9edf9, 0x7f9a7fad,
114 0x5f36afe8, 0x5f5bffdf, 0xdf95cb9e, 0xaf7d5fc3,
115 0xafed8c1b, 0x5fc3afdd, 0x5fc5df99, 0x7efdb0b3,
116 0x5fb3fffe, 0xabae5fb3, 0xfffe5fd0, 0x600be6bb,
117 0x600b5fd0, 0xdfc827fb, 0xefdf5fca, 0xcfde3a9c,
118 0xe7c9edf9, 0xf3c87f9e, 0x54ca7fed, 0x2d3a3637,
119 0x756f7e9a, 0xf1ce37ef, 0x2e677fee, 0x10ebadf8,
120 0xefdecfea, 0xe52f7d9f, 0xe12bf1ce, 0x5f647e9a,
121 0x4df8cfea, 0x5f717d9b, 0xefeecfea, 0x5f73e522,
122 0xefde5f73, 0xcfda0b61, 0x5d8fdf61, 0xe7c9edf9,
123 0x7e9a30d5, 0x1458bfff, 0xf3c85fff, 0xdfffa7f8,
124 0x5f5bbffe, 0x7f7d10d0, 0x144d5f33, 0xbfffaf78,
125 0x5f5bbffd, 0xa7f85f33, 0xbffe77fd, 0x30bd4e08,
126 0xfdcfe5ff, 0x6e0faff8, 0x7eef7e9f, 0xfdeff1cf,
127 0x5f17abf8, 0x0d5b5f5b, 0xffef79f7, 0x309eafdd,
128 0x5f3147f8, 0x5f31afed, 0x7fdd50af, 0x497847fd,
129 0x7f9e7fed, 0x7dfd70a9, 0xef7e7ece, 0x6ba07f9e,
130 0x2d227efd, 0x30db5f5b, 0xfffd5f5b, 0xffef5f5b,
131 0xffdf0c9c, 0xafed0a9a, 0xafdd0c37, 0x5f37afbd,
132 0x7fbdb081, 0x5f8147f8, 0x3a11e710, 0xedf0ccdd,
133 0xf3186d0a, 0x7f0e5f06, 0x7fedbb38, 0x3afe7468,
134 0x7fedf4fc, 0x8ffbb951, 0xb85f77fd, 0xb0df5ddd,
135 0xdefe7fed, 0x90e1e74d, 0x6f0dcbf7, 0xe7decfed,
136 0xcb74cfed, 0xcfeddf6d, 0x91714f74, 0x5dd2deef,
137 0x9e04e7df, 0xefbb6ffb, 0xe7ef7f0e, 0x9e097fed,
138 0xebdbeffa, 0xeb54affb, 0x7fea90d7, 0x7e0cf0c3,
139 0xbffff318, 0x5fffdfff, 0xac59efea, 0x7fce1ee5,
140 0xe2ff5ee1, 0xaffbe2ff, 0x5ee3affb, 0xf9cc7d0f,
141 0xaef8770f, 0x7d0fb0c6, 0xeffbbfff, 0xcfef5ede,
142 0x7d0fbfff, 0x5ede4cf8, 0x7fddd0bf, 0x49f847fd,
143 0x7efdf0bb, 0x7fedfffd, 0x7dfdf0b7, 0xef7e7e1e,
144 0x5ede7f0e, 0x3a11e710, 0xedf0ccab, 0xfb18ad2e,
145 0x1ea9bbb8, 0x74283b7e, 0x73c2e4bb, 0x2ada4fb8,
146 0xdc21e4bb, 0xb2a1ffbf, 0x5e2c43f8, 0xfc87e1bb,
147 0xe74ffd91, 0x6f0f4fe8, 0xc7ba32e2, 0xf396efeb,
148 0x600b4f78, 0xe5bb760b, 0x53acaef8, 0x4ef88b0e,
149 0xcfef9e09, 0xabf8751f, 0xefef5bac, 0x741f4fe8,
150 0x751e760d, 0x7fdbf081, 0x741cafce, 0xefcc7fce,
151 0x751e70ac, 0x741ce7bb, 0x3372cfed, 0xafdbefeb,
152 0xe5bb760b, 0x53f2aef8, 0xafe8e7eb, 0x4bf8771e,
153 0x7e247fed, 0x4fcbe2cc, 0x7fbc30a9, 0x7b0f7a0f,
154 0x34d577fd, 0x308b5db7, 0xde553e5f, 0xaf78741f,
155 0x741f30f0, 0xcfef5e2c, 0x741f3eac, 0xafb8771e,
156 0x5e677fed, 0x0bd3e2cc, 0x741ccfec, 0xe5ca53cd,
157 0x6fcb4f74, 0x5dadde4b, 0x2ab63d38, 0x4bb3de30,
158 0x751f741c, 0x6c42effa, 0xefea7fce, 0x6ffc30be,
159 0xefec3fca, 0x30b3de2e, 0xadf85d9e, 0xaf7daefd,
160 0x5d9ede2e, 0x5d9eafdd, 0x761f10ac, 0x1da07efd,
161 0x30adfffe, 0x4908fb18, 0x5fffdfff, 0xafbb709b,
162 0x4ef85e67, 0xadf814ad, 0x7a0f70ad, 0xcfef50ad,
163 0x7a0fde30, 0x5da0afed, 0x3c12780f, 0xefef780f,
164 0xefef790f, 0xa7f85e0f, 0xffef790f, 0xefef790f,
165 0x14adde2e, 0x5d9eadfd, 0x5e2dfffb, 0xe79addfd,
166 0xeff96079, 0x607ae79a, 0xddfceff9, 0x60795dff,
167 0x607acfef, 0xefefefdf, 0xefbfef7f, 0xeeffedff,
168 0xebffe7ff, 0xafefafdf, 0xafbfaf7f, 0xaeffadff,
169 0xabffa7ff, 0x6fef6fdf, 0x6fbf6f7f, 0x6eff6dff,
170 0x6bff67ff, 0x2fef2fdf, 0x2fbf2f7f, 0x2eff2dff,
171 0x2bff27ff, 0x4e08fd1f, 0xe5ff6e0f, 0xaff87eef,
172 0x7e0ffdef, 0xf11f6079, 0xabf8f542, 0x7e0af11c,
173 0x37cfae3a, 0x7fec90be, 0xadf8efdc, 0xcfeae52f,
174 0x7d0fe12b, 0xf11c6079, 0x7e0a4df8, 0xcfea5dc4,
175 0x7d0befec, 0xcfea5dc6, 0xe522efdc, 0x5dc6cfda,
176 0x4e08fd1f, 0x6e0faff8, 0x7c1f761f, 0xfdeff91f,
177 0x6079abf8, 0x761cee24, 0xf91f2bfb, 0xefefcfec,
178 0xf91f6079, 0x761c27fb, 0xefdf5da7, 0xcfdc7fdd,
179 0xd09c4bf8, 0x47fd7c1f, 0x761ccfcf, 0x7eef7fed,
180 0x7dfdf093, 0xef7e7f1e, 0x771efb18, 0x6079e722,
181 0xe6bbe5bb, 0xae0ae5bb, 0x600bae85, 0xe2bbe2bb,
182 0xe2bbe2bb, 0xaf02e2bb, 0xe2bb2ff9, 0x6079e2bb
183 };
184
185 static uint patch_2f00[] __initdata = {
186 0x30303030, 0x3e3e3434, 0xabbf9b99, 0x4b4fbdbd,
187 0x59949334, 0x9fff37fb, 0x9b177dd9, 0x936956bb,
188 0xfbdd697b, 0xdd2fd113, 0x1db9f7bb, 0x36313963,
189 0x79373369, 0x3193137f, 0x7331737a, 0xf7bb9b99,
190 0x9bb19795, 0x77fdfd3d, 0x573b773f, 0x737933f7,
191 0xb991d115, 0x31699315, 0x31531694, 0xbf4fbdbd,
192 0x35931497, 0x35376956, 0xbd697b9d, 0x96931313,
193 0x19797937, 0x6935af78, 0xb9b3baa3, 0xb8788683,
194 0x368f78f7, 0x87778733, 0x3ffffb3b, 0x8e8f78b8,
195 0x1d118e13, 0xf3ff3f8b, 0x6bd8e173, 0xd1366856,
196 0x68d1687b, 0x3daf78b8, 0x3a3a3f87, 0x8f81378f,
197 0xf876f887, 0x77fd8778, 0x737de8d6, 0xbbf8bfff,
198 0xd8df87f7, 0xfd876f7b, 0x8bfff8bd, 0x8683387d,
199 0xb873d87b, 0x3b8fd7f8, 0xf7338883, 0xbb8ee1f8,
200 0xef837377, 0x3337b836, 0x817d11f8, 0x7378b878,
201 0xd3368b7d, 0xed731b7d, 0x833731f3, 0xf22f3f23
202 };
203
204 static uint patch_2e00[] __initdata = {
205 0x27eeeeee, 0xeeeeeeee, 0xeeeeeeee, 0xeeeeeeee,
206 0xee4bf4fb, 0xdbd259bb, 0x1979577f, 0xdfd2d573,
207 0xb773f737, 0x4b4fbdbd, 0x25b9b177, 0xd2d17376,
208 0x956bbfdd, 0x697bdd2f, 0xff9f79ff, 0xff9ff22f
209 };
210 #endif
211
212 /*
213 * USB SOF patch arrays.
214 */
215
216 #ifdef CONFIG_USB_SOF_UCODE_PATCH
217
218 static char patch_name[] __initdata = "USB SOF";
219
220 static struct patch_params patch_params __initdata = {
221 9,
222 };
223
224 static uint patch_2000[] __initdata = {
225 0x7fff0000, 0x7ffd0000, 0x7ffb0000, 0x49f7ba5b,
226 0xba383ffb, 0xf9b8b46d, 0xe5ab4e07, 0xaf77bffe,
227 0x3f7bbf79, 0xba5bba38, 0xe7676076, 0x60750000
228 };
229
230 static uint patch_2f00[] __initdata = {
231 0x3030304c, 0xcab9e441, 0xa1aaf220
232 };
233
234 static uint patch_2e00[] __initdata = {};
235 #endif
236
237 /*
238 * SMC relocation patch arrays.
239 */
240
241 #ifdef CONFIG_SMC_UCODE_PATCH
242
243 static char patch_name[] __initdata = "SMC";
244
245 static struct patch_params patch_params __initdata = {
246 2, 0x8080, 0x8088,
247 };
248
249 static uint patch_2000[] __initdata = {
250 0x3fff0000, 0x3ffd0000, 0x3ffb0000, 0x3ff90000,
251 0x5fefeff8, 0x5f91eff8, 0x3ff30000, 0x3ff10000,
252 0x3a11e710, 0xedf0ccb9, 0xf318ed66, 0x7f0e5fe2,
253 0x7fedbb38, 0x3afe7468, 0x7fedf4d8, 0x8ffbb92d,
254 0xb83b77fd, 0xb0bb5eb9, 0xdfda7fed, 0x90bde74d,
255 0x6f0dcbd3, 0xe7decfed, 0xcb50cfed, 0xcfeddf6d,
256 0x914d4f74, 0x5eaedfcb, 0x9ee0e7df, 0xefbb6ffb,
257 0xe7ef7f0e, 0x9ee57fed, 0xebb7effa, 0xeb30affb,
258 0x7fea90b3, 0x7e0cf09f, 0xbffff318, 0x5fffdfff,
259 0xac35efea, 0x7fce1fc1, 0xe2ff5fbd, 0xaffbe2ff,
260 0x5fbfaffb, 0xf9a87d0f, 0xaef8770f, 0x7d0fb0a2,
261 0xeffbbfff, 0xcfef5fba, 0x7d0fbfff, 0x5fba4cf8,
262 0x7fddd09b, 0x49f847fd, 0x7efdf097, 0x7fedfffd,
263 0x7dfdf093, 0xef7e7e1e, 0x5fba7f0e, 0x3a11e710,
264 0xedf0cc87, 0xfb18ad0a, 0x1f85bbb8, 0x74283b7e,
265 0x7375e4bb, 0x2ab64fb8, 0x5c7de4bb, 0x32fdffbf,
266 0x5f0843f8, 0x7ce3e1bb, 0xe74f7ded, 0x6f0f4fe8,
267 0xc7ba32be, 0x73f2efeb, 0x600b4f78, 0xe5bb760b,
268 0x5388aef8, 0x4ef80b6a, 0xcfef9ee5, 0xabf8751f,
269 0xefef5b88, 0x741f4fe8, 0x751e760d, 0x7fdb70dd,
270 0x741cafce, 0xefcc7fce, 0x751e7088, 0x741ce7bb,
271 0x334ecfed, 0xafdbefeb, 0xe5bb760b, 0x53ceaef8,
272 0xafe8e7eb, 0x4bf8771e, 0x7e007fed, 0x4fcbe2cc,
273 0x7fbc3085, 0x7b0f7a0f, 0x34b177fd, 0xb0e75e93,
274 0xdf313e3b, 0xaf78741f, 0x741f30cc, 0xcfef5f08,
275 0x741f3e88, 0xafb8771e, 0x5f437fed, 0x0bafe2cc,
276 0x741ccfec, 0xe5ca53a9, 0x6fcb4f74, 0x5e89df27,
277 0x2a923d14, 0x4b8fdf0c, 0x751f741c, 0x6c1eeffa,
278 0xefea7fce, 0x6ffc309a, 0xefec3fca, 0x308fdf0a,
279 0xadf85e7a, 0xaf7daefd, 0x5e7adf0a, 0x5e7aafdd,
280 0x761f1088, 0x1e7c7efd, 0x3089fffe, 0x4908fb18,
281 0x5fffdfff, 0xafbbf0f7, 0x4ef85f43, 0xadf81489,
282 0x7a0f7089, 0xcfef5089, 0x7a0fdf0c, 0x5e7cafed,
283 0xbc6e780f, 0xefef780f, 0xefef790f, 0xa7f85eeb,
284 0xffef790f, 0xefef790f, 0x1489df0a, 0x5e7aadfd,
285 0x5f09fffb, 0xe79aded9, 0xeff96079, 0x607ae79a,
286 0xded8eff9, 0x60795edb, 0x607acfef, 0xefefefdf,
287 0xefbfef7f, 0xeeffedff, 0xebffe7ff, 0xafefafdf,
288 0xafbfaf7f, 0xaeffadff, 0xabffa7ff, 0x6fef6fdf,
289 0x6fbf6f7f, 0x6eff6dff, 0x6bff67ff, 0x2fef2fdf,
290 0x2fbf2f7f, 0x2eff2dff, 0x2bff27ff, 0x4e08fd1f,
291 0xe5ff6e0f, 0xaff87eef, 0x7e0ffdef, 0xf11f6079,
292 0xabf8f51e, 0x7e0af11c, 0x37cfae16, 0x7fec909a,
293 0xadf8efdc, 0xcfeae52f, 0x7d0fe12b, 0xf11c6079,
294 0x7e0a4df8, 0xcfea5ea0, 0x7d0befec, 0xcfea5ea2,
295 0xe522efdc, 0x5ea2cfda, 0x4e08fd1f, 0x6e0faff8,
296 0x7c1f761f, 0xfdeff91f, 0x6079abf8, 0x761cee00,
297 0xf91f2bfb, 0xefefcfec, 0xf91f6079, 0x761c27fb,
298 0xefdf5e83, 0xcfdc7fdd, 0x50f84bf8, 0x47fd7c1f,
299 0x761ccfcf, 0x7eef7fed, 0x7dfd70ef, 0xef7e7f1e,
300 0x771efb18, 0x6079e722, 0xe6bbe5bb, 0x2e66e5bb,
301 0x600b2ee1, 0xe2bbe2bb, 0xe2bbe2bb, 0x2f5ee2bb,
302 0xe2bb2ff9, 0x6079e2bb,
303 };
304
305 static uint patch_2f00[] __initdata = {
306 0x30303030, 0x3e3e3030, 0xaf79b9b3, 0xbaa3b979,
307 0x9693369f, 0x79f79777, 0x97333fff, 0xfb3b9e9f,
308 0x79b91d11, 0x9e13f3ff, 0x3f9b6bd9, 0xe173d136,
309 0x695669d1, 0x697b3daf, 0x79b93a3a, 0x3f979f91,
310 0x379ff976, 0xf99777fd, 0x9779737d, 0xe9d6bbf9,
311 0xbfffd9df, 0x97f7fd97, 0x6f7b9bff, 0xf9bd9683,
312 0x397db973, 0xd97b3b9f, 0xd7f9f733, 0x9993bb9e,
313 0xe1f9ef93, 0x73773337, 0xb936917d, 0x11f87379,
314 0xb979d336, 0x8b7ded73, 0x1b7d9337, 0x31f3f22f,
315 0x3f2327ee, 0xeeeeeeee, 0xeeeeeeee, 0xeeeeeeee,
316 0xeeeeee4b, 0xf4fbdbd2, 0x58bb1878, 0x577fdfd2,
317 0xd573b773, 0xf7374b4f, 0xbdbd25b8, 0xb177d2d1,
318 0x7376856b, 0xbfdd687b, 0xdd2fff8f, 0x78ffff8f,
319 0xf22f0000,
320 };
321
322 static uint patch_2e00[] __initdata = {};
323 #endif
324
cpm_write_patch(cpm8xx_t * cp,int offset,uint * patch,int len)325 static void __init cpm_write_patch(cpm8xx_t *cp, int offset, uint *patch, int len)
326 {
327 if (!len)
328 return;
329 memcpy_toio(cp->cp_dpmem + offset, patch, len);
330 }
331
cpm_load_patch(cpm8xx_t * cp)332 void __init cpm_load_patch(cpm8xx_t *cp)
333 {
334 out_be16(&cp->cp_rccr, 0);
335
336 cpm_write_patch(cp, 0, patch_2000, sizeof(patch_2000));
337 cpm_write_patch(cp, 0xf00, patch_2f00, sizeof(patch_2f00));
338 cpm_write_patch(cp, 0xe00, patch_2e00, sizeof(patch_2e00));
339
340 if (IS_ENABLED(CONFIG_I2C_SPI_UCODE_PATCH) ||
341 IS_ENABLED(CONFIG_I2C_SPI_SMC1_UCODE_PATCH)) {
342 u16 rpbase = 0x500;
343 iic_t *iip;
344 struct spi_pram *spp;
345
346 iip = (iic_t *)&cp->cp_dparam[PROFF_IIC];
347 out_be16(&iip->iic_rpbase, rpbase);
348
349 /* Put SPI above the IIC, also 32-byte aligned. */
350 spp = (struct spi_pram *)&cp->cp_dparam[PROFF_SPI];
351 out_be16(&spp->rpbase, (rpbase + sizeof(iic_t) + 31) & ~31);
352
353 if (IS_ENABLED(CONFIG_I2C_SPI_SMC1_UCODE_PATCH)) {
354 smc_uart_t *smp;
355
356 smp = (smc_uart_t *)&cp->cp_dparam[PROFF_SMC1];
357 out_be16(&smp->smc_rpbase, 0x1FC0);
358 }
359 }
360
361 if (IS_ENABLED(CONFIG_SMC_UCODE_PATCH)) {
362 smc_uart_t *smp;
363
364 smp = (smc_uart_t *)&cp->cp_dparam[PROFF_SMC1];
365 out_be16(&smp->smc_rpbase, 0x1ec0);
366 smp = (smc_uart_t *)&cp->cp_dparam[PROFF_SMC2];
367 out_be16(&smp->smc_rpbase, 0x1fc0);
368 }
369
370 out_be16(&cp->cp_cpmcr1, patch_params.cpmcr1);
371 out_be16(&cp->cp_cpmcr2, patch_params.cpmcr2);
372 out_be16(&cp->cp_cpmcr3, patch_params.cpmcr3);
373 out_be16(&cp->cp_cpmcr4, patch_params.cpmcr4);
374
375 out_be16(&cp->cp_rccr, patch_params.rccr);
376
377 pr_info("%s microcode patch installed\n", patch_name);
378 }
379