On Mon, 15 Feb 2016, Michael Ellerman wrote: > > > > +echo "int func() { return 0; }" | \ > > > > + $* -S -x c -O2 -p -mprofile-kernel - -o - 2> /dev/null | \ > > > > + sed -n -e '/func:/,/bl _mcount/p' | grep -q TOC > > > > + > > > > +leaf_toc_result=$? > > > > > > leaf_toc_result failed for me with gcc 5. I'll try and grab gcc-6 > > > and give the patches a spin > > > > Don't bother. _All_ gccs are broken in that respect currently. > > I'm not sure where we got our wires crossed on this one, but this is not a gcc > bug. In fact it's a feature :) > > There is explicit code in gcc to check whether the TOC setup is needed and only > emit it when it's required. One case where it's *not* required is when the > function does not TOC accesses. (See rs6000_global_entry_point_needed_p()). As gcc actually implements a '-mprofile-kernel' option, it's pretty much aware of the fact that the inserted space will be used by the kernel for inserting a call (as that's the sole point of the whole thing). Therefore it must not consider any traceable function to be leaf (even though it might "look" leaf from the source code); if it does, then the mprofile-kernel option is useless. So I actually would dare to call it a bug. Thanks, -- Jiri Kosina SUSE Labs -- To unsubscribe from this list: send the line "unsubscribe live-patching" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html