From patchwork Thu Oct 23 05:42:34 2014 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Dan Ben Yosef X-Patchwork-Id: 5138231 X-Patchwork-Delegate: ira.weiny@intel.com Return-Path: X-Original-To: patchwork-linux-rdma@patchwork.kernel.org Delivered-To: patchwork-parsemail@patchwork1.web.kernel.org Received: from mail.kernel.org (mail.kernel.org [198.145.19.201]) by patchwork1.web.kernel.org (Postfix) with ESMTP id EFB329F3ED for ; Thu, 23 Oct 2014 05:42:42 +0000 (UTC) Received: from mail.kernel.org (localhost [127.0.0.1]) by mail.kernel.org (Postfix) with ESMTP id DEBA120222 for ; Thu, 23 Oct 2014 05:42:41 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id AB2A0201EC for ; Thu, 23 Oct 2014 05:42:40 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751577AbaJWFmj (ORCPT ); Thu, 23 Oct 2014 01:42:39 -0400 Received: from mailp.voltaire.com ([193.47.165.129]:47833 "EHLO mellanox.co.il" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1750829AbaJWFmj (ORCPT ); Thu, 23 Oct 2014 01:42:39 -0400 Received: from Internal Mail-Server by MTLPINE2 (envelope-from danby@mellanox.com) with SMTP; 23 Oct 2014 07:42:37 +0200 Received: from r-ufm96.mtr.labs.mlnx (r-ufm96.mtr.labs.mlnx [10.209.36.187]) by labmailer.mlnx (8.13.8/8.13.8) with ESMTP id s9N5gZih025840; Thu, 23 Oct 2014 08:42:35 +0300 Received: from r-ufm96.mtr.labs.mlnx (localhost [127.0.0.1]) by r-ufm96.mtr.labs.mlnx (8.14.4/8.14.4) with ESMTP id s9N5gZlL031652; Thu, 23 Oct 2014 07:42:35 +0200 Received: (from danby@localhost) by r-ufm96.mtr.labs.mlnx (8.14.4/8.14.4/Submit) id s9N5gYNl031649; Thu, 23 Oct 2014 07:42:34 +0200 Date: Thu, 23 Oct 2014 07:42:34 +0200 From: Dan Ben Yosef To: Ira Weiny Cc: linux-rdma@vger.kernel.org Subject: [PATCH] libibmad: Add new fields for SM:PortInfoExtended and for Message-ID: <20141023054234.GA31556@r-ufm96.mtr.labs.mlnx> MIME-Version: 1.0 Content-Disposition: inline PM: PortExtendedSpeedsCounters User-Agent: Mutt/1.5.20 (2009-12-10) Sender: linux-rdma-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-rdma@vger.kernel.org X-Spam-Status: No, score=-8.3 required=5.0 tests=BAYES_00, RCVD_IN_DNSWL_HI, RP_MATCHES_RCVD, UNPARSEABLE_RELAY autolearn=ham version=3.3.1 X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on mail.kernel.org X-Virus-Scanned: ClamAV using ClamSMTP This change includes: 1. Adding new AttributeID and fields for MAD SM:PortInfoExtended. 2. Adding new fields to support PM:PortExtendedSpeedsCounters when RSFEC mode is active. Signed-off-by: Dan Ben Yosef --- include/infiniband/mad.h | 41 +++++++++++++++++++++++++++++++++++++++-- libibmad.ver | 2 +- src/dump.c | 13 +++++++++++++ src/fields.c | 36 +++++++++++++++++++++++++++++++++++- src/libibmad.map | 2 ++ 5 files changed, 90 insertions(+), 4 deletions(-) diff --git a/include/infiniband/mad.h b/include/infiniband/mad.h index cefcc54..119da8e 100644 --- a/include/infiniband/mad.h +++ b/include/infiniband/mad.h @@ -145,7 +145,7 @@ enum SMI_ATTR_ID { IB_ATTR_LINKSPEEDWIDTHPAIRSTBL = 0x1c, IB_ATTR_VENDORMADSTBL = 0x1d, IB_ATTR_SMINFO = 0x20, - + IB_ATTR_PORT_INFO_EXT = 0x33, IB_ATTR_LAST, IB_ATTR_MLNX_EXT_PORT_INFO = 0xff90, @@ -1253,6 +1253,42 @@ enum MAD_FIELDS { IB_PSR_COUNTER14_F, IB_PSR_LAST_F, + /* + * PortInfoExtended fields + */ + IB_PORT_EXT_FIRST_F, + IB_PORT_EXT_CAPMASK_F = IB_PORT_EXT_FIRST_F, + IB_PORT_EXT_FEC_MODE_ACTIVE_F, + IB_PORT_EXT_FDR_FEC_MODE_SUPPORTED_F, + IB_PORT_EXT_FDR_FEC_MODE_ENABLED_F, + IB_PORT_EXT_EDR_FEC_MODE_SUPPORTED_F, + IB_PORT_EXT_EDR_FEC_MODE_ENABLED_F, + IB_PORT_EXT_LAST_F, + + /* + * PortExtendedSpeedsCounters RSFEC active fields + */ + IB_PESC_RSFEC_PORT_SELECT_F, + IB_PESC_RSFEC_COUNTER_SELECT_F, + IB_PESC_RSFEC_SYNC_HDR_ERR_CTR_F, + IB_PESC_RSFEC_UNK_BLOCK_CTR_F, + IB_PESC_RSFEC_FEC_CORR_SYMBOL_CTR_LANE0_F, + IB_PESC_RSFEC_FEC_CORR_SYMBOL_CTR_LANE1_F, + IB_PESC_RSFEC_FEC_CORR_SYMBOL_CTR_LANE2_F, + IB_PESC_RSFEC_FEC_CORR_SYMBOL_CTR_LANE3_F, + IB_PESC_RSFEC_FEC_CORR_SYMBOL_CTR_LANE4_F, + IB_PESC_RSFEC_FEC_CORR_SYMBOL_CTR_LANE5_F, + IB_PESC_RSFEC_FEC_CORR_SYMBOL_CTR_LANE6_F, + IB_PESC_RSFEC_FEC_CORR_SYMBOL_CTR_LANE7_F, + IB_PESC_RSFEC_FEC_CORR_SYMBOL_CTR_LANE8_F, + IB_PESC_RSFEC_FEC_CORR_SYMBOL_CTR_LANE9_F, + IB_PESC_RSFEC_FEC_CORR_SYMBOL_CTR_LANE10_F, + IB_PESC_RSFEC_FEC_CORR_SYMBOL_CTR_LANE11_F, + IB_PESC_PORT_FEC_CORR_BLOCK_CTR_F, + IB_PESC_PORT_FEC_UNCORR_BLOCK_CTR_F, + IB_PESC_PORT_FEC_CORR_SYMBOL_CTR_F, + IB_PESC_RSFEC_LAST_F, + IB_FIELD_LAST_ /* must be last */ }; @@ -1615,7 +1651,8 @@ MAD_EXPORT ib_mad_dump_fn mad_dump_cc_switchportcongestionsettingelement, mad_dump_cc_cacongestionsetting, mad_dump_cc_cacongestionentry, mad_dump_cc_congestioncontroltable, mad_dump_cc_congestioncontroltableentry, mad_dump_cc_timestamp, - mad_dump_classportinfo, mad_dump_portsamples_result; + mad_dump_classportinfo, mad_dump_portsamples_result, + mad_dump_portinfo_ext, mad_dump_port_ext_speeds_counters_rsfec_active; MAD_EXPORT void mad_dump_fields(char *buf, int bufsz, void *val, int valsz, int start, int end); diff --git a/libibmad.ver b/libibmad.ver index 11698ff..4578eaf 100644 --- a/libibmad.ver +++ b/libibmad.ver @@ -6,4 +6,4 @@ # API_REV - advance on any added API # RUNNING_REV - advance any change to the vendor files # AGE - number of backward versions the API still supports -LIBVERSION=9:0:4 +LIBVERSION=10:0:5 diff --git a/src/dump.c b/src/dump.c index efe4bc4..64577c0 100644 --- a/src/dump.c +++ b/src/dump.c @@ -857,6 +857,13 @@ void mad_dump_portsamples_result(char *buf, int bufsz, void *val, int valsz) _dump_fields(buf, bufsz, val, IB_PSR_TAG_F, IB_PSR_LAST_F); } +void mad_dump_port_ext_speeds_counters_rsfec_active(char *buf, int bufsz, + void *val, int valsz) +{ + _dump_fields(buf, bufsz, val, IB_PESC_RSFEC_PORT_SELECT_F, + IB_PESC_RSFEC_LAST_F); +} + void mad_dump_port_ext_speeds_counters(char *buf, int bufsz, void *val, int valsz) { _dump_fields(buf, bufsz, val, IB_PESC_PORT_SELECT_F, IB_PESC_LAST_F); @@ -1115,6 +1122,12 @@ void mad_dump_classportinfo(char *buf, int bufsz, void *val, int valsz) _dump_fields(buf, bufsz, val, IB_CPI_BASEVER_F, IB_CPI_TRAP_QKEY_F + 1); } +void mad_dump_portinfo_ext(char *buf, int bufsz, void *val, int valsz) +{ + _dump_fields(buf, bufsz, val, IB_PORT_EXT_CAPMASK_F, + IB_PORT_EXT_LAST_F); +} + void xdump(FILE * file, char *msg, void *p, int size) { #define HEX(x) ((x) < 10 ? '0' + (x) : 'a' + ((x) -10)) diff --git a/src/fields.c b/src/fields.c index 33a6364..a848ebf 100644 --- a/src/fields.c +++ b/src/fields.c @@ -949,8 +949,42 @@ static const ib_field_t ib_mad_f[] = { {480, 32, "Counter14", mad_dump_uint}, {0, 0}, /* IB_PSR_LAST_F */ - {0, 0} /* IB_FIELD_LAST_ */ + /* + * PortInfoExtended fields + */ + {0, 32, "CapMask", mad_dump_hex}, + {BITSOFFS(32, 16), "FECModeActive", mad_dump_uint}, + {BITSOFFS(48, 16), "FDRFECModeSupported", mad_dump_uint}, + {BITSOFFS(64, 16), "FDRFECModeEnabled", mad_dump_uint}, + {BITSOFFS(80, 16), "EDRFECModeSupported", mad_dump_uint}, + {BITSOFFS(96, 16), "EDRFECModeEnabled", mad_dump_uint}, + {0, 0}, /* IB_PORT_EXT_LAST_F */ + /* + * PortExtendedSpeedsCounters RSFEC Active fields + */ + {BITSOFFS(8, 8), "PortSelect", mad_dump_uint}, + {64, 64, "CounterSelect", mad_dump_hex}, + {BITSOFFS(128, 16), "SyncHeaderErrorCounter", mad_dump_uint}, + {BITSOFFS(144, 16), "UnknownBlockCounter", mad_dump_uint}, + {352, 32, "FECCorrectableSymbolCtrLane0", mad_dump_uint}, + {384, 32, "FECCorrectableSymbolCtrLane1", mad_dump_uint}, + {416, 32, "FECCorrectableSymbolCtrLane2", mad_dump_uint}, + {448, 32, "FECCorrectableSymbolCtrLane3", mad_dump_uint}, + {480, 32, "FECCorrectableSymbolCtrLane4", mad_dump_uint}, + {512, 32, "FECCorrectableSymbolCtrLane5", mad_dump_uint}, + {544, 32, "FECCorrectableSymbolCtrLane6", mad_dump_uint}, + {576, 32, "FECCorrectableSymbolCtrLane7", mad_dump_uint}, + {608, 32, "FECCorrectableSymbolCtrLane8", mad_dump_uint}, + {640, 32, "FECCorrectableSymbolCtrLane9", mad_dump_uint}, + {672, 32, "FECCorrectableSymbolCtrLane10", mad_dump_uint}, + {704, 32, "FECCorrectableSymbolCtrLane11", mad_dump_uint}, + {1120, 32, "PortFECCorrectableBlockCtr", mad_dump_uint}, + {1152, 32, "PortFECUncorrectableBlockCtr", mad_dump_uint}, + {1184, 32, "PortFECCorrectedSymbolCtr", mad_dump_uint}, + {0, 0}, /* IB_PESC_RSFEC_LAST_F */ + + {0, 0} /* IB_FIELD_LAST_ */ }; static void _set_field64(void *buf, int base_offs, const ib_field_t * f, diff --git a/src/libibmad.map b/src/libibmad.map index 3f3aeef..3240a7b 100644 --- a/src/libibmad.map +++ b/src/libibmad.map @@ -19,6 +19,7 @@ IBMAD_1.3 { mad_dump_linkwidthen; mad_dump_linkwidthsup; mad_dump_mlnx_ext_port_info; + mad_dump_portinfo_ext; mad_dump_mtu; mad_dump_node_type; mad_dump_nodedesc; @@ -145,6 +146,7 @@ IBMAD_1.3 { mad_field_name; bm_call_via; mad_dump_port_ext_speeds_counters; + mad_dump_port_ext_speeds_counters_rsfec_active; cc_query_status_via; cc_config_status_via; smp_mkey_get;