]> Git Repo - J-linux.git/blob - drivers/firmware/microchip/mpfs-auto-update.c
Merge tag 'vfs-6.13-rc7.fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/vfs/vfs
[J-linux.git] / drivers / firmware / microchip / mpfs-auto-update.c
1 // SPDX-License-Identifier: GPL-2.0
2 /*
3  * Microchip Polarfire SoC "Auto Update" FPGA reprogramming.
4  *
5  * Documentation of this functionality is available in the "PolarFire® FPGA and
6  * PolarFire SoC FPGA Programming" User Guide.
7  *
8  * Copyright (c) 2022-2023 Microchip Corporation. All rights reserved.
9  *
10  * Author: Conor Dooley <[email protected]>
11  */
12 #include <linux/cleanup.h>
13 #include <linux/debugfs.h>
14 #include <linux/firmware.h>
15 #include <linux/math.h>
16 #include <linux/module.h>
17 #include <linux/mtd/mtd.h>
18 #include <linux/platform_device.h>
19 #include <linux/sizes.h>
20
21 #include <soc/microchip/mpfs.h>
22
23 #define AUTO_UPDATE_DEFAULT_MBOX_OFFSET         0u
24 #define AUTO_UPDATE_DEFAULT_RESP_OFFSET         0u
25
26 #define AUTO_UPDATE_FEATURE_CMD_OPCODE          0x05u
27 #define AUTO_UPDATE_FEATURE_CMD_DATA_SIZE       0u
28 #define AUTO_UPDATE_FEATURE_RESP_SIZE           33u
29 #define AUTO_UPDATE_FEATURE_CMD_DATA            NULL
30 #define AUTO_UPDATE_FEATURE_ENABLED             BIT(5)
31
32 #define AUTO_UPDATE_AUTHENTICATE_CMD_OPCODE     0x22u
33 #define AUTO_UPDATE_AUTHENTICATE_CMD_DATA_SIZE  0u
34 #define AUTO_UPDATE_AUTHENTICATE_RESP_SIZE      1u
35 #define AUTO_UPDATE_AUTHENTICATE_CMD_DATA       NULL
36
37 #define AUTO_UPDATE_PROGRAM_CMD_OPCODE          0x46u
38 #define AUTO_UPDATE_PROGRAM_CMD_DATA_SIZE       0u
39 #define AUTO_UPDATE_PROGRAM_RESP_SIZE           1u
40 #define AUTO_UPDATE_PROGRAM_CMD_DATA            NULL
41
42 /*
43  * SPI Flash layout example:
44  * |------------------------------| 0x0000000
45  * | 1 KiB                        |
46  * | SPI "directories"            |
47  * |------------------------------| 0x0000400
48  * | 1 MiB                        |
49  * | Reserved area                |
50  * | Used for bitstream info      |
51  * |------------------------------| 0x0100400
52  * | 20 MiB                       |
53  * | Golden Image                 |
54  * |------------------------------| 0x1500400
55  * | 20 MiB                       |
56  * | Auto Upgrade Image           |
57  * |------------------------------| 0x2900400
58  * | 20 MiB                       |
59  * | Reserved for multi-image IAP |
60  * | Unused for Auto Upgrade      |
61  * |------------------------------| 0x3D00400
62  * | ? B                          |
63  * | Unused                       |
64  * |------------------------------| 0x?
65  */
66 #define AUTO_UPDATE_DIRECTORY_BASE      0u
67 #define AUTO_UPDATE_DIRECTORY_WIDTH     4u
68 #define AUTO_UPDATE_GOLDEN_INDEX        0u
69 #define AUTO_UPDATE_UPGRADE_INDEX       1u
70 #define AUTO_UPDATE_BLANK_INDEX         2u
71 #define AUTO_UPDATE_GOLDEN_DIRECTORY    (AUTO_UPDATE_DIRECTORY_WIDTH * AUTO_UPDATE_GOLDEN_INDEX)
72 #define AUTO_UPDATE_UPGRADE_DIRECTORY   (AUTO_UPDATE_DIRECTORY_WIDTH * AUTO_UPDATE_UPGRADE_INDEX)
73 #define AUTO_UPDATE_BLANK_DIRECTORY     (AUTO_UPDATE_DIRECTORY_WIDTH * AUTO_UPDATE_BLANK_INDEX)
74 #define AUTO_UPDATE_DIRECTORY_SIZE      SZ_1K
75 #define AUTO_UPDATE_INFO_BASE           AUTO_UPDATE_DIRECTORY_SIZE
76 #define AUTO_UPDATE_INFO_SIZE           SZ_1M
77 #define AUTO_UPDATE_BITSTREAM_BASE      (AUTO_UPDATE_DIRECTORY_SIZE + AUTO_UPDATE_INFO_SIZE)
78
79 struct mpfs_auto_update_priv {
80         struct mpfs_sys_controller *sys_controller;
81         struct device *dev;
82         struct mtd_info *flash;
83         struct fw_upload *fw_uploader;
84         size_t size_per_bitstream;
85         bool cancel_request;
86 };
87
88 static bool mpfs_auto_update_is_bitstream_info(const u8 *data, u32 size)
89 {
90         if (size < 4)
91                 return false;
92
93         if (data[0] == 0x4d && data[1] == 0x43 && data[2] == 0x48 && data[3] == 0x50)
94                 return true;
95
96         return false;
97 }
98
99 static enum fw_upload_err mpfs_auto_update_prepare(struct fw_upload *fw_uploader, const u8 *data,
100                                                    u32 size)
101 {
102         struct mpfs_auto_update_priv *priv = fw_uploader->dd_handle;
103         size_t erase_size = AUTO_UPDATE_DIRECTORY_SIZE;
104
105         /*
106          * Verifying the Golden Image is idealistic. It will be evaluated
107          * against the currently programmed image and thus may fail - due to
108          * either rollback protection (if its an older version than that in use)
109          * or if the version is the same as that of the in-use image.
110          * Extracting the information as to why a failure occurred is not
111          * currently possible due to limitations of the system controller
112          * driver. If those are fixed, verification of the Golden Image should
113          * be added here.
114          */
115
116         priv->flash = mpfs_sys_controller_get_flash(priv->sys_controller);
117         if (!priv->flash)
118                 return FW_UPLOAD_ERR_HW_ERROR;
119
120         erase_size = round_up(erase_size, (u64)priv->flash->erasesize);
121
122         /*
123          * We need to calculate if we have enough space in the flash for the
124          * new image.
125          * First, chop off the first 1 KiB as it's reserved for the directory.
126          * The 1 MiB reserved for design info needs to be ignored also.
127          * All that remains is carved into 3 & rounded down to the erasesize.
128          * If this is smaller than the image size, we abort.
129          * There's also no need to consume more than 20 MiB per image.
130          */
131         priv->size_per_bitstream = priv->flash->size - SZ_1K - SZ_1M;
132         priv->size_per_bitstream = round_down(priv->size_per_bitstream / 3, erase_size);
133         if (priv->size_per_bitstream > 20 * SZ_1M)
134                 priv->size_per_bitstream = 20 * SZ_1M;
135
136         if (priv->size_per_bitstream < size) {
137                 dev_err(priv->dev,
138                         "flash device has insufficient capacity to store this bitstream\n");
139                 return FW_UPLOAD_ERR_INVALID_SIZE;
140         }
141
142         priv->cancel_request = false;
143
144         return FW_UPLOAD_ERR_NONE;
145 }
146
147 static void mpfs_auto_update_cancel(struct fw_upload *fw_uploader)
148 {
149         struct mpfs_auto_update_priv *priv = fw_uploader->dd_handle;
150
151         priv->cancel_request = true;
152 }
153
154 static enum fw_upload_err mpfs_auto_update_poll_complete(struct fw_upload *fw_uploader)
155 {
156         return FW_UPLOAD_ERR_NONE;
157 }
158
159 static int mpfs_auto_update_verify_image(struct fw_upload *fw_uploader)
160 {
161         struct mpfs_auto_update_priv *priv = fw_uploader->dd_handle;
162         u32 *response_msg __free(kfree) =
163                 kzalloc(AUTO_UPDATE_FEATURE_RESP_SIZE * sizeof(*response_msg), GFP_KERNEL);
164         struct mpfs_mss_response *response __free(kfree) =
165                 kzalloc(sizeof(struct mpfs_mss_response), GFP_KERNEL);
166         struct mpfs_mss_msg *message __free(kfree) =
167                 kzalloc(sizeof(struct mpfs_mss_msg), GFP_KERNEL);
168         int ret;
169
170         if (!response_msg || !response || !message)
171                 return -ENOMEM;
172
173         /*
174          * The system controller can verify that an image in the flash is valid.
175          * Rather than duplicate the check in this driver, call the relevant
176          * service from the system controller instead.
177          * This service has no command data and no response data. It overloads
178          * mbox_offset with the image index in the flash's SPI directory where
179          * the bitstream is located.
180          */
181         response->resp_msg = response_msg;
182         response->resp_size = AUTO_UPDATE_AUTHENTICATE_RESP_SIZE;
183         message->cmd_opcode = AUTO_UPDATE_AUTHENTICATE_CMD_OPCODE;
184         message->cmd_data_size = AUTO_UPDATE_AUTHENTICATE_CMD_DATA_SIZE;
185         message->response = response;
186         message->cmd_data = AUTO_UPDATE_AUTHENTICATE_CMD_DATA;
187         message->mbox_offset = AUTO_UPDATE_UPGRADE_INDEX;
188         message->resp_offset = AUTO_UPDATE_DEFAULT_RESP_OFFSET;
189
190         dev_info(priv->dev, "Running verification of Upgrade Image\n");
191         ret = mpfs_blocking_transaction(priv->sys_controller, message);
192         if (ret | response->resp_status) {
193                 dev_warn(priv->dev, "Verification of Upgrade Image failed!\n");
194                 return ret ? ret : -EBADMSG;
195         }
196
197         dev_info(priv->dev, "Verification of Upgrade Image passed!\n");
198
199         return 0;
200 }
201
202 static int mpfs_auto_update_set_image_address(struct mpfs_auto_update_priv *priv,
203                                               u32 image_address, loff_t directory_address)
204 {
205         struct erase_info erase;
206         size_t erase_size = round_up(AUTO_UPDATE_DIRECTORY_SIZE, (u64)priv->flash->erasesize);
207         size_t bytes_written = 0, bytes_read = 0;
208         char *buffer __free(kfree) = kzalloc(erase_size, GFP_KERNEL);
209         int ret;
210
211         if (!buffer)
212                 return -ENOMEM;
213
214         erase.addr = AUTO_UPDATE_DIRECTORY_BASE;
215         erase.len = erase_size;
216
217         /*
218          * We need to write the "SPI DIRECTORY" to the first 1 KiB, telling
219          * the system controller where to find the actual bitstream. Since
220          * this is spi-nor, we have to read the first eraseblock, erase that
221          * portion of the flash, modify the data and then write it back.
222          * There's no need to do this though if things are already the way they
223          * should be, so check and save the write in that case.
224          */
225         ret = mtd_read(priv->flash, AUTO_UPDATE_DIRECTORY_BASE, erase_size, &bytes_read,
226                        (u_char *)buffer);
227         if (ret)
228                 return ret;
229
230         if (bytes_read != erase_size)
231                 return -EIO;
232
233         if ((*(u32 *)(buffer + AUTO_UPDATE_UPGRADE_DIRECTORY) == image_address) &&
234             !(*(u32 *)(buffer + AUTO_UPDATE_BLANK_DIRECTORY)))
235                 return 0;
236
237         ret = mtd_erase(priv->flash, &erase);
238         if (ret)
239                 return ret;
240
241         /*
242          * Populate the image address and then zero out the next directory so
243          * that the system controller doesn't complain if in "Single Image"
244          * mode.
245          */
246         memcpy(buffer + AUTO_UPDATE_UPGRADE_DIRECTORY, &image_address,
247                AUTO_UPDATE_DIRECTORY_WIDTH);
248         memset(buffer + AUTO_UPDATE_BLANK_DIRECTORY, 0x0, AUTO_UPDATE_DIRECTORY_WIDTH);
249
250         dev_info(priv->dev, "Writing the image address (0x%x) to the flash directory (0x%llx)\n",
251                  image_address, directory_address);
252
253         ret = mtd_write(priv->flash, 0x0, erase_size, &bytes_written, (u_char *)buffer);
254         if (ret)
255                 return ret;
256
257         if (bytes_written != erase_size)
258                 return -EIO;
259
260         return 0;
261 }
262
263 static int mpfs_auto_update_write_bitstream(struct fw_upload *fw_uploader, const u8 *data,
264                                             u32 offset, u32 size, u32 *written)
265 {
266         struct mpfs_auto_update_priv *priv = fw_uploader->dd_handle;
267         struct erase_info erase;
268         loff_t directory_address = AUTO_UPDATE_UPGRADE_DIRECTORY;
269         size_t erase_size = AUTO_UPDATE_DIRECTORY_SIZE;
270         size_t bytes_written = 0;
271         bool is_info = mpfs_auto_update_is_bitstream_info(data, size);
272         u32 image_address;
273         int ret;
274
275         erase_size = round_up(erase_size, (u64)priv->flash->erasesize);
276
277         if (is_info)
278                 image_address = AUTO_UPDATE_INFO_BASE;
279         else
280                 image_address = AUTO_UPDATE_BITSTREAM_BASE +
281                                 AUTO_UPDATE_UPGRADE_INDEX * priv->size_per_bitstream;
282
283         /*
284          * For bitstream info, the descriptor is written to a fixed offset,
285          * so there is no need to set the image address.
286          */
287         if (!is_info) {
288                 ret = mpfs_auto_update_set_image_address(priv, image_address, directory_address);
289                 if (ret) {
290                         dev_err(priv->dev, "failed to set image address in the SPI directory: %d\n", ret);
291                         return ret;
292                 }
293         } else {
294                 if (size > AUTO_UPDATE_INFO_SIZE) {
295                         dev_err(priv->dev, "bitstream info exceeds permitted size\n");
296                         return -ENOSPC;
297                 }
298         }
299
300         /*
301          * Now the .spi image itself can be written to the flash. Preservation
302          * of contents here is not important here, unlike the spi "directory"
303          * which must be RMWed.
304          */
305         erase.len = round_up(size, (size_t)priv->flash->erasesize);
306         erase.addr = image_address;
307
308         dev_info(priv->dev, "Erasing the flash at address (0x%x)\n", image_address);
309         ret = mtd_erase(priv->flash, &erase);
310         if (ret)
311                 return ret;
312
313         /*
314          * No parsing etc of the bitstream is required. The system controller
315          * will do all of that itself - including verifying that the bitstream
316          * is valid.
317          */
318         dev_info(priv->dev, "Writing the image to the flash at address (0x%x)\n", image_address);
319         ret = mtd_write(priv->flash, (loff_t)image_address, size, &bytes_written, data);
320         if (ret)
321                 return ret;
322
323         if (bytes_written != size)
324                 return -EIO;
325
326         *written = bytes_written;
327         dev_info(priv->dev, "Wrote 0x%zx bytes to the flash\n", bytes_written);
328
329         return 0;
330 }
331
332 static enum fw_upload_err mpfs_auto_update_write(struct fw_upload *fw_uploader, const u8 *data,
333                                                  u32 offset, u32 size, u32 *written)
334 {
335         struct mpfs_auto_update_priv *priv = fw_uploader->dd_handle;
336         int ret;
337
338         ret = mpfs_auto_update_write_bitstream(fw_uploader, data, offset, size, written);
339         if (ret)
340                 return FW_UPLOAD_ERR_RW_ERROR;
341
342         if (priv->cancel_request)
343                 return FW_UPLOAD_ERR_CANCELED;
344
345         if (mpfs_auto_update_is_bitstream_info(data, size))
346                 return FW_UPLOAD_ERR_NONE;
347
348         ret = mpfs_auto_update_verify_image(fw_uploader);
349         if (ret)
350                 return FW_UPLOAD_ERR_FW_INVALID;
351
352         return FW_UPLOAD_ERR_NONE;
353 }
354
355 static const struct fw_upload_ops mpfs_auto_update_ops = {
356         .prepare = mpfs_auto_update_prepare,
357         .write = mpfs_auto_update_write,
358         .poll_complete = mpfs_auto_update_poll_complete,
359         .cancel = mpfs_auto_update_cancel,
360 };
361
362 static int mpfs_auto_update_available(struct mpfs_auto_update_priv *priv)
363 {
364         u32 *response_msg __free(kfree) =
365                 kzalloc(AUTO_UPDATE_FEATURE_RESP_SIZE * sizeof(*response_msg), GFP_KERNEL);
366         struct mpfs_mss_response *response __free(kfree) =
367                 kzalloc(sizeof(struct mpfs_mss_response), GFP_KERNEL);
368         struct mpfs_mss_msg *message __free(kfree) =
369                 kzalloc(sizeof(struct mpfs_mss_msg), GFP_KERNEL);
370         int ret;
371
372         if (!response_msg || !response || !message)
373                 return -ENOMEM;
374
375         /*
376          * To verify that Auto Update is possible, the "Query Security Service
377          * Request" is performed.
378          * This service has no command data & does not overload mbox_offset.
379          */
380         response->resp_msg = response_msg;
381         response->resp_size = AUTO_UPDATE_FEATURE_RESP_SIZE;
382         message->cmd_opcode = AUTO_UPDATE_FEATURE_CMD_OPCODE;
383         message->cmd_data_size = AUTO_UPDATE_FEATURE_CMD_DATA_SIZE;
384         message->response = response;
385         message->cmd_data = AUTO_UPDATE_FEATURE_CMD_DATA;
386         message->mbox_offset = AUTO_UPDATE_DEFAULT_MBOX_OFFSET;
387         message->resp_offset = AUTO_UPDATE_DEFAULT_RESP_OFFSET;
388
389         ret = mpfs_blocking_transaction(priv->sys_controller, message);
390         if (ret)
391                 return ret;
392
393         /*
394          * Currently, the system controller's firmware does not generate any
395          * interrupts for failed services, so mpfs_blocking_transaction() should
396          * time out & therefore return an error.
397          * Hitting this check is highly unlikely at present, but if the system
398          * controller's behaviour changes so that it does generate interrupts
399          * for failed services, it will be required.
400          */
401         if (response->resp_status)
402                 return -EIO;
403
404         /*
405          * Bit 5 of byte 1 is "UL_IAP" & if it is set, Auto Update is
406          * not possible.
407          */
408         if ((((u8 *)response_msg)[1] & AUTO_UPDATE_FEATURE_ENABLED))
409                 return -EPERM;
410
411         return 0;
412 }
413
414 static int mpfs_auto_update_probe(struct platform_device *pdev)
415 {
416         struct device *dev = &pdev->dev;
417         struct mpfs_auto_update_priv *priv;
418         struct fw_upload *fw_uploader;
419         int ret;
420
421         priv = devm_kzalloc(dev, sizeof(*priv), GFP_KERNEL);
422         if (!priv)
423                 return -ENOMEM;
424
425         priv->sys_controller = mpfs_sys_controller_get(dev);
426         if (IS_ERR(priv->sys_controller))
427                 return dev_err_probe(dev, PTR_ERR(priv->sys_controller),
428                                      "Could not register as a sub device of the system controller\n");
429
430         priv->dev = dev;
431         platform_set_drvdata(pdev, priv);
432
433         ret = mpfs_auto_update_available(priv);
434         if (ret)
435                 return dev_err_probe(dev, ret,
436                                      "The current bitstream does not support auto-update\n");
437
438         fw_uploader = firmware_upload_register(THIS_MODULE, dev, "mpfs-auto-update",
439                                                &mpfs_auto_update_ops, priv);
440         if (IS_ERR(fw_uploader))
441                 return dev_err_probe(dev, PTR_ERR(fw_uploader),
442                                      "Failed to register the bitstream uploader\n");
443
444         priv->fw_uploader = fw_uploader;
445
446         return 0;
447 }
448
449 static void mpfs_auto_update_remove(struct platform_device *pdev)
450 {
451         struct mpfs_auto_update_priv *priv = platform_get_drvdata(pdev);
452
453         firmware_upload_unregister(priv->fw_uploader);
454 }
455
456 static struct platform_driver mpfs_auto_update_driver = {
457         .driver = {
458                 .name = "mpfs-auto-update",
459         },
460         .probe = mpfs_auto_update_probe,
461         .remove = mpfs_auto_update_remove,
462 };
463 module_platform_driver(mpfs_auto_update_driver);
464
465 MODULE_LICENSE("GPL");
466 MODULE_AUTHOR("Conor Dooley <[email protected]>");
467 MODULE_DESCRIPTION("PolarFire SoC Auto Update FPGA reprogramming");
This page took 0.051197 seconds and 4 git commands to generate.