Hi guys, Sorry I haven't been keeping up to date with this thread I've been away. On Thu, 2016-02-11 at 09:42 +0100, Torsten Duwe wrote: > On Thu, Feb 11, 2016 at 06:48:17PM +1100, Balbir Singh wrote: > > On Wed, 2016-02-10 at 17:25 +0100, Torsten Duwe 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()). So I think this is just one of the "fun" details we have to deal with to implement kernel tracing. The first implication of this is that there is not a single offset value for the _mcount call, it needs to be calculated per-function. In practice there will only be two values, so we could try both, or we could just have the code work it out dynamically by looking for the expected code sequence? Secondly it means the ftrace trampoline needs to cope with being called with r2 containing something other than the kernel TOC (ie. a module's TOC pointer). But I think that's solvable also? cheers -- 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