lists.openwall.net | lists / announce owl-users owl-dev john-users john-dev passwdqc-users yescrypt popa3d-users / oss-security kernel-hardening musl sabotage tlsify passwords / crypt-dev xvendor / Bugtraq Full-Disclosure linux-kernel linux-netdev linux-ext4 linux-hardening PHC | |
Open Source and information security mailing list archives
| ||
|
Date: Mon, 19 Mar 2007 11:38:29 -0700 (PDT) From: Linus Torvalds <torvalds@...ux-foundation.org> To: "Eric W. Biederman" <ebiederm@...ssion.com> cc: Rusty Russell <rusty@...tcorp.com.au>, Andi Kleen <ak@....de>, David Miller <davem@...emloft.net>, jeremy@...p.org, mingo@...e.hu, akpm@...ux-foundation.org, linux-kernel@...r.kernel.org, virtualization@...ts.osdl.org, xen-devel@...ts.xensource.com, chrisw@...s-sol.org, zach@...are.com, anthony@...emonkey.ws, netdev@...r.kernel.org Subject: Re: [patch 13/26] Xen-paravirt_ops: Consistently wrap paravirt ops callsites to make them patchable On Mon, 19 Mar 2007, Eric W. Biederman wrote: > > True. You can use all of the call clobbered registers. Quite often, the biggest single win of inlining is not so much the code size (although if done right, that will be smaller too), but the fact that inlining DOES NOT CLOBBER AS MANY REGISTERS! The lack of register clobbering, and the freedom for the compiler to choose registers around an inlined function is usually the biggest win! If you can't do that, then inlining generally doesn't actually even help: a call/return to a single instruction isn't all that much slower than just doing the "cli" in the first place. If we end up with a setup where any inlined instruction needs to act as if it was a function call (just with the "call" instruction papered over with the inlined instruction sequence), then there is no point to this at all. In short: people here seem to think that inlining is about avoiding the call/ret sequence. Not so. The real advantages of inlining are elsewhere. So *please* don't believe that you can make it "as cheap" to have some automatic fixup of two sequences, one inlined and one as a "call". It may look so when you look at the single instruction generated, but you're ignoring all the instructions *around* the site. Linus - 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