| .. SPDX-License-Identifier: GPL-2.0 |
| |
| ==================== |
| iosm devlink support |
| ==================== |
| |
| This document describes the devlink features implemented by the ``iosm`` |
| device driver. |
| |
| Parameters |
| ========== |
| |
| The ``iosm`` driver implements the following driver-specific parameters. |
| |
| .. list-table:: Driver-specific parameters implemented |
| :widths: 5 5 5 85 |
| |
| * - Name |
| - Type |
| - Mode |
| - Description |
| * - ``erase_full_flash`` |
| - u8 |
| - runtime |
| - erase_full_flash parameter is used to check if full erase is required for |
| the device during firmware flashing. |
| If set, Full nand erase command will be sent to the device. By default, |
| only conditional erase support is enabled. |
| |
| |
| Flash Update |
| ============ |
| |
| The ``iosm`` driver implements support for flash update using the |
| ``devlink-flash`` interface. |
| |
| It supports updating the device flash using a combined flash image which contains |
| the Bootloader images and other modem software images. |
| |
| The driver uses DEVLINK_SUPPORT_FLASH_UPDATE_COMPONENT to identify type of |
| firmware image that need to be flashed as requested by user space application. |
| Supported firmware image types. |
| |
| .. list-table:: Firmware Image types |
| :widths: 15 85 |
| |
| * - Name |
| - Description |
| * - ``PSI RAM`` |
| - Primary Signed Image |
| * - ``EBL`` |
| - External Bootloader |
| * - ``FLS`` |
| - Modem Software Image |
| |
| PSI RAM and EBL are the RAM images which are injected to the device when the |
| device is in BOOT ROM stage. Once this is successful, the actual modem firmware |
| image is flashed to the device. The modem software image contains multiple files |
| each having one secure bin file and at least one Loadmap/Region file. For flashing |
| these files, appropriate commands are sent to the modem device along with the |
| data required for flashing. The data like region count and address of each region |
| has to be passed to the driver using the devlink param command. |
| |
| If the device has to be fully erased before firmware flashing, user application |
| need to set the erase_full_flash parameter using devlink param command. |
| By default, conditional erase feature is supported. |
| |
| Flash Commands: |
| =============== |
| 1) When modem is in Boot ROM stage, user can use below command to inject PSI RAM |
| image using devlink flash command. |
| |
| $ devlink dev flash pci/0000:02:00.0 file <PSI_RAM_File_name> |
| |
| 2) If user want to do a full erase, below command need to be issued to set the |
| erase full flash param (To be set only if full erase required). |
| |
| $ devlink dev param set pci/0000:02:00.0 name erase_full_flash value true cmode runtime |
| |
| 3) Inject EBL after the modem is in PSI stage. |
| |
| $ devlink dev flash pci/0000:02:00.0 file <EBL_File_name> |
| |
| 4) Once EBL is injected successfully, then the actual firmware flashing takes |
| place. Below is the sequence of commands used for each of the firmware images. |
| |
| a) Flash secure bin file. |
| |
| $ devlink dev flash pci/0000:02:00.0 file <Secure_bin_file_name> |
| |
| b) Flashing the Loadmap/Region file |
| |
| $ devlink dev flash pci/0000:02:00.0 file <Load_map_file_name> |
| |
| Regions |
| ======= |
| |
| The ``iosm`` driver supports dumping the coredump logs. |
| |
| In case a firmware encounters an exception, a snapshot will be taken by the |
| driver. Following regions are accessed for device internal data. |
| |
| .. list-table:: Regions implemented |
| :widths: 15 85 |
| |
| * - Name |
| - Description |
| * - ``report.json`` |
| - The summary of exception details logged as part of this region. |
| * - ``coredump.fcd`` |
| - This region contains the details related to the exception occurred in the |
| device (RAM dump). |
| * - ``cdd.log`` |
| - This region contains the logs related to the modem CDD driver. |
| * - ``eeprom.bin`` |
| - This region contains the eeprom logs. |
| * - ``bootcore_trace.bin`` |
| - This region contains the current instance of bootloader logs. |
| * - ``bootcore_prev_trace.bin`` |
| - This region contains the previous instance of bootloader logs. |
| |
| |
| Region commands |
| =============== |
| |
| $ devlink region show |
| |
| $ devlink region new pci/0000:02:00.0/report.json |
| |
| $ devlink region dump pci/0000:02:00.0/report.json snapshot 0 |
| |
| $ devlink region del pci/0000:02:00.0/report.json snapshot 0 |
| |
| $ devlink region new pci/0000:02:00.0/coredump.fcd |
| |
| $ devlink region dump pci/0000:02:00.0/coredump.fcd snapshot 1 |
| |
| $ devlink region del pci/0000:02:00.0/coredump.fcd snapshot 1 |
| |
| $ devlink region new pci/0000:02:00.0/cdd.log |
| |
| $ devlink region dump pci/0000:02:00.0/cdd.log snapshot 2 |
| |
| $ devlink region del pci/0000:02:00.0/cdd.log snapshot 2 |
| |
| $ devlink region new pci/0000:02:00.0/eeprom.bin |
| |
| $ devlink region dump pci/0000:02:00.0/eeprom.bin snapshot 3 |
| |
| $ devlink region del pci/0000:02:00.0/eeprom.bin snapshot 3 |
| |
| $ devlink region new pci/0000:02:00.0/bootcore_trace.bin |
| |
| $ devlink region dump pci/0000:02:00.0/bootcore_trace.bin snapshot 4 |
| |
| $ devlink region del pci/0000:02:00.0/bootcore_trace.bin snapshot 4 |
| |
| $ devlink region new pci/0000:02:00.0/bootcore_prev_trace.bin |
| |
| $ devlink region dump pci/0000:02:00.0/bootcore_prev_trace.bin snapshot 5 |
| |
| $ devlink region del pci/0000:02:00.0/bootcore_prev_trace.bin snapshot 5 |