public inbox for linux-rdma@vger.kernel.org
 help / color / mirror / Atom feed
From: Hal Rosenstock <hal-LDSdmyG8hGV8YrgS2mwiifqBs+8SCbDb@public.gmane.org>
To: Ira Weiny <weiny2-i2BcT+NCU+M@public.gmane.org>
Cc: Hal Rosenstock <hal-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org>,
	"linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org"
	<linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org>
Subject: Re: [PATCH] libibumad: add string functions for various enums
Date: Fri, 22 Feb 2013 13:27:10 -0500	[thread overview]
Message-ID: <5127B87E.5020907@dev.mellanox.co.il> (raw)
In-Reply-To: <20130222091333.57b91bbb5957928eeb0e62a7-i2BcT+NCU+M@public.gmane.org>

On 2/22/2013 12:13 PM, Ira Weiny wrote:
> 
> Some of this code was originally proposed by Sean in 2010 as part of user space
> madeye: http://www.mail-archive.com/linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org/msg06185.html
> 
> Changes from V1:
> 	Move functions into library calls
> 	remove funky marco obfuscation
> 	remove public access to umad_[sm|sa|cm]_attr_str functions
> Changes from V2:
> 	Added mgmt_class to umad_method_str call (with man page update)
> 	remove "inline" from man page
> 	Use UMAD_STATUS_x values in umad_mad_status_str decode.
> 
> Signed-off-by: Ira Weiny <weiny2-i2BcT+NCU+M@public.gmane.org>

Just a couple of nits below

