[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <1415995451.15154.54.camel@localhost>
Date: Fri, 14 Nov 2014 21:04:11 +0100
From: Hannes Frederic Sowa <hannes@...essinduktion.org>
To: David Miller <davem@...emloft.net>
Cc: eric.dumazet@...il.com, netdev@...r.kernel.org,
ogerlitz@...lanox.com, pshelar@...ira.com, jesse@...ira.com,
jay.vosburgh@...onical.com, discuss@...nvswitch.org
Subject: Re: [PATCH net-next] fast_hash: clobber registers correctly for
inline function use
On Fr, 2014-11-14 at 13:38 -0500, David Miller wrote:
> From: Hannes Frederic Sowa <hannes@...essinduktion.org>
> Date: Fri, 14 Nov 2014 16:46:18 +0100
>
> > I would still like to see the current proposed fix getting applied and
> > we can do this on-top. The inline call after this patch reassembles a
> > direct function call, so besides the long list of clobbers, it should
> > still be pretty fast.
>
> I would rather revert the change entirely until it is implemented
> properly.
>
> Also, I am strongly of the opinion that this is a mis-use of the
> alternative call interface. It was never intended to be used for
> things that can make real function calls.
I tend to disagree. Grepping e.g. shows
alternative_call_2(copy_user_generic_unrolled,
copy_user_generic_string,
X86_FEATURE_REP_GOOD,
copy_user_enhanced_fast_string,
X86_FEATURE_ERMS,
ASM_OUTPUT2("=a" (ret), "=D" (to), "=S" (from),
"=d" (len)),
"1" (to), "2" (from), "3" (len)
: "memory", "rcx", "r8", "r9", "r10", "r11");
(it has a few less clobbers because it has more output operands)
I just tried to come up with some macros which lets you abstract away
the clobber list, but in the end it somehow has to look exactly like
that. The double-colon syntax also makes it difficult to come up with
something that let's us use varargs for that.
> You can add a million clobbers, or a trampoline, it's still using a
> facility in a manner for which it was not designed.
The full clobber list for a function call which would always clear
registers like we would have in a normal non-inlined function call would
look like this:
#define FUNC_CLOBBER LIST "memory", "cc", "rax", "rdi", "rsi", "rdx", "rcx", "r8", "r9", "r10", "r11"
(reference in arch/x86/include/asm/calling.h).
> This means a new interface with a new name and with capabilities
> explicitly supporting this case are in order.
It try to implicitly embed the clobber list, would something like that
be ok?
Thanks,
Hannes
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists