From patchwork Thu Aug 3 02:39:56 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Jinjian Song X-Patchwork-Id: 13339170 X-Patchwork-Delegate: kuba@kernel.org Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net [23.128.96.19]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 3C67A187B for ; Thu, 3 Aug 2023 02:40:28 +0000 (UTC) Received: from AUS01-SY4-obe.outbound.protection.outlook.com (mail-sy4aus01olkn2188.outbound.protection.outlook.com [40.92.62.188]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 446B8E43 for ; Wed, 2 Aug 2023 19:40:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=n+RDnUGf83cn8bw1OeGt8hxFZG8maMSMDJg86AHkBgZKn/nf/48lKJM+AHdKOHVBODQIWlA/R/kcdbL02ru+GChUqTgwEUBG6fYxnuDwkcGXOJrsnNt5UGiNyTUJz2WFNCDxaXjfwXm0ofO7T4uqfneSqvzv1f38xUAq16CU9gtqTlkD+Vz1gcWE6yOEwK08uXui0j2KlVMO9bolDKc032ihk04GqshaVjwzvz24RLz0kQQWozoNkvRYrIiXzRj/V8GuNkpIgWtD9x538Zv6UiSa/sqnicGr3PTul2xYzelThaSBmdQlv2TgpzXG86woC7uaqmRm5dh72VzEgpVDUw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=OrapQZ9Ih4OGdoFEKKqr/woU2Sun4sNecZ7ducLsbWk=; b=Xi7qts4SCOyu3uOKX909wmOK3NksDvmDfILs94TTJiZ9+tpZ4lzq1kcZ+rfCDyR/JnZaEw7PBrcvWPjR71aKX1zy3/110NTDiUirzE40X5omLgtmZfIr1Apg7SKjAdBKyry1mcwWNbduxPS/XDboNxhFcJtGQOaaX5TRo3K94bkyVZODypGYPJJaCiqQqpvKgpotMbmS1pXhhwItfiYEs9XBqEvWypiEpaYsO6HgXYxRx/7NS+lzb6U9Wsqm+uJQg4RUlXeMbRuwRErTkrqsD/AtevM5654c+9jX8teoUrRXHAOxNOEl2oDEL1mcZTqnCGYEEZ7MMTMjBwBJ1iFVEA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=none; dmarc=none; dkim=none; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=hotmail.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=OrapQZ9Ih4OGdoFEKKqr/woU2Sun4sNecZ7ducLsbWk=; b=ul9or5HPbcJwMPpuIYJxOyDADqRmCq1/nd82Cm1G8hYzLKK3MaCwpfcoQMmt9cdwmS2w7vOryGRjhU/2xKDTGQcpJpGqwG4BRmdYnjSmcF9Ina+WgiXs9aeLauyK1prRidXdBQCct7TBlC0uv74spDAHWBVA3ZxoG/zLG4rP1rn/VKvMBPVThRQzfDk+1bHfILZcJUruj927sajmgbDLvUgFv/S5WjE8pV4ECP1+tlFkwOjfETX6HCrlCYo5y/WqI8USI+lLchzcy8i2be7hHv/EDRQv+Xo735jOoGtNmIhahukJbhK7sTuxjKQyxhXvPZBNyGgIAI/25YoIN4VoPw== Received: from MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM (2603:10c6:220:14c::12) by ME3P282MB3585.AUSP282.PROD.OUTLOOK.COM (2603:10c6:220:186::5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6631.47; Thu, 3 Aug 2023 02:40:19 +0000 Received: from MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM ([fe80::826:d9a5:23be:3b14]) by MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM ([fe80::826:d9a5:23be:3b14%3]) with mapi id 15.20.6652.020; Thu, 3 Aug 2023 02:40:19 +0000 From: Jinjian Song To: netdev@vger.kernel.org Cc: kuba@kernel.org, davem@davemloft.net, johannes@sipsolutions.net, ryazanov.s.a@gmail.com, loic.poulain@linaro.org, ilpo.jarvinen@linux.intel.com, ricardo.martinez@linux.intel.com, chiranjeevi.rapolu@linux.intel.com, haijun.liu@mediatek.com, edumazet@google.com, pabeni@redhat.com, chandrashekar.devegowda@intel.com, m.chetan.kumar@linux.intel.com, linuxwwan@intel.com, linuxwwan_5g@intel.com, soumya.prakash.mishra@intel.com, jesse.brandeburg@intel.com, danielwinkler@google.com, Jinjian Song Subject: [net-next 4/6] net: wwan: t7xx: Creates region & snapshot for coredump log collection Date: Thu, 3 Aug 2023 10:39:56 +0800 Message-ID: X-Mailer: git-send-email 2.34.1 X-TMN: [koObQfEkmSzVqDXScuwsE632XlzfOcoO] X-ClientProxiedBy: SG2PR03CA0096.apcprd03.prod.outlook.com (2603:1096:4:7c::24) To MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM (2603:10c6:220:14c::12) X-Microsoft-Original-Message-ID: <20230803023956.3448-1-songjinjian@hotmail.com> Precedence: bulk X-Mailing-List: netdev@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: MEYP282MB2697:EE_|ME3P282MB3585:EE_ X-MS-Office365-Filtering-Correlation-Id: bc986b7c-15ee-4076-08dc-08db93caf966 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: ftFNnG/wtUC92DYtHM5geaQXLY/2gTztx3KLE047rVn5adSeRDEEvExgCHBzMFuv3Ls34ezB4oEuYBN2sjzPGlpxQLNC9rKglWoabSZeYHj8G3KK+xftjLESQVQxkILB23i6uGL/xY8UcK//Jc8qURELPS/Cgj5uiCybJwOLSNyl+StWkov+iogtHS4b/tUjiljO1zL1QL3bi+PlgDVu/HWowIZRrfBLrAEAQ1cjttL/MxRWhkF49GFgBn9FqsPTvgvfvdvK1XBRJqdJ/TkLiziUDIjL6VK85tUkGrzDMAh+ljmJxbVuyx1tRsTKusdcddkYFYdF5fL5adkWf9vL6wEEuSnjoGlxRh9p6XRb+Wip0o/ur6gUNNUp4TAsRMPgwdCz65o1kb+uyV8brTq6sq47mKM65OZToQD3Xoc3CKJVcjMBiPPWfBl9B95wJzokY+8e8tOu29erKrhyxWJqp7cIAVpQZSn5ZEig8r+nws+D5atP++MWn5NXQLQYQXboBwBF/4Mf+fRZOlYSjshI0ttOD8HRBwDNOxsqlnY3W08= X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: 6djbs7T/Zt/2rkp2seBvWi7RW2+86H15CPPoqEOXFCejzL+7dnxHq82uTO0PNKdjKiVY5DRw9EZKqvY+Fkf7GztkZ7KGbHqlM14pLbYUq+JG/1nIEWCf16tWRoUPmdFYzKrk+0mHsb4ZeY6IjZXC0NJ4f6RRBAk8BL5NAvEnBmG05xcc4sYlopMo6ZMlYcOggba/HeiFze3YJqsFxL5YK6Ow3QADmsVtEUpBl3WeSxVL0KgMIfzyJmQdR3oTnHXKSiZWIXClOCzlq4g8iRL7pKnqpCJ/xSzwqyvCsFjUppxVKKunxus3rq93GCLK9fZSBLZXAfub5OM2j8lACwYlsiDiDTNYHJdviIrxth6rJbfWIEzN08tz5WYakCZ50dgvRTMswdcWTT/j72vpaTY6+n+1YJYXp6m0u8pPctDfbbIKuYk1hUwTwoUAIW5XAITmNSM99spLnKCEirNT6u3fpoO15oV2/EJImJIX9ft5Y/KE9imICs0i4KauipDSvWKC2+zfTc65oRL4rPso7lr5IzHlSLa/zJresFWSIqesKRW1ilWBq6xJRNq3nYNxbGstYhPNCnxzUWfIGn03I/WGh+2gggYVGPV97nhdsLl+vrGCY1uDlmrkyHXaw5wXudGG8cS17slqUAxuZgRv5fFUEqOnqXLAuhyi1oFpcvkk3+Zl6jDpLA1MwW2UVOro87o2wUVpyVaO448u5amhV6a5MgEOpq6AkAYEfByGyFL1KJjK3R+fATbMBkOB241TrJOyWZ1rGdvCB5UujhPOoPOHLnrAsXC7WdKH7UJ7akGASL/yTAlBqDjN5Ceu1yFBc09K1h37iGm3XFaQntl40YJkSngNuiImpTmdjTLQN02tScaUmeiAKOQMKdQfDjszsmOjwk7lRIyii3avFvPGA941n0QHdlrHc9cXa/MBmmUbEG9uyd9WT+t+uTFHwFVEjSinANBAa3XG9F1Nw46tvTxM12UM3TJd3t2hzQe2CkfcSmF6Y6mxKmUWN0USjMyKpTV5tWxxfBe1fu7WzkMAG0Mfx0/lKMq0wCgAUESaDZDnlVue4LeCcic+6O3KczoJ4yVnxzGkImN/u2NDuxtBJ42GTVOX122OCkledY0ax8XDv2hsEg6kz42NB1DKZuEnn2cRag5lKKd+uw2c1UHuTB2fPlRHqEcK1eSQ7WKezzM9qKUvRgCP3k9MnyldTZMuwxbAXtN44repAwXf68QFy066Pbt3l3r1S2+bMtAnyKmTf50= X-OriginatorOrg: sct-15-20-4755-11-msonline-outlook-746f3.templateTenant X-MS-Exchange-CrossTenant-Network-Message-Id: bc986b7c-15ee-4076-08dc-08db93caf966 X-MS-Exchange-CrossTenant-AuthSource: MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 03 Aug 2023 02:40:19.0808 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 84df9e7f-e9f6-40af-b435-aaaaaaaaaaaa X-MS-Exchange-CrossTenant-RMS-PersistedConsumerOrg: 00000000-0000-0000-0000-000000000000 X-MS-Exchange-Transport-CrossTenantHeadersStamped: ME3P282MB3585 X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FREEMAIL_FROM, RCVD_IN_DNSWL_NONE,SPF_HELO_PASS,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net X-Patchwork-Delegate: kuba@kernel.org From: Jinjian Song Adds support for t7xx wwan device coredump collection using devlink. In case of coredump collection when wwan device encounters an exception it reboots & stays in fastboot mode for coredump collection by host driver. On detecting exception state driver collects the core dump, creates the devlink region & reports an event to user space application for dump collection. The user space application invokes devlink region read command for dump collection. Below are the devlink commands used for coredump collection. devlink region new pci/$BDF/mr_dump devlink region read pci/$BDF/mr_dump snapshot $ID address $ADD length $LEN devlink region del pci/$BDF/mr_dump snapshot $ID Base on the v5 patch version of follown series: 'net: wwan: t7xx: fw flashing & coredump support' (https://patchwork.kernel.org/project/netdevbpf/patch/fc8bbb0b66a5ff3a489ea9857d79b374508090ef.1674307425.git.m.chetan.kumar@linux.intel.com/) Signed-off-by: Jinjian Song --- drivers/net/wwan/t7xx/t7xx_port_devlink.c | 243 +++++++++++++++++++++ drivers/net/wwan/t7xx/t7xx_port_devlink.h | 41 +++- drivers/net/wwan/t7xx/t7xx_state_monitor.c | 2 + 3 files changed, 285 insertions(+), 1 deletion(-) diff --git a/drivers/net/wwan/t7xx/t7xx_port_devlink.c b/drivers/net/wwan/t7xx/t7xx_port_devlink.c index f10804a2c0d7..0949809aa219 100644 --- a/drivers/net/wwan/t7xx/t7xx_port_devlink.c +++ b/drivers/net/wwan/t7xx/t7xx_port_devlink.c @@ -9,6 +9,11 @@ #include "t7xx_port_ap_msg.h" #include "t7xx_port_devlink.h" +static struct t7xx_devlink_region_info t7xx_devlink_region_infos[] = { + [T7XX_MRDUMP_INDEX] = {"mr_dump", T7XX_MRDUMP_SIZE}, + [T7XX_LKDUMP_INDEX] = {"lk_dump", T7XX_LKDUMP_SIZE}, +}; + static int t7xx_devlink_port_read(struct t7xx_port *port, char *buf, size_t count) { struct sk_buff *skb; @@ -177,6 +182,149 @@ static int t7xx_devlink_fb_flash_partition(struct t7xx_port *port, const char *p return t7xx_devlink_fb_flash(port, partition); } +static int t7xx_devlink_fb_cmd_send(struct t7xx_port *port, char *cmd) +{ + int len = strlen(cmd); + int ret; + + ret = t7xx_devlink_port_write(port, cmd, len); + if (ret == len) + return 0; + + return ret; +} + +static int t7xx_devlink_fb_get_core(struct t7xx_port *port) +{ + u32 mrd_mb = T7XX_MRDUMP_SIZE / (1024 * 1024); + struct t7xx_devlink *dl = port->t7xx_dev->dl; + char mcmd[T7XX_FB_MCMD_SIZE + 1]; + size_t offset_dlen = 0; + int clen, dlen, ret; + + dl->regions[T7XX_MRDUMP_INDEX].buf = vmalloc(dl->regions[T7XX_MRDUMP_INDEX].info->size); + if (!dl->regions[T7XX_MRDUMP_INDEX].buf) + return -ENOMEM; + + set_bit(T7XX_MRDUMP_STATUS, &dl->status); + ret = t7xx_devlink_fb_raw_command(T7XX_FB_CMD_OEM_MRDUMP, port, NULL); + if (ret) { + dev_err(port->dev, "%s command failed\n", T7XX_FB_CMD_OEM_MRDUMP); + goto free_mem; + } + + while (dl->regions[T7XX_MRDUMP_INDEX].info->size > offset_dlen) { + clen = t7xx_devlink_port_read(port, mcmd, sizeof(mcmd) - 1); + if (clen <= 0) + goto free_mem; + + mcmd[clen] = '\0'; + if (!strcmp(mcmd, T7XX_FB_CMD_RTS)) { + memset(mcmd, 0, sizeof(mcmd)); + ret = t7xx_devlink_fb_cmd_send(port, T7XX_FB_CMD_CTS); + if (ret < 0) { + dev_err(port->dev, "write for _CTS failed:%zu\n", + strlen(T7XX_FB_CMD_CTS)); + goto free_mem; + } + + dlen = t7xx_devlink_port_read(port, dl->regions[T7XX_MRDUMP_INDEX].buf + + offset_dlen, T7XX_FB_MDATA_SIZE); + if (dlen <= 0) { + dev_err(port->dev, "read data error(%d)\n", dlen); + ret = dlen; + goto free_mem; + } + offset_dlen += dlen; + + ret = t7xx_devlink_fb_cmd_send(port, T7XX_FB_CMD_FIN); + if (ret < 0) { + dev_err(port->dev, "_FIN failed, (Read %05zu:%05zu)\n", + strlen(T7XX_FB_CMD_FIN), offset_dlen); + goto free_mem; + } + continue; + } else if (!strcmp(mcmd, T7XX_FB_RESP_MRDUMP_DONE)) { + dev_dbg(port->dev, "%s! size:%zd\n", T7XX_FB_RESP_MRDUMP_DONE, offset_dlen); + clear_bit(T7XX_MRDUMP_STATUS, &dl->status); + return 0; + } + dev_err(port->dev, "getcore protocol error (read len %05d, response %s)\n", + clen, mcmd); + ret = -EPROTO; + goto free_mem; + } + + dev_err(port->dev, "mrdump exceeds %uMB size. Discarded!\n", mrd_mb); + +free_mem: + vfree(dl->regions[T7XX_MRDUMP_INDEX].buf); + clear_bit(T7XX_MRDUMP_STATUS, &dl->status); + return ret; +} + +static int t7xx_devlink_fb_dump_log(struct t7xx_port *port) +{ + struct t7xx_devlink *dl = port->t7xx_dev->dl; + struct t7xx_devlink_region *lkdump_region; + char rsp[T7XX_FB_RESPONSE_SIZE]; + int datasize = 0, ret; + size_t offset = 0; + + if (dl->status != T7XX_DEVLINK_IDLE) { + dev_err(&dl->t7xx_dev->pdev->dev, "Modem is busy!\n"); + return -EBUSY; + } + + set_bit(T7XX_LKDUMP_STATUS, &dl->status); + ret = t7xx_devlink_fb_raw_command(T7XX_FB_CMD_OEM_LKDUMP, port, rsp); + if (ret) { + dev_err(port->dev, "%s command returns failure\n", T7XX_FB_CMD_OEM_LKDUMP); + goto err_clear_bit; + } + + ret = kstrtoint(rsp, 16, &datasize); + if (ret) { + dev_err(port->dev, "bad value\n"); + goto err_clear_bit; + } + + lkdump_region = &dl->regions[T7XX_LKDUMP_INDEX]; + if (datasize > lkdump_region->info->size) { + dev_err(port->dev, "lkdump size is more than %dKB. Discarded!\n", + T7XX_LKDUMP_SIZE / 1024); + ret = -EFBIG; + goto err_clear_bit; + } + + lkdump_region->buf = vmalloc(lkdump_region->info->size); + if (!lkdump_region->buf) { + ret = -ENOMEM; + goto err_clear_bit; + } + + while (datasize > 0) { + int dlen = t7xx_devlink_port_read(port, lkdump_region->buf + offset, datasize); + + if (dlen <= 0) { + dev_err(port->dev, "lkdump read error ret = %d\n", dlen); + ret = dlen; + goto err_clear_bit; + } + + datasize -= dlen; + offset += dlen; + } + + dev_dbg(port->dev, "LKDUMP DONE! size:%zd\n", offset); + clear_bit(T7XX_LKDUMP_STATUS, &dl->status); + return t7xx_devlink_fb_handle_response(port, NULL); + +err_clear_bit: + clear_bit(T7XX_LKDUMP_STATUS, &dl->status); + return ret; +} + static int t7xx_devlink_flash_update(struct devlink *devlink, struct devlink_flash_update_params *params, struct netlink_ext_ack *extack) @@ -387,6 +535,65 @@ static const struct devlink_ops devlink_flash_ops = { .reload_up = t7xx_devlink_reload_up, }; +static int t7xx_devlink_region_snapshot(struct devlink *dl, const struct devlink_region_ops *ops, + struct netlink_ext_ack *extack, u8 **data) +{ + struct t7xx_devlink *t7xx_dl = devlink_priv(dl); + struct t7xx_devlink_region *region = ops->priv; + struct t7xx_port *port = t7xx_dl->port; + u8 *snapshot_mem; + + if (t7xx_dl->status != T7XX_DEVLINK_IDLE) + return -EBUSY; + + if (!strncmp(ops->name, "mr_dump", strlen("mr_dump"))) { + snapshot_mem = vmalloc(region->info->size); + memcpy(snapshot_mem, region->buf, region->info->size); + *data = snapshot_mem; + } else if (!strncmp(ops->name, "lk_dump", strlen("lk_dump"))) { + int ret; + + ret = t7xx_devlink_fb_dump_log(port); + if (ret) + return ret; + + *data = region->buf; + } + + return 0; +} + +static_assert(ARRAY_SIZE(t7xx_devlink_region_infos) == + ARRAY_SIZE(((struct t7xx_devlink *)NULL)->regions)); + +/* To create regions for dump files */ +static int t7xx_devlink_create_regions(struct t7xx_devlink *dl) +{ + int ret, i; + + for (i = 0; i < ARRAY_SIZE(t7xx_devlink_region_infos); i++) { + dl->regions[i].info = &t7xx_devlink_region_infos[i]; + dl->regions[i].ops.name = dl->regions[i].info->name; + dl->regions[i].ops.snapshot = t7xx_devlink_region_snapshot; + dl->regions[i].ops.destructor = vfree; + dl->regions[i].dlreg = devlink_region_create(dl->ctx, &dl->regions[i].ops, + T7XX_MAX_SNAPSHOTS, + t7xx_devlink_region_infos[i].size); + if (IS_ERR(dl->regions[i].dlreg)) { + ret = PTR_ERR(dl->regions[i].dlreg); + dev_err(dl->port->dev, "create devlink region failed, err %d\n", ret); + while (i >= 0) + devlink_region_destroy(dl->regions[i--].dlreg); + + return ret; + } + + dl->regions[i].ops.priv = &dl->regions[i]; + } + + return 0; +} + int t7xx_devlink_register(struct t7xx_pci_dev *t7xx_dev) { union devlink_param_value value; @@ -422,6 +629,14 @@ void t7xx_devlink_unregister(struct t7xx_pci_dev *t7xx_dev) devlink_free(dl_ctx); } +static void t7xx_devlink_work(struct work_struct *work) +{ + struct t7xx_devlink *dl; + + dl = container_of(work, struct t7xx_devlink, ws); + t7xx_devlink_fb_get_core(dl->port); +} + /** * t7xx_devlink_init - Initialize devlink to t7xx driver * @port: Pointer to port structure @@ -431,28 +646,56 @@ void t7xx_devlink_unregister(struct t7xx_pci_dev *t7xx_dev) static int t7xx_devlink_init(struct t7xx_port *port) { struct t7xx_devlink *dl = port->t7xx_dev->dl; + struct workqueue_struct *dl_wq; + int rc; + + dl_wq = create_workqueue("t7xx_devlink"); + if (!dl_wq) { + dev_err(port->dev, "create_workqueue failed\n"); + return -ENODATA; + } + INIT_WORK(&dl->ws, t7xx_devlink_work); port->rx_length_th = T7XX_MAX_QUEUE_LENGTH; dl->mode = T7XX_NORMAL_MODE; dl->status = T7XX_DEVLINK_IDLE; + dl->wq = dl_wq; dl->port = port; + rc = t7xx_devlink_create_regions(dl); + if (rc) { + destroy_workqueue(dl->wq); + dev_err(port->dev, "devlink region creation failed, rc %d\n", rc); + return -ENOMEM; + } + return 0; } static void t7xx_devlink_uninit(struct t7xx_port *port) { struct t7xx_devlink *dl = port->t7xx_dev->dl; + int i; + + vfree(dl->regions[T7XX_MRDUMP_INDEX].buf); dl->mode = T7XX_NORMAL_MODE; + destroy_workqueue(dl->wq); + + for (i = 0; i < ARRAY_SIZE(t7xx_devlink_region_infos); ++i) + devlink_region_destroy(dl->regions[i].dlreg); skb_queue_purge(&port->rx_skb_list); } static int t7xx_devlink_enable_chl(struct t7xx_port *port) { + struct t7xx_devlink *dl = port->t7xx_dev->dl; + t7xx_port_enable_chl(port); + if (dl->mode == T7XX_FB_DUMP_MODE) + queue_work(dl->wq, &dl->ws); return 0; } diff --git a/drivers/net/wwan/t7xx/t7xx_port_devlink.h b/drivers/net/wwan/t7xx/t7xx_port_devlink.h index 92f0993e7205..e01845b4f2aa 100644 --- a/drivers/net/wwan/t7xx/t7xx_port_devlink.h +++ b/drivers/net/wwan/t7xx/t7xx_port_devlink.h @@ -12,27 +12,66 @@ #define T7XX_MAX_QUEUE_LENGTH 32 #define T7XX_FB_COMMAND_SIZE 64 #define T7XX_FB_RESPONSE_SIZE 512 +#define T7XX_FB_MCMD_SIZE 64 +#define T7XX_FB_MDATA_SIZE 1024 #define T7XX_FB_RESP_COUNT 30 +#define T7XX_FB_EVENT_SIZE 50 + +#define T7XX_MAX_SNAPSHOTS 1 +#define T7XX_MRDUMP_SIZE (160 * 1024 * 1024) +#define T7XX_LKDUMP_SIZE (256 * 1024) +#define T7XX_TOTAL_REGIONS 2 + #define T7XX_FLASH_STATUS 0 +#define T7XX_MRDUMP_STATUS 1 +#define T7XX_LKDUMP_STATUS 2 #define T7XX_GET_INFO 3 - #define T7XX_DEVLINK_IDLE 0 + #define T7XX_NORMAL_MODE 0 #define T7XX_FB_DL_MODE 1 +#define T7XX_FB_DUMP_MODE 2 +#define T7XX_FB_CMD_RTS "_RTS" +#define T7XX_FB_CMD_CTS "_CTS" +#define T7XX_FB_CMD_FIN "_FIN" +#define T7XX_FB_CMD_OEM_MRDUMP "oem mrdump" +#define T7XX_FB_CMD_OEM_LKDUMP "oem dump_pllk_log" #define T7XX_FB_CMD_DOWNLOAD "download" #define T7XX_FB_CMD_FLASH "flash" #define T7XX_FB_CMD_REBOOT "reboot" +#define T7XX_FB_RESP_MRDUMP_DONE "MRDUMP08_DONE" #define T7XX_FB_RESP_OKAY "OKAY" #define T7XX_FB_RESP_FAIL "FAIL" #define T7XX_FB_RESP_DATA "DATA" #define T7XX_FB_RESP_INFO "INFO" #define T7XX_FB_CMD_GET_VER "get_version" +/* Internal region indexes */ +enum t7xx_regions { + T7XX_MRDUMP_INDEX, + T7XX_LKDUMP_INDEX, +}; + +struct t7xx_devlink_region_info { + const char *name; + size_t size; +}; + +struct t7xx_devlink_region { + struct t7xx_devlink_region_info *info; + struct devlink_region_ops ops; + struct devlink_region *dlreg; + void *buf; +}; + struct t7xx_devlink { + struct t7xx_devlink_region regions[T7XX_TOTAL_REGIONS]; struct t7xx_pci_dev *t7xx_dev; + struct workqueue_struct *wq; struct t7xx_port *port; + struct work_struct ws; struct devlink *ctx; unsigned long status; u8 mode; diff --git a/drivers/net/wwan/t7xx/t7xx_state_monitor.c b/drivers/net/wwan/t7xx/t7xx_state_monitor.c index a6147f2324a6..500dadaddb30 100644 --- a/drivers/net/wwan/t7xx/t7xx_state_monitor.c +++ b/drivers/net/wwan/t7xx/t7xx_state_monitor.c @@ -244,6 +244,8 @@ static void t7xx_lk_stage_event_handling(struct t7xx_fsm_ctl *ctl, unsigned int if (lk_event == LK_EVENT_CREATE_POST_DL_PORT) md->t7xx_dev->dl->mode = T7XX_FB_DL_MODE; + else + md->t7xx_dev->dl->mode = T7XX_FB_DUMP_MODE; port->port_conf->ops->enable_chl(port); t7xx_cldma_start(md_ctrl); From patchwork Thu Aug 3 02:40:33 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Jinjian Song X-Patchwork-Id: 13339174 X-Patchwork-Delegate: kuba@kernel.org Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net [23.128.96.19]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 0341B46A7 for ; Thu, 3 Aug 2023 02:41:04 +0000 (UTC) Received: from AUS01-SY4-obe.outbound.protection.outlook.com (mail-sy4aus01olkn2181.outbound.protection.outlook.com [40.92.62.181]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id F152AB2 for ; Wed, 2 Aug 2023 19:41:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=FZcc/2/tLlWwckWFnvVq69C6LmfFVifOXI0Am0gHWQBr1RIXKxicUxR/LLb+Te3S+05PjuWTb9TUR1XAv3oGurbY+cbpltyf8ftmBGSiq2X9Rgqvt2ppl93XK2de2EnZevfmbL3J/oVWw32g23MJTDhxuMAxowVKuzeD8LynB/dIo7CUk6ywE9YQu+vKXa4MJc2s4KztHlaH7Yr9N8lfTSG0kgSNU68oxEUDfjncWBdXu55lR476qbijExkcLsJ2iGFWpvTbUS/UOCg1BEv3207JkLtuMovXAGnsTufDe0Zn6bObtYx5Kyt1T5+0cRmnEgLkeyaBJrMJJcfhnc/e/A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=07O5d5GfwqZ3LC1XdbdDCYcNLN8JLw41NrQzUCcEqJ8=; b=g/R+zh1OcEhoIe6P+iE710PKf9tAxPpVEGxVGXp1UrOhyTUZcBc1dxoW6+FAj0ZN61oYCt/0naCt+Xa+q3UjkL4YiZPNQZm5+RqXBxaNvl/7CYzXtvb0TWjelHDY1g5Dam2HxQFn0rJMDbwVtg21e0XN+At22zDHP3t9Ge+LasofB7r1V2kNXFx8P3U6LR7VTnuXI6hRE1b9/kTJsAdVWeCs+dwdGu9avr79jRz8NGIjFjoP2s6B3xPRYYy7qrU7GbxfpmfzmWor1EmAvJ1g6aVbhgcGPn5CmV0YUtR+aRIAjfKceqp+8IHCdMEb/SN6fClFZrwAflubdu2SDxRMpA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=none; dmarc=none; dkim=none; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=hotmail.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=07O5d5GfwqZ3LC1XdbdDCYcNLN8JLw41NrQzUCcEqJ8=; b=QxmrN4sv4L9Ma4c5d7tdMyXVeLKD8rXTcaLTVM4kPf55jymPYCpkpxCWMkH3ucFVQzKWMtGvZVwCeCH5d9tGUr1W77zJoZBmYZNBwXbxdPqRfR4VWl7YThF6o/78bIMOAR6V9rK7PJLEFHWp+E/87X6dS9McbGYrx5CX2lFizXAZ6OFqceHET1nSro/K7POZkRbXWKN5139x0zRxVtaBCImQSRpF+9I5kviN08x9hpjTm876QaC1xREmFYq04nOVn+uSuD55Cg0weJRtjr3LmCNAb1jVWtskMtgtae53Yd9ugyPtpQnQzir/vLE+hQjqfDVZKczFusb0qJiodRGHnw== Received: from MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM (2603:10c6:220:14c::12) by ME3P282MB3585.AUSP282.PROD.OUTLOOK.COM (2603:10c6:220:186::5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6631.47; Thu, 3 Aug 2023 02:40:55 +0000 Received: from MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM ([fe80::826:d9a5:23be:3b14]) by MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM ([fe80::826:d9a5:23be:3b14%3]) with mapi id 15.20.6652.020; Thu, 3 Aug 2023 02:40:55 +0000 From: Jinjian Song To: netdev@vger.kernel.org Cc: kuba@kernel.org, davem@davemloft.net, johannes@sipsolutions.net, ryazanov.s.a@gmail.com, loic.poulain@linaro.org, ilpo.jarvinen@linux.intel.com, ricardo.martinez@linux.intel.com, chiranjeevi.rapolu@linux.intel.com, haijun.liu@mediatek.com, edumazet@google.com, pabeni@redhat.com, chandrashekar.devegowda@intel.com, m.chetan.kumar@linux.intel.com, linuxwwan@intel.com, linuxwwan_5g@intel.com, soumya.prakash.mishra@intel.com, jesse.brandeburg@intel.com, danielwinkler@google.com, Jinjian Song Subject: [net-next 5/6] net: wwan: t7xx: Adds sysfs attribute of modem event Date: Thu, 3 Aug 2023 10:40:33 +0800 Message-ID: X-Mailer: git-send-email 2.34.1 X-TMN: [DENDRDkLl1+gg54x4RoChMAXFI+IUa4w] X-ClientProxiedBy: SGAP274CA0006.SGPP274.PROD.OUTLOOK.COM (2603:1096:4:b6::18) To MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM (2603:10c6:220:14c::12) X-Microsoft-Original-Message-ID: <20230803024033.3465-1-songjinjian@hotmail.com> Precedence: bulk X-Mailing-List: netdev@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: MEYP282MB2697:EE_|ME3P282MB3585:EE_ X-MS-Office365-Filtering-Correlation-Id: 2a75bb37-71a6-45eb-a877-08db93cb0f2d X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: C0Ky4fSFS5ppbxihwmU8IGISynrC1bOUlb+krPjALvokRQ0758Hj1RM+kazvZTVuspQfzb7ax4H9WY1/Ku0JGGPfbaxYWHw5VVh1gf+Ka4HMnVeSi3qJYWttggnDHpgVlKP70jUNLSyyAGtcGF67tIbjKFUfJEMxqfNU+4163EyjuhCx1pr9Q0ENRf7u/1Li/LCIIUiLX80GLFw+CLlzRwgGzoPSpaOOOYUMRNsgmJVV1WYj66p1f+W8Wn+pzY+64eiGDw+1N+2wrTd5C27Y10m3S9nurzXG0QN7K32S6ryfJT1/nIcGdtovdCZ+yT0xSxiuwljQcnv6/xAZA4+QyGmlxYyqNsnrBXfVu0Zi0eD5KUxzPd+KkUBfi7SrJ4ByrpW2En4mUuGRmQh85MQ2etHfsC7i8ON9Ps06I0xkd7EsvSRbz9AeBsB601U8gF3hEFdcDALgbmOitRtZurdlkpie/KXiiJASCahHbUGrp41J8ZTF/U9Kk6huGukzCyTrMmbWa+b1qpIY6I7k7RIfZZN8bVsrSTW6F15YwGPKnyU= X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: Y0lZ7sgXBHpKYkVxUlwpYGtpJQ32Cy5S0cwDq+0KGoC0+jLKYBhZalT8EEMf6SnhzrtcvBwsCXTNNaFQ/Ze/v5BBFxPoCTKBIXf+0Hw+u7nQTxzg2xKKgBb8oCEcl8+vDu8uNstQ4i2nnfdhe2XH9DUJHsMkUWSUrrDfyXrxnc88k9mAYU/anm/CI+lJ88TntxunOgrkvV/tlgBv6dTg6qieBRdV3ZXNgGcLjW5VpiTozNrSbs4WIykmXk49+43NI/8K+gsuPlVaA3B+Tiltr/vBxyoWkEpOcWzP6GaAeEii8U82AB7IZ+juzvZoECgBmn0uQYZsKoeX/SZV07ZGPy6M5lEAmLtivjKEkvf4RkdlAA8RQ7GsNmSlCGT9KwcHg+3i/NelC/6JG/wJdDhLGsygz7UNdY+ArNSYvBDSvyvtZBMdLzvmP7F7ydixA9HMvyDFczIjKomxIMuZkXBG105Qrhh7HzLQsqX1iew2XeJjAlfefZQ2+7Fi98SXsgFGGD3iCTeGc8tgZj1aJPsVfYi30f7cytKF3LAbLuK9xkp+h6nq/cKOZ13YKiR5bRl1hXrwq8MvWjVSTjFUYcKItH1XcTrtbcfeuNhk57T4O/rbGbPePjraybFnof2NN/HXwycUmfg1ma/if8MNix9w2fmmvMB2nw0dWzwS7XckccktIXa3/SS8ZSUtZ9G15on2Uc3wZmjjuBKb7X2mABtFk0ZyQQHQZy3gVVe024KB8V+BLKvp6bfnTmBCibDUJZCb3OQ+LEscY04wvv4vfdUZaVMWDpmgisA6wGZbTi6BpVOJLl4JJKSuS8V0bHRgXEKScCxVM1TcCo0MoWA5xJe3LWAm/vAUtSJm8LnFXIj3DUjAJoiuqZHZHEVAHPqTanJGaBVsazpCFDBeYe2V+643qK2b0lKx5TbnpOHpkugy3+bA85De6+UONU8X4TEUzCDcgm3rIiao/H5uGLbdGY8x019TVr8SILcGdHCLjdym9hVpFUgJqpLWPFTG5ewbXesTHCvUWCw6XpXtBQVHreAuofE6yNpEzvsTZvno3KXWhKP6irRFwIxoEHA1a2doGRiDrBLHC7/ofQjHI2ghMQO/2dy/pRxQQElQ/a92v3WmleSHeXe6Af0Taip0aK9CxGK6i7y7coXQtZWtpaKlWnFAu5RvGxLu9YEtUKfM+FGgVwXtcsJ6A098YmjsfI6hcb5pMmnDGaSEaJJVlLSFBUjwsdeibqYtkB8ZTi9GybNn85I= X-OriginatorOrg: sct-15-20-4755-11-msonline-outlook-746f3.templateTenant X-MS-Exchange-CrossTenant-Network-Message-Id: 2a75bb37-71a6-45eb-a877-08db93cb0f2d X-MS-Exchange-CrossTenant-AuthSource: MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 03 Aug 2023 02:40:55.1519 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 84df9e7f-e9f6-40af-b435-aaaaaaaaaaaa X-MS-Exchange-CrossTenant-RMS-PersistedConsumerOrg: 00000000-0000-0000-0000-000000000000 X-MS-Exchange-Transport-CrossTenantHeadersStamped: ME3P282MB3585 X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FREEMAIL_FROM, RCVD_IN_DNSWL_BLOCKED,RCVD_IN_MSPIKE_H2,SPF_HELO_PASS,SPF_PASS, T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net X-Patchwork-Delegate: kuba@kernel.org From: Jinjian Song Adds support for t7xx wwan device firmware flashing & coredump collection using devlink. Provides sysfs attribute on user space to query the event from modem about flashing/coredump/reset. Base on the v5 patch version of follow series: 'net: wwan: t7xx: fw flashing & coredump support' (https://patchwork.kernel.org/project/netdevbpf/patch/fc8bbb0b66a5ff3a489ea9857d79b374508090ef.1674307425.git.m.chetan.kumar@linux.intel.com/) Signed-off-by: Jinjian Song --- drivers/net/wwan/t7xx/t7xx_modem_ops.c | 1 + drivers/net/wwan/t7xx/t7xx_pci.c | 62 ++++++++++++++++++++++ drivers/net/wwan/t7xx/t7xx_pci.h | 17 ++++++ drivers/net/wwan/t7xx/t7xx_port_devlink.c | 14 +++++ drivers/net/wwan/t7xx/t7xx_port_devlink.h | 1 + drivers/net/wwan/t7xx/t7xx_state_monitor.c | 7 +++ 6 files changed, 102 insertions(+) diff --git a/drivers/net/wwan/t7xx/t7xx_modem_ops.c b/drivers/net/wwan/t7xx/t7xx_modem_ops.c index cbd65aa48721..4de75874f1b5 100644 --- a/drivers/net/wwan/t7xx/t7xx_modem_ops.c +++ b/drivers/net/wwan/t7xx/t7xx_modem_ops.c @@ -192,6 +192,7 @@ static irqreturn_t t7xx_rgu_isr_thread(int irq, void *data) { struct t7xx_pci_dev *t7xx_dev = data; + atomic_set(&t7xx_dev->event, T7XX_RESET); msleep(RGU_RESET_DELAY_MS); t7xx_reset_device_via_pmic(t7xx_dev); return IRQ_HANDLED; diff --git a/drivers/net/wwan/t7xx/t7xx_pci.c b/drivers/net/wwan/t7xx/t7xx_pci.c index 5e9b954f39ce..f1723c02376e 100644 --- a/drivers/net/wwan/t7xx/t7xx_pci.c +++ b/drivers/net/wwan/t7xx/t7xx_pci.c @@ -2,6 +2,7 @@ /* * Copyright (c) 2021, MediaTek Inc. * Copyright (c) 2021-2022, Intel Corporation. + * Copyright (c) 2023, Fibocom Wireless Inc. * * Authors: * Haijun Liu @@ -14,6 +15,7 @@ * Chiranjeevi Rapolu * Eliot Lee * Moises Veleta + * Jinjian Song */ #include @@ -60,6 +62,57 @@ enum t7xx_pm_state { MTK_PM_RESUMED, }; +static ssize_t t7xx_event_show(struct device *dev, struct device_attribute *attr, + char *buf) +{ + enum t7xx_event event = T7XX_UNKNOWN; + struct pci_dev *pdev; + struct t7xx_pci_dev *t7xx_dev; + + pdev = to_pci_dev(dev); + t7xx_dev = pci_get_drvdata(pdev); + if (!t7xx_dev) + return -ENODEV; + + event = atomic_read(&t7xx_dev->event); + if (event == T7XX_READY) { + return sprintf(buf, "T7XX_MODEM_READY\n"); + } else if (event == T7XX_RESET) { + return sprintf(buf, "T7XX_RESET\n"); + } else if (event == T7XX_FASTBOOT_DL_MODE) { + return sprintf(buf, "T7XX_MODEM_FASTBOOT_DL_MODE\n"); + } else if (event == T7XX_FLASH_SUCCESS) { + return sprintf(buf, "T7XX_FLASHING_SUCCESS\n"); + } else if (event == T7XX_FLASH_FAILURE) { + return sprintf(buf, "T7XX_FLASHING_FAILURE\n"); + } else if (event == T7XX_FASTBOOT_DUMP_MODE) { + return sprintf(buf, "T7XX_MODEM_FASTBOOT_DUMP_MODE\n"); + } else if (event == T7XX_MRDUMP_READY) { + return sprintf(buf, "T7XX_MRDUMP_READY size:%zu\n", + t7xx_dev->dl->regions[T7XX_MRDUMP_INDEX].info->dump_size); + } else if (event == T7XX_LKDUMP_READY) { + return sprintf(buf, "T7XX_LKDUMP_READY size:%zu\n", + t7xx_dev->dl->regions[T7XX_LKDUMP_INDEX].info->dump_size); + } else if (event == T7XX_MRDUMP_DISCARD) { + return sprintf(buf, "T7XX_MRDUMP_DISCARDED\n"); + } else if (event == T7XX_LKDUMP_DISCARD) { + return sprintf(buf, "T7XX_LKDUMP_DISCARDED\n"); + } + + return sprintf(buf, "T7XX_UNKNOWN\n"); +} + +static DEVICE_ATTR_RO(t7xx_event); + +static struct attribute *t7xx_event_attr[] = { + &dev_attr_t7xx_event.attr, + NULL +}; + +static const struct attribute_group t7xx_event_attribute_group = { + .attrs = t7xx_event_attr, +}; + static void t7xx_dev_set_sleep_capability(struct t7xx_pci_dev *t7xx_dev, bool enable) { void __iomem *ctrl_reg = IREG_BASE(t7xx_dev) + T7XX_PCIE_MISC_CTRL; @@ -734,8 +787,17 @@ static int t7xx_pci_probe(struct pci_dev *pdev, const struct pci_device_id *id) t7xx_pcie_mac_interrupts_dis(t7xx_dev); + ret = sysfs_create_group(&t7xx_dev->pdev->dev.kobj, + &t7xx_event_attribute_group); + if (ret) { + t7xx_md_exit(t7xx_dev); + goto err_devlink_unregister; + } + ret = t7xx_interrupt_init(t7xx_dev); if (ret) { + sysfs_remove_group(&t7xx_dev->pdev->dev.kobj, + &t7xx_event_attribute_group); t7xx_md_exit(t7xx_dev); goto err_devlink_unregister; } diff --git a/drivers/net/wwan/t7xx/t7xx_pci.h b/drivers/net/wwan/t7xx/t7xx_pci.h index 6777581cd540..0d82f9e99243 100644 --- a/drivers/net/wwan/t7xx/t7xx_pci.h +++ b/drivers/net/wwan/t7xx/t7xx_pci.h @@ -2,6 +2,7 @@ * * Copyright (c) 2021, MediaTek Inc. * Copyright (c) 2021-2022, Intel Corporation. + * Copyright (c) 2023, Fibocom Wireless Inc. * * Authors: * Haijun Liu @@ -12,6 +13,7 @@ * Amir Hanania * Chiranjeevi Rapolu * Moises Veleta + * Jinjian Song */ #ifndef __T7XX_PCI_H__ @@ -84,6 +86,7 @@ struct t7xx_pci_dev { struct dentry *debugfs_dir; #endif struct t7xx_devlink *dl; + atomic_t event; }; enum t7xx_pm_id { @@ -115,6 +118,20 @@ struct md_pm_entity { void *entity_param; }; +enum t7xx_event { + T7XX_UNKNOWN, + T7XX_READY, + T7XX_RESET, + T7XX_FASTBOOT_DL_MODE, + T7XX_FLASH_SUCCESS, + T7XX_FLASH_FAILURE, + T7XX_FASTBOOT_DUMP_MODE, + T7XX_MRDUMP_READY, + T7XX_LKDUMP_READY, + T7XX_MRDUMP_DISCARD, + T7XX_LKDUMP_DISCARD, +}; + void t7xx_pci_disable_sleep(struct t7xx_pci_dev *t7xx_dev); void t7xx_pci_enable_sleep(struct t7xx_pci_dev *t7xx_dev); int t7xx_pci_sleep_disable_complete(struct t7xx_pci_dev *t7xx_dev); diff --git a/drivers/net/wwan/t7xx/t7xx_port_devlink.c b/drivers/net/wwan/t7xx/t7xx_port_devlink.c index 0949809aa219..5d2c81a29ab5 100644 --- a/drivers/net/wwan/t7xx/t7xx_port_devlink.c +++ b/drivers/net/wwan/t7xx/t7xx_port_devlink.c @@ -246,11 +246,14 @@ static int t7xx_devlink_fb_get_core(struct t7xx_port *port) continue; } else if (!strcmp(mcmd, T7XX_FB_RESP_MRDUMP_DONE)) { dev_dbg(port->dev, "%s! size:%zd\n", T7XX_FB_RESP_MRDUMP_DONE, offset_dlen); + dl->regions[T7XX_MRDUMP_INDEX].info->dump_size = offset_dlen; + atomic_set(&port->t7xx_dev->event, T7XX_MRDUMP_READY); clear_bit(T7XX_MRDUMP_STATUS, &dl->status); return 0; } dev_err(port->dev, "getcore protocol error (read len %05d, response %s)\n", clen, mcmd); + atomic_set(&port->t7xx_dev->event, T7XX_MRDUMP_DISCARD); ret = -EPROTO; goto free_mem; } @@ -293,6 +296,7 @@ static int t7xx_devlink_fb_dump_log(struct t7xx_port *port) if (datasize > lkdump_region->info->size) { dev_err(port->dev, "lkdump size is more than %dKB. Discarded!\n", T7XX_LKDUMP_SIZE / 1024); + atomic_set(&port->t7xx_dev->event, T7XX_LKDUMP_DISCARD); ret = -EFBIG; goto err_clear_bit; } @@ -317,6 +321,8 @@ static int t7xx_devlink_fb_dump_log(struct t7xx_port *port) } dev_dbg(port->dev, "LKDUMP DONE! size:%zd\n", offset); + lkdump_region->info->dump_size = offset; + atomic_set(&port->t7xx_dev->event, T7XX_LKDUMP_READY); clear_bit(T7XX_LKDUMP_STATUS, &dl->status); return t7xx_devlink_fb_handle_response(port, NULL); @@ -360,6 +366,10 @@ static int t7xx_devlink_flash_update(struct devlink *devlink, sprintf(flash_status, "%s %s", "flashing", !ret ? "success" : "failure"); devlink_flash_update_status_notify(devlink, flash_status, params->component, 0, 0); + if (ret) + atomic_set(&port->t7xx_dev->event, T7XX_FLASH_FAILURE); + else + atomic_set(&port->t7xx_dev->event, T7XX_FLASH_SUCCESS); clear_bit(T7XX_FLASH_STATUS, &dl->status); err_out: @@ -414,9 +424,13 @@ static int t7xx_devlink_reload_up(struct devlink *devlink, u32 *actions_performed, struct netlink_ext_ack *extack) { + struct t7xx_devlink *dl = devlink_priv(devlink); + *actions_performed = BIT(action); switch (action) { case DEVLINK_RELOAD_ACTION_DRIVER_REINIT: + atomic_set(&dl->t7xx_dev->event, T7XX_RESET); + return 0; case DEVLINK_RELOAD_ACTION_FW_ACTIVATE: return 0; default: diff --git a/drivers/net/wwan/t7xx/t7xx_port_devlink.h b/drivers/net/wwan/t7xx/t7xx_port_devlink.h index e01845b4f2aa..f5442a7f3431 100644 --- a/drivers/net/wwan/t7xx/t7xx_port_devlink.h +++ b/drivers/net/wwan/t7xx/t7xx_port_devlink.h @@ -57,6 +57,7 @@ enum t7xx_regions { struct t7xx_devlink_region_info { const char *name; size_t size; + size_t dump_size; }; struct t7xx_devlink_region { diff --git a/drivers/net/wwan/t7xx/t7xx_state_monitor.c b/drivers/net/wwan/t7xx/t7xx_state_monitor.c index 500dadaddb30..db76bc6fe660 100644 --- a/drivers/net/wwan/t7xx/t7xx_state_monitor.c +++ b/drivers/net/wwan/t7xx/t7xx_state_monitor.c @@ -249,6 +249,12 @@ static void t7xx_lk_stage_event_handling(struct t7xx_fsm_ctl *ctl, unsigned int port->port_conf->ops->enable_chl(port); t7xx_cldma_start(md_ctrl); + + if (lk_event == LK_EVENT_CREATE_POST_DL_PORT) + atomic_set(&md->t7xx_dev->event, T7XX_FASTBOOT_DL_MODE); + else + atomic_set(&md->t7xx_dev->event, T7XX_FASTBOOT_DUMP_MODE); + break; default: @@ -332,6 +338,7 @@ static void fsm_routine_ready(struct t7xx_fsm_ctl *ctl) ctl->curr_state = FSM_STATE_READY; t7xx_fsm_broadcast_ready_state(ctl); + atomic_set(&md->t7xx_dev->event, T7XX_READY); t7xx_md_event_notify(md, FSM_READY); } From patchwork Thu Aug 3 02:41:07 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Jinjian Song X-Patchwork-Id: 13339175 X-Patchwork-Delegate: kuba@kernel.org Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net [23.128.96.19]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 2F7F7187B for ; Thu, 3 Aug 2023 02:41:49 +0000 (UTC) Received: from AUS01-SY4-obe.outbound.protection.outlook.com (mail-sy4aus01olkn2151.outbound.protection.outlook.com [40.92.62.151]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2CA94E2 for ; Wed, 2 Aug 2023 19:41:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=YFEDHZ7eRLhgKLnvvxR3wgISq5i3vC2LVyQGyl8YMoiT36g7wQOy+JPsRuhtegcjVmUTsqIi7WXnlnB/vWceUQvzgKpP6O5ry/6wrgCzO03XQVlS2ldpUqaSGORh7CsfKTW4qr0GmSvbYQhqaA3zNeukn+UVL0M8G3dHRq0vN5J5+CaYF0tr1YTsphdriwiyzWStN0IfSkJBkYk1daPP1KCri4r/gT9rYD2rD23TaoQl8/GGgsPQJnUoY5N1hrzkoz9mufKCS29wDjoRDvKC11HdfOloc3bZATuainScTjehQ2ejBXrnv2O6zPFLzzTag4L3WGn0newRyDlqaILsJQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=Kbb2137+Um2SBCJLfyA8j7g0pN7Kfw2jjoEAmW+S5/4=; b=L2LBbMHS4BMX0hIeUZBsJdHjGsaji+eEjq5tmya8PBEcIK+VVzXzeYeaLCjzldYyIt7JZBSo5IVdfa3kwMtmzDO8Wowv9DmN6g61PniKhrTGRED3kn/UTIY+yT/SdD6sfdNdVO+YdWiBqAYvOO0woCdVfeg/ix0n3RVf044EguFErhmeLMx6lPihzsUsK8cBQx6Hrx1aVC1Q4teRZRntEIMQvSm4zxGz+yfx9iTSBPy7xnf+WZX+3wbrKDnR0cjZQGiDv/mhu/wu4gWF26k12FrOaXy1hfjqVw1YX2km53RHz/KPscnuCW5WqJ+I+XvdsHPaEwiDxEhxKdqPIPn6wA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=none; dmarc=none; dkim=none; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=hotmail.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=Kbb2137+Um2SBCJLfyA8j7g0pN7Kfw2jjoEAmW+S5/4=; b=OCnOdwryx1t2Wgf/Nl6sUMMqlPobP4wrV8QZx5vhiaV0zK5D3bd4LBbns6zyZyDtOq0LG5pB20OawzBA4uGcs1azG/DcZMHt7sQBDHv8KjEDGk5G3WzwIV7xfLkdOT2JpV3jMHZDdljCa/3fo5NdkQ3LPcH8W+Atdxe8dtmxPU9D/iACYj001UxLz8yVZyvfkrCn5DBgxxRPHIMH02pCiHRgoJjfioDcThEAnxkrNRBHuSRdIDXH77nsd3JxEePrI8cPYBMau5A4ipXE5s2Ekzr/KgQUybnbiO9Cj8UrWb3R9v9o/FKDO013B89893bbaJ7VGS46YzU+4PJmHAoXPA== Received: from MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM (2603:10c6:220:14c::12) by ME3P282MB3585.AUSP282.PROD.OUTLOOK.COM (2603:10c6:220:186::5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6631.47; Thu, 3 Aug 2023 02:41:39 +0000 Received: from MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM ([fe80::826:d9a5:23be:3b14]) by MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM ([fe80::826:d9a5:23be:3b14%3]) with mapi id 15.20.6652.020; Thu, 3 Aug 2023 02:41:39 +0000 From: Jinjian Song To: netdev@vger.kernel.org Cc: kuba@kernel.org, davem@davemloft.net, johannes@sipsolutions.net, ryazanov.s.a@gmail.com, loic.poulain@linaro.org, ilpo.jarvinen@linux.intel.com, ricardo.martinez@linux.intel.com, chiranjeevi.rapolu@linux.intel.com, haijun.liu@mediatek.com, edumazet@google.com, pabeni@redhat.com, chandrashekar.devegowda@intel.com, m.chetan.kumar@linux.intel.com, linuxwwan@intel.com, linuxwwan_5g@intel.com, soumya.prakash.mishra@intel.com, jesse.brandeburg@intel.com, danielwinkler@google.com, Jinjian Song Subject: [net-next 6/6] net: wwan: t7xx: Devlink documentation Date: Thu, 3 Aug 2023 10:41:07 +0800 Message-ID: X-Mailer: git-send-email 2.34.1 X-TMN: [1grYUK2lcLrpAzrai2zSgwY/tos+rC4M] X-ClientProxiedBy: SG2PR02CA0046.apcprd02.prod.outlook.com (2603:1096:3:18::34) To MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM (2603:10c6:220:14c::12) X-Microsoft-Original-Message-ID: <20230803024107.3480-1-songjinjian@hotmail.com> Precedence: bulk X-Mailing-List: netdev@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: MEYP282MB2697:EE_|ME3P282MB3585:EE_ X-MS-Office365-Filtering-Correlation-Id: 33785683-70bd-4451-2100-08db93cb29db X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: cOSr3MNsMvRj9R0zQw7uGZ/KCvf39EZCsbnCnoh5rQbaLuNBU7OHb4uzZbAckI7BkzG1TglyV7RHPeocE00L6kUujv4kZ1Um2kamAL74gJY1lFLyNnQp/zXHwDOHqGJ4BrBZJYsV46PLPVhc8D4eNt9SYTN5OqzmcRahQRe3HZzhcm9Fwn6SSGzwCQgkbyEbNJqHbuVOjT17Zey5YklD5sGYJKIV0uZ3awzhI6gWQje0w5yeSQGq1uETRMFJNfge/Z1EZpeggjJxoHc2mhmBWU/S3c/bw+WZAtvCVfeMX5XOgCLZVrgoN41sXfjTE6PaZSuja743njhTZkjh8nq/CO/JF01QLeCMnr/Er0h82/+pwDH6Cn60dv+j6hFUN3gIu8io7l5fmJcMGxLHq2a4DY7YV9luo7xC77jdf2vNgNsvS80izDWwowGyq4/p2X2FgD5tJbNE33nq7RlboHec8mxsSESHag3Ikcg1MSO+zhQGNmhd+M9rm+xlKikBkVUdlvNa2ByjQpTsF/JZ1Q2pHOYm06oYx9AqTMfk719o0/U= X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: 2WGJDaEYYgyUebBCSL35O2MewEyu2NrJY9e1pQE3XxEqLmjD55arL9CQ2WA6DRe64lgkaxSEb5G0DrYHELJK5TAU8WH/vHd7IiPmf6KMtZrdbHNxl61PXjOpw+F73ZRXA/3asdq/67mW5MyeP2tRJJa6oaFSpzZXj1NnpQ6KY1leihaBgKZ3lteLRBvfcvUp63yR4kx/r9Mn9uAO+dQcJ7VqnjAvQ3W4H00AFWPdpzpGk3E8mBgUCKsBlADOQZVvG4zpRECBbJov8yr+NDiHwq5PA8SdnK62NaqbErFPoqzdUvCSyR8gwTK9eDGoEqW4kZUbQrhhWwXm0EIlVLVZfEWCjeNOtelhPjAf4R6OK5BUU7tajv6lngubgSDV38t99asZrvMtlX1LRa1fldwlK+K9PlIave2Jksguoi/jHNlKGgTPOP9cCsjE+wqrangekqz0Pq67ncVQFeYqTDv1iPqn6Dp4GweI07iepvDcS3mBpua903zgMSpTRhSXmHPVqFHweCiw84xXnkor/EIFoMgcbpOQmk6LSHW2zL/r+SEXpQGj6fQMfj2ckU7I5+SL4LrtggY7eHb6mfnWUt60WqwFmYxWwvlfba9XLerP7orD0xbEtYh4+Lgw6gj2YNBpUn30Ds156uFOibHCDGukNtjblr5Rrwyqcc9GGA9tehfGjSE0enW/XPMUon5COBn6GkmBf3yqEhPKlz7i4un50tcoVuMZWlM1q8eys74O4BUTZR/rrvWjkAsgHQBiZ5BhKADiE2XSI6WLEaQSmHzoVHgbkdT2NQ/BJ7AkGiAO8gcYxMTmmAETiskRn9YvlszOA1QIR2q5ACsy9F84jK2QEPvHGWqd5l38HJkvVxb6mmrnMrTPIMvNxxF3GFMpibSqLZRvCO2qRYRCpX6TBb5h3a9Tg333mm9QMcNu+3qekilvDMU/sPa61+ZVTrG2L8UO1QLxwzv036oUcfZvClO1DlXNLrurjUDJHSjcgqcALAR/cOZFgG7iXijd1aFT0BkUi7Mq4NeZAH/3TLYkFvCSZVuMEqDnD5i20CLgq8UksZLRyrSpjjBDCRO9O0dwmPjmfqvldXqhspIQBT+Rn8kY8f45/7kpiKQFtEd7v9fCmtRENyHoM72INIp4/Bp1mNEaYMnkG/UiiU7BU97fPKe3Eit+ikVgoG7qWvugutfxaXFwrV+chzEtX/AKq5Xmouv3LrmKAu93CO7/GVjPvm5F9zKxmZCDBCmTOLrRnRHReCA= X-OriginatorOrg: sct-15-20-4755-11-msonline-outlook-746f3.templateTenant X-MS-Exchange-CrossTenant-Network-Message-Id: 33785683-70bd-4451-2100-08db93cb29db X-MS-Exchange-CrossTenant-AuthSource: MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 03 Aug 2023 02:41:39.8389 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 84df9e7f-e9f6-40af-b435-aaaaaaaaaaaa X-MS-Exchange-CrossTenant-RMS-PersistedConsumerOrg: 00000000-0000-0000-0000-000000000000 X-MS-Exchange-Transport-CrossTenantHeadersStamped: ME3P282MB3585 X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FREEMAIL_FROM, RCVD_IN_DNSWL_NONE,RCVD_IN_MSPIKE_H2,SPF_HELO_PASS,SPF_PASS, T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net X-Patchwork-Delegate: kuba@kernel.org From: Jinjian Song Document the t7xx devlink commands usage for firmware flashing & coredump collection. Base on the v5 patch version of follow series: 'net: wwan: t7xx: fw flashing & coredump support' (https://patchwork.kernel.org/project/netdevbpf/patch/f902d4a0cb807a205687f7e693079fba72ca7341.1674307425.git.m.chetan.kumar@linux.intel.com/) Signed-off-by: Jinjian Song --- Documentation/networking/devlink/index.rst | 1 + Documentation/networking/devlink/t7xx.rst | 232 +++++++++++++++++++++ 2 files changed, 233 insertions(+) create mode 100644 Documentation/networking/devlink/t7xx.rst diff --git a/Documentation/networking/devlink/index.rst b/Documentation/networking/devlink/index.rst index b49749e2b9a6..f101781105ca 100644 --- a/Documentation/networking/devlink/index.rst +++ b/Documentation/networking/devlink/index.rst @@ -67,3 +67,4 @@ parameters, info versions, and other features it supports. iosm octeontx2 sfc + mtk_t7xx diff --git a/Documentation/networking/devlink/t7xx.rst b/Documentation/networking/devlink/t7xx.rst new file mode 100644 index 000000000000..1f5108338ef0 --- /dev/null +++ b/Documentation/networking/devlink/t7xx.rst @@ -0,0 +1,232 @@ +.. SPDX-License-Identifier: GPL-2.0 + +==================== +t7xx devlink support +==================== + +This document describes the devlink features implemented by the ``t7xx`` +device driver. + +Parameters +========== +The ``t7xx`` driver implements the following driver-specific parameters. + +.. list-table:: Driver-specific parameters + :widths: 5 5 5 85 + + * - Name + - Type + - Mode + - Description + * - ``fastboot`` + - boolean + - driverinit + - Set this param to enter fastboot mode. + +Flash Update +============ + +The ``t7xx`` driver implements the flash update using the ``devlink-flash`` +interface. + +The driver uses ``DEVLINK_SUPPORT_FLASH_UPDATE_OVERWRITE_MASK`` to identify the type of +firmware image that need to be programmed upon the request by user space application. + +``t7xx`` driver uses fastboot protocol for firmware flashing. In the firmware +flashing procedure, fastboot command & response are exchanged between driver +and wwan device. + +:: + + $ devlink dev param set pci/0000:bdf name fastboot value 1 cmode driverinit + +The devlink param fastboot is set to true via devlink param command, by +passing name ``fastboot``, value ``1`` and cmode ``driverinit``. + +:: + + $ devlink dev reload pci/0000:$bdf action driver_reinit + +The wwan device is put into fastboot mode via devlink reload command, by +passing ``driver_reinit`` action. + +:: + + $ devlink dev reload pci/0000:$bdf action fw_activate + +Upon completion of firmware flashing or coredump collection the wwan device is +reset to normal mode using devlink reload command, by passing ``fw_activate`` +action. + +Flash Commands +-------------- + +:: + + $ devlink dev flash pci/0000:$bdf file preloader_k6880v1_mdot2_datacard.bin component "preloader" + +:: + + $ devlink dev flash pci/0000:$bdf file loader_ext-verified.img component "loader_ext1" + +:: + + $ devlink dev flash pci/0000:$bdf file tee-verified.img component "tee1" + +:: + + $ devlink dev flash pci/0000:$bdf file lk-verified.img component "lk" + +:: + + $ devlink dev flash pci/0000:$bdf file spmfw-verified.img component "spmfw" + +:: + + $ devlink dev flash pci/0000:$bdf file sspm-verified.img component "sspm_1" + +:: + + $ devlink dev flash pci/0000:$bdf file mcupm-verified.img component "mcupm_1" + +:: + + $ devlink dev flash pci/0000:$bdf file dpm-verified.img component "dpm_1" + +:: + + $ devlink dev flash pci/0000:$bdf file boot-verified.img component "boot" + +:: + + $ devlink dev flash pci/0000:$bdf file root.squashfs component "rootfs" + +:: + + $ devlink dev flash pci/0000:$bdf file modem-verified.img component "md1img" + +:: + + $ devlink dev flash pci/0000:$bdf file dsp-verified.bin component "md1dsp" + +:: + + $ devlink dev flash pci/0000:$bdf file OP_OTA.img component "mcf1" + +:: + + $ devlink dev flash pci/0000:$bdf file OEM_OTA.img component "mcf2" + +:: + + $ devlink dev flash pci/0000:$bdf file DEV_OTA.img component "mcf3" + +Note: Component selects the partition type to be programmed. + + +The supported list of firmware image types is described below. + +.. list-table:: Firmware Image types + :widths: 15 85 + + * - Name + - Description + * - ``preloader`` + - The first-stage bootloader image + * - ``loader_ext1`` + - Preloader extension image + * - ``tee1`` + - ARM trusted firmware and TEE (Trusted Execution Environment) image + * - ``lk`` + - The second-stage bootloader image + * - ``spmfw`` + - MediaTek in-house ASIC for power management image + * - ``sspm_1`` + - MediaTek in-house ASIC for power management under secure world image + * - ``mcupm_1`` + - MediaTek in-house ASIC for cpu power management image + * - ``dpm_1`` + - MediaTek in-house ASIC for dram power management image + * - ``boot`` + - The kernel and dtb image + * - ``rootfs`` + - Root filesystem image + * - ``md1img`` + - Modem image + * - ``md1dsp`` + - Modem DSP image + * - ``mcf1`` + - Modem OTA image (Modem Configuration Framework) for operators + * - ``mcf2`` + - Modem OTA image (Modem Configuration Framework) for OEM vendors + * - ``mcf3`` + - Modem OTA image (other usage) for OEM configurations + + +Regions +======= + +The ``t7xx`` driver supports core dump collection in exception state and second +stage bootloader log collection in fastboot mode. The log snapshot is taken by +the driver using fastboot commands. + +Region commands +--------------- + +:: + + $ devlink region show + +This command list the regions implemented by driver. These regions are accessed +for device internal data. Below table describes the regions. + +.. list-table:: Regions + :widths: 15 85 + + * - Name + - Description + * - ``mr_dump`` + - The detailed modem component logs are captured in this region + * - ``lk_dump`` + - This region dumps the current snapshot of lk + +Coredump Collection +~~~~~~~~~~~~~~~~~~ + +:: + + $ devlink region new mr_dump + +:: + + $ devlink region read mr_dump snapshot 0 address 0 length $len + +:: + + $ devlink region del mr_dump snapshot 0 + +Note: $len is actual len to be dumped. + +The userspace application uses these commands for obtaining the modem component +logs when device encounters an exception. + +Second Stage Bootloader dump +~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +:: + + $ devlink region new lk_dump + +:: + + $ devlink region read lk_dump snapshot 0 address 0 length $len + +:: + + $ devlink region del lk_dump snapshot 0 + +Note: $len is actual len to be dumped. + +In fastboot mode the userspace application uses these commands for obtaining the +current snapshot of second stage bootloader. +