> ---
>  Makefile.am                     |   12 +-
>  include/infiniband/umad_sm.h    |   31 ++--
>  include/infiniband/umad_str.h   |   55 +++++++
>  include/infiniband/umad_types.h |    4 +-
>  man/umad_attribute_str.3        |    3 +
>  man/umad_class_str.3            |   38 +++++
>  man/umad_mad_status_str.3       |    3 +
>  man/umad_method_str.3           |    3 +
>  src/libibumad.map               |    4 +
>  src/umad_str.c                  |  335 +++++++++++++++++++++++++++++++++++++++
>  10 files changed, 469 insertions(+), 19 deletions(-)
>  create mode 100644 include/infiniband/umad_str.h
>  create mode 100644 man/umad_attribute_str.3
>  create mode 100644 man/umad_class_str.3
>  create mode 100644 man/umad_mad_status_str.3
>  create mode 100644 man/umad_method_str.3
>  create mode 100644 src/umad_str.c
> 
> diff --git a/Makefile.am b/Makefile.am
> index 14e2389..dc34c3d 100644
> --- a/Makefile.am
> +++ b/Makefile.am
> @@ -15,7 +15,12 @@ man_MANS = man/umad_debug.3 man/umad_get_ca.3 \
>  	   man/umad_get_pkey.3 \
>  	   man/umad_register.3 man/umad_register_oui.3 man/umad_unregister.3 \
>  	   man/umad_send.3 man/umad_recv.3 man/umad_poll.3 \
> -	   man/umad_get_issm_path.3
> +	   man/umad_get_issm_path.3 \
> +	   man/umad_attribute_str.3 \
> +	   man/umad_class_str.3 \
> +	   man/umad_mad_status_str.3 \
> +	   man/umad_method_str.3
> +
>  
>  lib_LTLIBRARIES = libibumad.la
>  
> @@ -27,7 +32,7 @@ else
>  libibumad_version_script =
>  endif
>  
> -libibumad_la_SOURCES = src/umad.c src/sysfs.c
> +libibumad_la_SOURCES = src/umad.c src/sysfs.c src/umad_str.c
>  libibumad_la_LDFLAGS = -version-info $(ibumad_api_version) \
>      -export-dynamic $(libibumad_version_script)
>  libibumad_la_DEPENDENCIES = $(srcdir)/src/libibumad.map
> @@ -38,7 +43,8 @@ libibumadinclude_HEADERS = $(srcdir)/include/infiniband/umad.h \
>  	$(srcdir)/include/infiniband/umad_types.h \
>  	$(srcdir)/include/infiniband/umad_sa.h \
>  	$(srcdir)/include/infiniband/umad_sm.h \
> -	$(srcdir)/include/infiniband/umad_cm.h
> +	$(srcdir)/include/infiniband/umad_cm.h \
> +	$(srcdir)/include/infiniband/umad_str.h
>  
>  EXTRA_DIST = $(srcdir)/include/infiniband/umad.h \
>  	libibumad.spec.in libibumad.spec \
> diff --git a/include/infiniband/umad_sm.h b/include/infiniband/umad_sm.h
> index 10348d4..f6ee171 100644
> --- a/include/infiniband/umad_sm.h
> +++ b/include/infiniband/umad_sm.h
> @@ -55,21 +55,22 @@ enum {
>  
>  /* Subnet management attributes */
>  enum {
> -	UMAD_SMP_ATTR_NODE_DESC		= 0x0010,
> -	UMAD_SMP_ATTR_NODE_INFO		= 0x0011,
> -	UMAD_SMP_ATTR_SWITCH_INFO	= 0x0012,
> -	UMAD_SMP_ATTR_GUID_INFO		= 0x0014,
> -	UMAD_SMP_ATTR_PORT_INFO		= 0x0015,
> -	UMAD_SMP_ATTR_PKEY_TABLE	= 0x0016,
> -	UMAD_SMP_ATTR_SLVL_TABLE	= 0x0017,
> -	UMAD_SMP_ATTR_VL_ARB_TABLE	= 0x0018,
> -	UMAD_SMP_ATTR_LINEAR_FT		= 0x0019,
> -	UMAD_SMP_ATTR_RANDOM_FT		= 0x001A,
> -	UMAD_SMP_ATTR_MCAST_FT		= 0x001B,
> -	UMAD_SMP_ATTR_SM_INFO		= 0x0020,
> -	UMAD_SMP_ATTR_VENDOR_DIAG	= 0x0030,
> -	UMAD_SMP_ATTR_LED_INFO		= 0x0031,
> -	UMAD_SMP_ATTR_VENDOR_MASK	= 0xFF00
> +	UMAD_SMP_ATTR_NODE_DESC			= 0x0010,
> +	UMAD_SMP_ATTR_NODE_INFO			= 0x0011,
> +	UMAD_SMP_ATTR_SWITCH_INFO		= 0x0012,
> +	UMAD_SMP_ATTR_GUID_INFO			= 0x0014,
> +	UMAD_SMP_ATTR_PORT_INFO			= 0x0015,
> +	UMAD_SMP_ATTR_PKEY_TABLE		= 0x0016,
> +	UMAD_SMP_ATTR_SLVL_TABLE		= 0x0017,
> +	UMAD_SMP_ATTR_VL_ARB_TABLE		= 0x0018,
> +	UMAD_SMP_ATTR_LINEAR_FT			= 0x0019,
> +	UMAD_SMP_ATTR_RANDOM_FT			= 0x001A,
> +	UMAD_SMP_ATTR_MCAST_FT			= 0x001B,
> +	UMAD_SMP_ATTR_LINK_SPD_WIDTH_TABLE	= 0x001C,
> +	UMAD_SMP_ATTR_SM_INFO			= 0x0020,
> +	UMAD_SMP_ATTR_VENDOR_DIAG		= 0x0030,
> +	UMAD_SMP_ATTR_LED_INFO			= 0x0031,
> +	UMAD_SMP_ATTR_VENDOR_MASK		= 0xFF00
>  };
>  
>  enum {
> diff --git a/include/infiniband/umad_str.h b/include/infiniband/umad_str.h
> new file mode 100644
> index 0000000..8c00a83
> --- /dev/null
> +++ b/include/infiniband/umad_str.h
> @@ -0,0 +1,55 @@
> +/*
> + * Copyright (c) 2004, 2005, 2010 Intel Corporation.  All rights reserved.
> + * Copyright (c) 2013 Lawrence Livermore National Security. All rights reserved.
> + *
> + * This software is available to you under a choice of one of two
> + * licenses.  You may choose to be licensed under the terms of the GNU
> + * General Public License (GPL) Version 2, available from the file
> + * COPYING in the main directory of this source tree, or the
> + * OpenIB.org BSD license below:
> + *
> + *     Redistribution and use in source and binary forms, with or
> + *     without modification, are permitted provided that the following
> + *     conditions are met:
> + *
> + *      - Redistributions of source code must retain the above
> + *        copyright notice, this list of conditions and the following
> + *        disclaimer.
> + *
> + *      - Redistributions in binary form must reproduce the above
> + *        copyright notice, this list of conditions and the following
> + *        disclaimer in the documentation and/or other materials
> + *        provided with the distribution.
> + *
> + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
> + * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
> + * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
> + * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
> + * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
> + * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
> + * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
> + * SOFTWARE.
> + *
> + */
> +#ifndef _UMAD_STR_H
> +#define _UMAD_STR_H
> +
> +#include <infiniband/umad.h>
> +
> +#ifdef __cplusplus
> +#  define BEGIN_C_DECLS extern "C" {
> +#  define END_C_DECLS   }
> +#else				/* !__cplusplus */
> +#  define BEGIN_C_DECLS
> +#  define END_C_DECLS
> +#endif				/* __cplusplus */
> +
> +BEGIN_C_DECLS
> +
> +char * umad_class_str(uint8_t mgmt_class);
> +char * umad_method_str(uint8_t mgmt_class, uint8_t method);
> +char * umad_attribute_str(uint8_t mgmt_class, be16_t attr_id);
> +char * umad_mad_status_str(be16_t status, char * buf, size_t len);
> +
> +END_C_DECLS
> +#endif /* _UMAD_STR_H */
> diff --git a/include/infiniband/umad_types.h b/include/infiniband/umad_types.h
> index a722b8c..db13438 100644
> --- a/include/infiniband/umad_types.h
> +++ b/include/infiniband/umad_types.h
> @@ -64,10 +64,12 @@ enum {
>  	UMAD_CLASS_SNMP			= 0x08,
>  	UMAD_CLASS_VENDOR_RANGE1_START	= 0x09,
>  	UMAD_CLASS_VENDOR_RANGE1_END	= 0x0F,
> -	UMAD_CLASS_DEVICE_ADM		= 0x10,
> +	UMAD_CLASS_APPLICATION_START	= 0x10,
> +	UMAD_CLASS_DEVICE_ADM		= UMAD_CLASS_APPLICATION_START,
>  	UMAD_CLASS_BOOT_MGMT		= 0x11,
>  	UMAD_CLASS_BIS			= 0x12,
>  	UMAD_CLASS_CONG_MGMT		= 0x21,
> +	UMAD_CLASS_APPLICATION_END	= 0x2F,
>  	UMAD_CLASS_VENDOR_RANGE2_START	= 0x30,
>  	UMAD_CLASS_VENDOR_RANGE2_END	= 0x4F
>  };
> diff --git a/man/umad_attribute_str.3 b/man/umad_attribute_str.3
> new file mode 100644
> index 0000000..f5e6b02
> --- /dev/null
> +++ b/man/umad_attribute_str.3
> @@ -0,0 +1,3 @@
> +.\" -*- nroff -*-
> +.\"
> +.so man3/umad_class_str.3
> diff --git a/man/umad_class_str.3 b/man/umad_class_str.3
> new file mode 100644
> index 0000000..1d7552b
> --- /dev/null
> +++ b/man/umad_class_str.3
> @@ -0,0 +1,38 @@
> +.\" -*- nroff -*-
> +.\"
> +.TH UMAD_CLASS_STR 3  "Feb 15, 2013" "OpenIB" "OpenIB Programmer\'s Manual"
> +.SH "NAME"
> +umad_*_str \- class of functions to return string representations of enums
> +
> +.SH "SYNOPSIS"
> +.nf
> +.B #include <infiniband/umad_str.h>
> +.sp
> +.BI "char * umad_class_str(uint8_t mgmt_class)"
> +.BI "char * umad_method_str(uint8_t mgmt_class, uint8_t method)"
> +.BI "char * umad_mad_status_str(be16_t status, char * buf, size_t len)"
> +.BI "char * umad_attribute_str(uint8_t mgmt_class, be16_t attr_id)"
> +
> +.SH "DESCRIPTION"
> +
> +.B "char * umad_class_str(uint8_t mgmt_class)"
> +Return string value of management class enum
> +
> +.B "char * umad_method_str(uint8_t mgmt_class, uint8_t method)"
> +Return string value of method enum

Should this now be:
Return string value of method for mgmt_class specified

> +
> +.B "char * umad_mad_status_str(be16_t status, char * buf, size_t len)"
> +Print MAD status into buf and return buf
> +
> +.B "char * umad_attribute_str(uint8_t mgmt_class, be16_t attr_id)"
> +Return string value of attribute specified in attr_id based on mgmt_class specified.
> +
> +Currently SM, SA, and CM classes are supported.
> +
> +.SH "RETURN VALUE"
> +
> +Returns a string representations of the fields specified.
> +
> +.SH "AUTHOR"
> +.TP
> +Ira Weiny <weiny2-i2BcT+NCU+M@public.gmane.org>
> diff --git a/man/umad_mad_status_str.3 b/man/umad_mad_status_str.3
> new file mode 100644
> index 0000000..f5e6b02
> --- /dev/null
> +++ b/man/umad_mad_status_str.3
> @@ -0,0 +1,3 @@
> +.\" -*- nroff -*-
> +.\"
> +.so man3/umad_class_str.3
> diff --git a/man/umad_method_str.3 b/man/umad_method_str.3
> new file mode 100644
> index 0000000..f5e6b02
> --- /dev/null
> +++ b/man/umad_method_str.3
> @@ -0,0 +1,3 @@
> +.\" -*- nroff -*-
> +.\"
> +.so man3/umad_class_str.3
> diff --git a/src/libibumad.map b/src/libibumad.map
> index 0154b7f..af68d11 100644
> --- a/src/libibumad.map
> +++ b/src/libibumad.map
> @@ -30,5 +30,9 @@ IBUMAD_1.0 {
>  		umad_debug;
>  		umad_addr_dump;
>  		umad_dump;
> +		umad_class_str;
> +		umad_method_str;
> +		umad_mad_status_str;
> +		umad_attribute_str;
>  	local: *;
>  };
> diff --git a/src/umad_str.c b/src/umad_str.c
> new file mode 100644
> index 0000000..c77f00b
> --- /dev/null
> +++ b/src/umad_str.c
> @@ -0,0 +1,335 @@
> +/*
> + * Copyright (c) 2004, 2005, 2010 Intel Corporation.  All rights reserved.
> + * Copyright (c) 2013 Lawrence Livermore National Security. All rights reserved.
> + *
> + * This software is available to you under a choice of one of two
> + * licenses.  You may choose to be licensed under the terms of the GNU
> + * General Public License (GPL) Version 2, available from the file
> + * COPYING in the main directory of this source tree, or the
> + * OpenIB.org BSD license below:
> + *
> + *     Redistribution and use in source and binary forms, with or
> + *     without modification, are permitted provided that the following
> + *     conditions are met:
> + *
> + *      - Redistributions of source code must retain the above
> + *        copyright notice, this list of conditions and the following
> + *        disclaimer.
> + *
> + *      - Redistributions in binary form must reproduce the above
> + *        copyright notice, this list of conditions and the following
> + *        disclaimer in the documentation and/or other materials
> + *        provided with the distribution.
> + *
> + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
> + * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
> + * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
> + * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
> + * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
> + * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
> + * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
> + * SOFTWARE.
> + *
> + */
> +
> +#include <stdio.h>
> +#include <arpa/inet.h>
> +#include <infiniband/umad.h>
> +#include <infiniband/umad_types.h>
> +#include <infiniband/umad_sm.h>
> +#include <infiniband/umad_sa.h>
> +#include <infiniband/umad_cm.h>
> +
> +char * umad_class_str(uint8_t mgmt_class)
> +{
> +	switch (mgmt_class) {
> +		case UMAD_CLASS_SUBN_LID_ROUTED:
> +		case UMAD_CLASS_SUBN_DIRECTED_ROUTE:
> +			return("Subn");
> +		case UMAD_CLASS_SUBN_ADM:
> +			return("SubnAdm");
> +		case UMAD_CLASS_PERF_MGMT:
> +			return("Perf");
> +		case UMAD_CLASS_BM:
> +			return("BM");
> +		case UMAD_CLASS_DEVICE_MGMT:
> +			return("DevMgt");
> +		case UMAD_CLASS_CM:
> +			return("ComMgt");
> +		case UMAD_CLASS_SNMP:
> +			return("SNMP");
> +		case UMAD_CLASS_DEVICE_ADM:
> +			return("DevAdm");
> +		case UMAD_CLASS_BOOT_MGMT:
> +			return("BootMgt");
> +		case UMAD_CLASS_BIS:
> +			return("BIS");
> +		case UMAD_CLASS_CONG_MGMT:
> +			return("CongestionManagment");
> +		default:
> +			break;
> +	}
> +
> +	if ((UMAD_CLASS_VENDOR_RANGE1_START <= mgmt_class
> +		&& mgmt_class <= UMAD_CLASS_VENDOR_RANGE1_END)
> +	    || (UMAD_CLASS_VENDOR_RANGE2_START <= mgmt_class
> +		&& mgmt_class <= UMAD_CLASS_VENDOR_RANGE2_END))
> +		return("Vendor");
> +
> +	if (UMAD_CLASS_APPLICATION_START <= mgmt_class
> +	    && mgmt_class <= UMAD_CLASS_APPLICATION_END) {
> +		return("Application");
> +	}
> +	return ("<unknown>");
> +}
> +
> +static char * umad_common_method_str(uint8_t method)
> +{
> +	switch(method) {
> +		case UMAD_METHOD_GET:
> +			return ("Get");
> +		case UMAD_METHOD_SET:
> +			return ("Set");
> +		case UMAD_METHOD_GET_RESP:
> +			return ("GetResp");
> +		case UMAD_METHOD_SEND:
> +			return ("Send");
> +		case UMAD_METHOD_TRAP:
> +			return ("Trap");
> +		case UMAD_METHOD_REPORT:
> +			return ("Report");
> +		case UMAD_METHOD_REPORT_RESP:
> +			return ("ReportResp");
> +		case UMAD_METHOD_TRAP_REPRESS:
> +			return ("TrapRepress");
> +		case UMAD_METHOD_RESP:
> +			return ("Resp");

There's no RESP method, right ? So shouldn't UMAD_METHOD_RESP case be
removed ?

-- Hal

> +		default:
> +			return ("<unknown");
> +	}
> +}
> +

<snip...>

--
To unsubscribe from this list: send the line "unsubscribe linux-rdma" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

  parent reply	other threads:[~2013-02-22 18:27 UTC|newest]

Thread overview: 23+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-02-22 17:13 [PATCH] libibumad: add string functions for various enums Ira Weiny
     [not found] ` <20130222091333.57b91bbb5957928eeb0e62a7-i2BcT+NCU+M@public.gmane.org>
2013-02-22 18:27   ` Hal Rosenstock [this message]
     [not found]     ` <5127B87E.5020907-LDSdmyG8hGV8YrgS2mwiifqBs+8SCbDb@public.gmane.org>
2013-02-22 19:23       ` Ira Weiny
     [not found]         ` <20130222112315.9469e2a6003a98d26d2f1ec5-i2BcT+NCU+M@public.gmane.org>
2013-02-22 19:24           ` Hal Rosenstock
2013-02-22 20:23       ` Jason Gunthorpe
     [not found]         ` <20130222202314.GB10206-ePGOBjL8dl3ta4EC/59zMFaTQe2KTcn/@public.gmane.org>
2013-02-22 20:56           ` Hal Rosenstock
     [not found]             ` <5127DB75.60709-LDSdmyG8hGV8YrgS2mwiifqBs+8SCbDb@public.gmane.org>
2013-02-22 21:01               ` Jason Gunthorpe
     [not found]                 ` <20130222210117.GB15093-ePGOBjL8dl3ta4EC/59zMFaTQe2KTcn/@public.gmane.org>
2013-02-22 21:11                   ` Ira Weiny
2013-02-22 18:47   ` Hefty, Sean
     [not found]     ` <1828884A29C6694DAF28B7E6B8A823736F352A97-P5GAC/sN6hmkrb+BlOpmy7fspsVTdybXVpNB7YpNyf8@public.gmane.org>
2013-02-22 19:19       ` Ira Weiny
     [not found]         ` <20130222111908.2f8b1e56a8f67396a91a3893-i2BcT+NCU+M@public.gmane.org>
2013-02-22 20:00           ` Hefty, Sean
     [not found]             ` <1828884A29C6694DAF28B7E6B8A823736F352B11-P5GAC/sN6hmkrb+BlOpmy7fspsVTdybXVpNB7YpNyf8@public.gmane.org>
2013-02-22 23:07               ` Ira Weiny
     [not found]                 ` <20130222150713.ca761aa639c497c483d9a938-i2BcT+NCU+M@public.gmane.org>
2013-02-23  0:53                   ` Hefty, Sean
     [not found]                     ` <1828884A29C6694DAF28B7E6B8A823736F352C29-P5GAC/sN6hmkrb+BlOpmy7fspsVTdybXVpNB7YpNyf8@public.gmane.org>
2013-02-23  4:46                       ` Ira Weiny
  -- strict thread matches above, loose matches on Subject: below --
2013-03-01 19:40 Ira Weiny
     [not found] ` <20130301114034.85fdbe136d503d803cb167ae-i2BcT+NCU+M@public.gmane.org>
2013-03-01 21:30   ` Hal Rosenstock
     [not found]     ` <51311E07.8070209-LDSdmyG8hGV8YrgS2mwiifqBs+8SCbDb@public.gmane.org>
2013-03-01 21:33       ` Ira Weiny
     [not found]         ` <20130301133305.29edc9171b3a264b277e34ed-i2BcT+NCU+M@public.gmane.org>
2013-03-01 22:05           ` Hefty, Sean
     [not found]             ` <1828884A29C6694DAF28B7E6B8A823736F3561BF-P5GAC/sN6hmkrb+BlOpmy7fspsVTdybXVpNB7YpNyf8@public.gmane.org>
2013-03-01 22:08               ` Ira Weiny
     [not found]                 ` <20130301140811.99423e66848a1509e08bc5ec-i2BcT+NCU+M@public.gmane.org>
2013-03-01 22:28                   ` Hefty, Sean
     [not found]                     ` <24c3c83e-bd79-4e10-8569-6106860d43a1@email.android.com>
     [not found]                       ` <24c3c83e-bd79-4e10-8569-6106860d43a1-2ueSQiBKiTY7tOexoI0I+QC/G2K4zDHf@public.gmane.org>
2013-03-02  1:56                         ` Ira Weiny
     [not found]                           ` <CAMLCd9L2gkMEAxo2evE66R55RcGPct2WWre=wBav1zYTkA3Pdw-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2013-03-02 13:36                             ` Hal Rosenstock
2013-03-07 11:36   ` Hal Rosenstock

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=5127B87E.5020907@dev.mellanox.co.il \
    --to=hal-ldsdmyg8hgv8yrgs2mwiifqbs+8scbdb@public.gmane.org \
    --cc=hal-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org \
    --cc=linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
    --cc=weiny2-i2BcT+NCU+M@public.gmane.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox