* [PATCH 2/8] opensm/complib: define "if" statements with branch prediction hints
@ 2012-08-14 21:32 Yevgeny Kliteynik
[not found] ` <502AC3DC.9090102-VPRAkNaXOzVS1MOuV/RT9w@public.gmane.org>
0 siblings, 1 reply; 7+ messages in thread
From: Yevgeny Kliteynik @ 2012-08-14 21:32 UTC (permalink / raw)
To: Linux RDMA, alexne-VPRAkNaXOzVWk0Htik3J/w, Yevgeny Kliteynik
Defined "if_PT" and "if_PF" for "predict true"
and "predict false" respectively.
Signed-off-by: Yevgeny Kliteynik <kliteyn-LDSdmyG8hGV8YrgS2mwiifqBs+8SCbDb@public.gmane.org>
---
include/complib/cl_types_osd.h | 17 ++++++++++++++++-
1 file changed, 16 insertions(+), 1 deletion(-)
diff --git a/include/complib/cl_types_osd.h b/include/complib/cl_types_osd.h
index ce1a452..f9abb28 100644
--- a/include/complib/cl_types_osd.h
+++ b/include/complib/cl_types_osd.h
@@ -1,6 +1,6 @@
/*
* Copyright (c) 2004-2009 Voltaire, Inc. All rights reserved.
- * Copyright (c) 2002-2005 Mellanox Technologies LTD. All rights reserved.
+ * Copyright (c) 2002-2012 Mellanox Technologies LTD. All rights reserved.
* Copyright (c) 1996-2003 Intel Corporation. All rights reserved.
*
* This software is available to you under a choice of one of two
@@ -64,6 +64,21 @@ BEGIN_C_DECLS
#include <inttypes.h>
#include <assert.h>
#include <string.h>
+
+/*
+ * Branch prediction hints
+ */
+#if defined(HAVE_BUILTIN_EXPECT)
+#define CL_PREDICT_TRUE(exp) __builtin_expect( ((uintptr_t)(exp)), 1 )
+#define CL_PREDICT_FALSE(exp) __builtin_expect( ((uintptr_t)(exp)), 0 )
+#else
+#define CL_PREDICT_TRUE(exp) (exp)
+#define CL_PREDICT_FALSE(exp) (exp)
+#endif
+
+#define if_PF(cond) if(CL_PREDICT_FALSE(cond))
+#define if_PT(cond) if(CL_PREDICT_TRUE(cond))
+
#if defined (_DEBUG_)
#define CL_ASSERT assert
#else /* _DEBUG_ */
--
1.7.11.1
--
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
^ permalink raw reply related [flat|nested] 7+ messages in thread[parent not found: <502AC3DC.9090102-VPRAkNaXOzVS1MOuV/RT9w@public.gmane.org>]
* RE: [PATCH 2/8] opensm/complib: define "if" statements with branch prediction hints [not found] ` <502AC3DC.9090102-VPRAkNaXOzVS1MOuV/RT9w@public.gmane.org> @ 2012-08-14 21:39 ` Hefty, Sean [not found] ` <1828884A29C6694DAF28B7E6B8A8237346A892A4-P5GAC/sN6hmkrb+BlOpmy7fspsVTdybXVpNB7YpNyf8@public.gmane.org> 0 siblings, 1 reply; 7+ messages in thread From: Hefty, Sean @ 2012-08-14 21:39 UTC (permalink / raw) To: kliteyn-LDSdmyG8hGV8YrgS2mwiifqBs+8SCbDb@public.gmane.org, Linux RDMA, alexne-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org > +#define if_PF(cond) if(CL_PREDICT_FALSE(cond)) > +#define if_PT(cond) if(CL_PREDICT_TRUE(cond)) If CL_PREDICT_TRUE/FALSE are too long, why not just shorten those, rather than abstract if statements behind a macro? -- 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 ^ permalink raw reply [flat|nested] 7+ messages in thread
[parent not found: <1828884A29C6694DAF28B7E6B8A8237346A892A4-P5GAC/sN6hmkrb+BlOpmy7fspsVTdybXVpNB7YpNyf8@public.gmane.org>]
* Re: [PATCH 2/8] opensm/complib: define "if" statements with branch prediction hints [not found] ` <1828884A29C6694DAF28B7E6B8A8237346A892A4-P5GAC/sN6hmkrb+BlOpmy7fspsVTdybXVpNB7YpNyf8@public.gmane.org> @ 2012-08-14 21:54 ` Jason Gunthorpe [not found] ` <20120814215413.GA29245-ePGOBjL8dl3ta4EC/59zMFaTQe2KTcn/@public.gmane.org> 0 siblings, 1 reply; 7+ messages in thread From: Jason Gunthorpe @ 2012-08-14 21:54 UTC (permalink / raw) To: Hefty, Sean Cc: kliteyn-LDSdmyG8hGV8YrgS2mwiifqBs+8SCbDb@public.gmane.org, Linux RDMA, alexne-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org On Tue, Aug 14, 2012 at 09:39:23PM +0000, Hefty, Sean wrote: > > +#define if_PF(cond) if(CL_PREDICT_FALSE(cond)) > > +#define if_PT(cond) if(CL_PREDICT_TRUE(cond)) > > If CL_PREDICT_TRUE/FALSE are too long, why not just shorten those, > rather than abstract if statements behind a macro? If you are typing these so often (ie more than in some datastructure kernels) that the length is a problem then you really should be using profile guided optimization instead... Jason -- 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 ^ permalink raw reply [flat|nested] 7+ messages in thread
[parent not found: <20120814215413.GA29245-ePGOBjL8dl3ta4EC/59zMFaTQe2KTcn/@public.gmane.org>]
* Re: [PATCH 2/8] opensm/complib: define "if" statements with branch prediction hints [not found] ` <20120814215413.GA29245-ePGOBjL8dl3ta4EC/59zMFaTQe2KTcn/@public.gmane.org> @ 2012-08-26 13:43 ` Yevgeny Kliteynik [not found] ` <503A2814.6030709-LDSdmyG8hGV8YrgS2mwiifqBs+8SCbDb@public.gmane.org> 0 siblings, 1 reply; 7+ messages in thread From: Yevgeny Kliteynik @ 2012-08-26 13:43 UTC (permalink / raw) To: Jason Gunthorpe Cc: Hefty, Sean, Linux RDMA, alexne-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org Hi, Sorry for the delay with a response - just got back from a long vacation. On 8/15/2012 12:54 AM, Jason Gunthorpe wrote: > On Tue, Aug 14, 2012 at 09:39:23PM +0000, Hefty, Sean wrote: >>> +#define if_PF(cond) if(CL_PREDICT_FALSE(cond)) >>> +#define if_PT(cond) if(CL_PREDICT_TRUE(cond)) >> >> If CL_PREDICT_TRUE/FALSE are too long, why not just shorten those, >> rather than abstract if statements behind a macro? It's not the size - it's just the readability of the macro. First macro (CL_PREDICT_*) is close to the GCC's way to define it. Second macro (if_PF/T) is close to the usual 'if' statement syntax. If you think it's a deal breaker, I can lose the first macro and have everything in one macro. > If you are typing these so often (ie more than in some datastructure > kernels) that the length is a problem then you really should be using > profile guided optimization instead... I'm trying to optimize all the 'if' conditions in the SM. As I described in patch 3/8 (next patch in these series), I don't touch all the non-fatal cases. The goal is not to help SM to perform better in general (in which case I agree than PGO would be the right way to go), but to make sure that the fatal cases will never be predicted wrong, so any fatal check (existing or a newly added one) won't affect the SM performance. Also, the plan is to define a new ASSERT macro that will use this if_PF thing to make sure that ASSERT statement doesn't cost much (if any). -- YK > Jason > -- 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 ^ permalink raw reply [flat|nested] 7+ messages in thread
[parent not found: <503A2814.6030709-LDSdmyG8hGV8YrgS2mwiifqBs+8SCbDb@public.gmane.org>]
* Re: [PATCH 2/8] opensm/complib: define "if" statements with branch prediction hints [not found] ` <503A2814.6030709-LDSdmyG8hGV8YrgS2mwiifqBs+8SCbDb@public.gmane.org> @ 2012-08-26 13:56 ` Yevgeny Kliteynik 2012-08-27 17:51 ` Hefty, Sean 1 sibling, 0 replies; 7+ messages in thread From: Yevgeny Kliteynik @ 2012-08-26 13:56 UTC (permalink / raw) To: kliteyn-LDSdmyG8hGV8YrgS2mwiifqBs+8SCbDb, Jason Gunthorpe, Hefty, Sean Cc: Linux RDMA, alexne-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org On 8/26/2012 4:43 PM, Yevgeny Kliteynik wrote: > >> If you are typing these so often (ie more than in some datastructure >> kernels) that the length is a problem then you really should be using >> profile guided optimization instead... > > I'm trying to optimize all the 'if' conditions in the SM. Obviously, what I meant is that I'm *not* trying to optimize all the 'if' conditions in the SM... :) -- YK -- 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 ^ permalink raw reply [flat|nested] 7+ messages in thread
* RE: [PATCH 2/8] opensm/complib: define "if" statements with branch prediction hints [not found] ` <503A2814.6030709-LDSdmyG8hGV8YrgS2mwiifqBs+8SCbDb@public.gmane.org> 2012-08-26 13:56 ` Yevgeny Kliteynik @ 2012-08-27 17:51 ` Hefty, Sean [not found] ` <1828884A29C6694DAF28B7E6B8A8237346A8B2AD-P5GAC/sN6hmkrb+BlOpmy7fspsVTdybXVpNB7YpNyf8@public.gmane.org> 1 sibling, 1 reply; 7+ messages in thread From: Hefty, Sean @ 2012-08-27 17:51 UTC (permalink / raw) To: kliteyn-LDSdmyG8hGV8YrgS2mwiifqBs+8SCbDb@public.gmane.org, Jason Gunthorpe Cc: Linux RDMA, alexne-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org > On 8/15/2012 12:54 AM, Jason Gunthorpe wrote: > > On Tue, Aug 14, 2012 at 09:39:23PM +0000, Hefty, Sean wrote: > >>> +#define if_PF(cond) if(CL_PREDICT_FALSE(cond)) > >>> +#define if_PT(cond) if(CL_PREDICT_TRUE(cond)) > >> > >> If CL_PREDICT_TRUE/FALSE are too long, why not just shorten those, > >> rather than abstract if statements behind a macro? > > It's not the size - it's just the readability of the macro. > First macro (CL_PREDICT_*) is close to the GCC's way to define > it. Second macro (if_PF/T) is close to the usual 'if' statement > syntax. I would not abstract the 'if' statement. If CL_PREDICT_FALSE/TRUE are not readable, then shorten those. if (PF(...)) is just as readable as if_PF(...) -- 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 ^ permalink raw reply [flat|nested] 7+ messages in thread
[parent not found: <1828884A29C6694DAF28B7E6B8A8237346A8B2AD-P5GAC/sN6hmkrb+BlOpmy7fspsVTdybXVpNB7YpNyf8@public.gmane.org>]
* Re: [PATCH 2/8] opensm/complib: define "if" statements with branch prediction hints [not found] ` <1828884A29C6694DAF28B7E6B8A8237346A8B2AD-P5GAC/sN6hmkrb+BlOpmy7fspsVTdybXVpNB7YpNyf8@public.gmane.org> @ 2012-09-11 15:23 ` Yevgeny Kliteynik 0 siblings, 0 replies; 7+ messages in thread From: Yevgeny Kliteynik @ 2012-09-11 15:23 UTC (permalink / raw) To: Hefty, Sean Cc: Jason Gunthorpe, Linux RDMA, alexne-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org > > I would not abstract the 'if' statement. If CL_PREDICT_FALSE/TRUE are not readable, then shorten those. > > if (PF(...)) > > is just as readable as > > if_PF(...) OK, agree. I'll issue a v2 shortly - the only difference would be change in this macro and rebase to the updated trunk. -- YK -- 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 ^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2012-09-11 15:23 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2012-08-14 21:32 [PATCH 2/8] opensm/complib: define "if" statements with branch prediction hints Yevgeny Kliteynik
[not found] ` <502AC3DC.9090102-VPRAkNaXOzVS1MOuV/RT9w@public.gmane.org>
2012-08-14 21:39 ` Hefty, Sean
[not found] ` <1828884A29C6694DAF28B7E6B8A8237346A892A4-P5GAC/sN6hmkrb+BlOpmy7fspsVTdybXVpNB7YpNyf8@public.gmane.org>
2012-08-14 21:54 ` Jason Gunthorpe
[not found] ` <20120814215413.GA29245-ePGOBjL8dl3ta4EC/59zMFaTQe2KTcn/@public.gmane.org>
2012-08-26 13:43 ` Yevgeny Kliteynik
[not found] ` <503A2814.6030709-LDSdmyG8hGV8YrgS2mwiifqBs+8SCbDb@public.gmane.org>
2012-08-26 13:56 ` Yevgeny Kliteynik
2012-08-27 17:51 ` Hefty, Sean
[not found] ` <1828884A29C6694DAF28B7E6B8A8237346A8B2AD-P5GAC/sN6hmkrb+BlOpmy7fspsVTdybXVpNB7YpNyf8@public.gmane.org>
2012-09-11 15:23 ` Yevgeny Kliteynik
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).