Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp1701155pxb; Sat, 23 Jan 2021 02:54:05 -0800 (PST) X-Google-Smtp-Source: ABdhPJzG9nVoufQWPAjFvJEj/7Ui5XnyHB8zdJxnbC9s5DfViTC79vpGqaYFAlMGR6MMIC8NdFHn X-Received: by 2002:a17:906:da02:: with SMTP id fi2mr5520513ejb.230.1611399245167; Sat, 23 Jan 2021 02:54:05 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1611399245; cv=none; d=google.com; s=arc-20160816; b=O8Jf+kil+zNN38ESxZPVCkjLRLXY5abagW6OpKG7JeeKybr8mzaPcBFF424QOLR8rP BjiRq+vjmLQeAIK06CklmUV/LB+8dO7J0QA8HXWH9ftHuTJtQavJABCYyao7bjewyE6w 6NxCAGyA33vH6AZxaZCe+z+TAkC7VcMmYrQKsY2nkc7BjHnkFn+4y4xk8EuqlSANphhL ON4dMau2VVxfHzOW4Ri+GXlaNXqhKSxGGCoMm6mlRpjLo7TDSDNUz5ttth+tdEiVilRQ VlvechcmyoIdIHR1Odcno7MWCChwcx2No6sEu2KRu8IDOQInKqmCbwClnToQgTc1ulQ2 CSQQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=grKmWLGAk7sZzTqlb1s/0PbNKM4OZcrNFB/3+DXmhj8=; b=KQJy3ZBxyKKDzS9o9Ng0BaAVvv5V7kNnEZmCjTaRCB2/D5YoU+LedJYfEIrg/DcKwl cmLaCFY3aQaMKyTLpPjRwD42yeXo9ivLo4dOYZX9Itc8fqPNU0ziu7+RGuYK0X947/KP 4rljqSRBNbHvMigpcU/QETzoCxKRdhK8ApRIyN12ycVbAipWEprY80l7I9DagEGylVT+ KiUirBuX/TeYTEF/DhJi6OHQDd2ZW74z40SP1PjP5TiMUxemZSOqFWPCmJeMNbFbTs6O YH/aS0bGbnVDqiQok2JudndH2WoaueiDPM7gJ1WxIp2u5PfITBQYanSMtD07e8eGBj/O arIw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=CV3tSxIz; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id zk17si3920765ejb.268.2021.01.23.02.53.41; Sat, 23 Jan 2021 02:54:05 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=CV3tSxIz; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727045AbhAWKuD (ORCPT + 99 others); Sat, 23 Jan 2021 05:50:03 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60006 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726693AbhAWKri (ORCPT ); Sat, 23 Jan 2021 05:47:38 -0500 Received: from mail-pf1-x42d.google.com (mail-pf1-x42d.google.com [IPv6:2607:f8b0:4864:20::42d]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 9DBE6C061788; Sat, 23 Jan 2021 02:46:57 -0800 (PST) Received: by mail-pf1-x42d.google.com with SMTP id m6so5503250pfk.1; Sat, 23 Jan 2021 02:46:57 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=grKmWLGAk7sZzTqlb1s/0PbNKM4OZcrNFB/3+DXmhj8=; b=CV3tSxIzsslCEX8/PzlnheCqpmSOoncPtOBiPuZi8nFgImC3fKkQhY+2QfecMREYEE VBdNaG2B/SI1pUag8TKbPaGDeqENyy1x0W4SEsqKvGoq+H0s0uO3zb7xcHcYg1WEqxCG RQdZNG5SGrtcM76jn/WAaYcKEeXmpamG3ksdkEglOPv//NWDkcPcryfA7Mo1B8qdsW00 OCX04ikU94jTpWlKQfYyfVYT0RL/I9NsSjXOR6ut1OC1wK63IcC6UwqaNWEJpsc/Ce4w UjrmVzbhJ9LqrwbwnJavSotLRxEA3XzGvBIA7NSpYINbpyhHbv2/w+H1QMibxM9hWg2h fhbA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=grKmWLGAk7sZzTqlb1s/0PbNKM4OZcrNFB/3+DXmhj8=; b=dmvw4t6NCHuCoQP30nNHDWlpoq7BUlXJlAeEen/StGGtLxqTld8JuEzBCSfTfTHmkC fshO6tp++52hpP2aRpHDWh+aQwEn+1CHJJfpJtTDccNW8K/uLrioj9xc2EhdmNmJFMVp waFzTXDllFwSGrOp9Cwrko+cnhk53MG/rORqDcAbHasHsoDmxuvPiV55lhqmfO/M3Jtp d9/XRKrWI/zEq3kw4dPd6t2pqdHDPmNrZrBjsrvSLZx/yuapBP4y1dF+NzAV2QS6Gufb 4Jnn6lqJt0toa8efOvpM2+56ECIju4sThJqrAwE+Mu3E/Q/tOEWwRAznvmTx0qc7i+NI d1NA== X-Gm-Message-State: AOAM531GqS5h0P++G+WGl1rfOWbU/LbLw6OCRkt5KhZGrYV3TXCGvORN IZIshQCiF8xSBOTxfTZMJD4= X-Received: by 2002:a65:6405:: with SMTP id a5mr9022691pgv.389.1611398817217; Sat, 23 Jan 2021 02:46:57 -0800 (PST) Received: from localhost ([2001:e42:102:1532:160:16:113:140]) by smtp.gmail.com with ESMTPSA id i25sm11175165pgb.33.2021.01.23.02.46.55 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 23 Jan 2021 02:46:56 -0800 (PST) From: Coiby Xu To: devel@driverdev.osuosl.org Cc: Benjamin Poirier , Dan Carpenter , Shung-Hsi Yu , Willem de Bruijn , GR-Linux-NIC-Dev@marvell.com, Manish Chopra , Greg Kroah-Hartman , netdev@vger.kernel.org (open list:QLOGIC QLGE 10Gb ETHERNET DRIVER), linux-kernel@vger.kernel.org (open list) Subject: [PATCH v4 4/8] staging: qlge: coredump via devlink health reporter Date: Sat, 23 Jan 2021 18:46:09 +0800 Message-Id: <20210123104613.38359-5-coiby.xu@gmail.com> X-Mailer: git-send-email 2.30.0 In-Reply-To: <20210123104613.38359-1-coiby.xu@gmail.com> References: <20210123104613.38359-1-coiby.xu@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org $ devlink health dump show DEVICE reporter coredump -p -j { "Core Registers": { "segment": 1, "values": [ 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 ] }, "Test Logic Regs": { "segment": 2, "values": [ 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 ] }, "RMII Registers": { "segment": 3, "values": [ 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 ] }, ... "Sem Registers": { "segment": 50, "values": [ 0,0,0,0 ] } } Signed-off-by: Coiby Xu --- drivers/staging/qlge/qlge_devlink.c | 132 ++++++++++++++++++++++++++-- 1 file changed, 126 insertions(+), 6 deletions(-) diff --git a/drivers/staging/qlge/qlge_devlink.c b/drivers/staging/qlge/qlge_devlink.c index d9c71f45211f..bf7d75ed5eae 100644 --- a/drivers/staging/qlge/qlge_devlink.c +++ b/drivers/staging/qlge/qlge_devlink.c @@ -2,16 +2,136 @@ #include "qlge.h" #include "qlge_devlink.h" -static int -qlge_reporter_coredump(struct devlink_health_reporter *reporter, - struct devlink_fmsg *fmsg, void *priv_ctx, - struct netlink_ext_ack *extack) +static int qlge_fill_seg_(struct devlink_fmsg *fmsg, + struct mpi_coredump_segment_header *seg_header, + u32 *reg_data) { - return 0; + int regs_num = (seg_header->seg_size + - sizeof(struct mpi_coredump_segment_header)) / sizeof(u32); + int err; + int i; + + err = devlink_fmsg_pair_nest_start(fmsg, seg_header->description); + if (err) + return err; + err = devlink_fmsg_obj_nest_start(fmsg); + if (err) + return err; + err = devlink_fmsg_u32_pair_put(fmsg, "segment", seg_header->seg_num); + if (err) + return err; + err = devlink_fmsg_arr_pair_nest_start(fmsg, "values"); + if (err) + return err; + for (i = 0; i < regs_num; i++) { + err = devlink_fmsg_u32_put(fmsg, *reg_data); + if (err) + return err; + reg_data++; + } + err = devlink_fmsg_obj_nest_end(fmsg); + if (err) + return err; + err = devlink_fmsg_arr_pair_nest_end(fmsg); + if (err) + return err; + err = devlink_fmsg_pair_nest_end(fmsg); + return err; +} + +#define FILL_SEG(seg_hdr, seg_regs) \ + do { \ + err = qlge_fill_seg_(fmsg, &dump->seg_hdr, dump->seg_regs); \ + if (err) { \ + kvfree(dump); \ + return err; \ + } \ + } while (0) + +static int qlge_reporter_coredump(struct devlink_health_reporter *reporter, + struct devlink_fmsg *fmsg, void *priv_ctx, + struct netlink_ext_ack *extack) +{ + int err = 0; + + struct qlge_adapter *qdev = devlink_health_reporter_priv(reporter); + struct qlge_mpi_coredump *dump; + + if (!netif_running(qdev->ndev)) + return 0; + + dump = kvmalloc(sizeof(*dump), GFP_KERNEL); + if (!dump) + return -ENOMEM; + + err = qlge_core_dump(qdev, dump); + if (err) { + kvfree(dump); + return err; + } + + qlge_soft_reset_mpi_risc(qdev); + + FILL_SEG(core_regs_seg_hdr, mpi_core_regs); + FILL_SEG(test_logic_regs_seg_hdr, test_logic_regs); + FILL_SEG(rmii_regs_seg_hdr, rmii_regs); + FILL_SEG(fcmac1_regs_seg_hdr, fcmac1_regs); + FILL_SEG(fcmac2_regs_seg_hdr, fcmac2_regs); + FILL_SEG(fc1_mbx_regs_seg_hdr, fc1_mbx_regs); + FILL_SEG(ide_regs_seg_hdr, ide_regs); + FILL_SEG(nic1_mbx_regs_seg_hdr, nic1_mbx_regs); + FILL_SEG(smbus_regs_seg_hdr, smbus_regs); + FILL_SEG(fc2_mbx_regs_seg_hdr, fc2_mbx_regs); + FILL_SEG(nic2_mbx_regs_seg_hdr, nic2_mbx_regs); + FILL_SEG(i2c_regs_seg_hdr, i2c_regs); + FILL_SEG(memc_regs_seg_hdr, memc_regs); + FILL_SEG(pbus_regs_seg_hdr, pbus_regs); + FILL_SEG(mde_regs_seg_hdr, mde_regs); + FILL_SEG(nic_regs_seg_hdr, nic_regs); + FILL_SEG(nic2_regs_seg_hdr, nic2_regs); + FILL_SEG(xgmac1_seg_hdr, xgmac1); + FILL_SEG(xgmac2_seg_hdr, xgmac2); + FILL_SEG(code_ram_seg_hdr, code_ram); + FILL_SEG(memc_ram_seg_hdr, memc_ram); + FILL_SEG(xaui_an_hdr, serdes_xaui_an); + FILL_SEG(xaui_hss_pcs_hdr, serdes_xaui_hss_pcs); + FILL_SEG(xfi_an_hdr, serdes_xfi_an); + FILL_SEG(xfi_train_hdr, serdes_xfi_train); + FILL_SEG(xfi_hss_pcs_hdr, serdes_xfi_hss_pcs); + FILL_SEG(xfi_hss_tx_hdr, serdes_xfi_hss_tx); + FILL_SEG(xfi_hss_rx_hdr, serdes_xfi_hss_rx); + FILL_SEG(xfi_hss_pll_hdr, serdes_xfi_hss_pll); + + err = qlge_fill_seg_(fmsg, &dump->misc_nic_seg_hdr, + (u32 *)&dump->misc_nic_info); + if (err) { + kvfree(dump); + return err; + } + + FILL_SEG(intr_states_seg_hdr, intr_states); + FILL_SEG(cam_entries_seg_hdr, cam_entries); + FILL_SEG(nic_routing_words_seg_hdr, nic_routing_words); + FILL_SEG(ets_seg_hdr, ets); + FILL_SEG(probe_dump_seg_hdr, probe_dump); + FILL_SEG(routing_reg_seg_hdr, routing_regs); + FILL_SEG(mac_prot_reg_seg_hdr, mac_prot_regs); + FILL_SEG(xaui2_an_hdr, serdes2_xaui_an); + FILL_SEG(xaui2_hss_pcs_hdr, serdes2_xaui_hss_pcs); + FILL_SEG(xfi2_an_hdr, serdes2_xfi_an); + FILL_SEG(xfi2_train_hdr, serdes2_xfi_train); + FILL_SEG(xfi2_hss_pcs_hdr, serdes2_xfi_hss_pcs); + FILL_SEG(xfi2_hss_tx_hdr, serdes2_xfi_hss_tx); + FILL_SEG(xfi2_hss_rx_hdr, serdes2_xfi_hss_rx); + FILL_SEG(xfi2_hss_pll_hdr, serdes2_xfi_hss_pll); + FILL_SEG(sem_regs_seg_hdr, sem_regs); + + kvfree(dump); + return err; } static const struct devlink_health_reporter_ops qlge_reporter_ops = { - .name = "dummy", + .name = "coredump", .dump = qlge_reporter_coredump, }; -- 2.29.2