* Josh Poimboeuf <jpoimboe@xxxxxxxxxx> wrote: > > So it would be nice to also add a build time warning if the 'upstream' copy of > > hashtable.h deviates from the tooling file. > > > > Just like you are already doing it for other files: > > > > objtool/Makefile: diff -I'^#include' arch/x86/insn/insn.c ../../arch/x86/lib/insn.c >/dev/null && \ > > > > Btw., eventually we might want to factor out such duplication into a single > > place in tools/lib/ or so, to only have a 'master copy' (upstream kernel > > source), and the tooling copy. > > Yeah, since we already have at least two instances of this type of diffing in > the tools tree, it would be good to generalize these diffs in a common place > with a common kernel build target. I'll add it to my TODOs. > > BTW, do you know why the policy is to copy them instead of just including the > kernel versions? Yeah, so we started with that, but it occasionally resulted in build failures being introduced on the kernel side, which wasn't noticed on the tooling side immediately. (as you don't normally build tooling if you build the kernel.) Linus (rightfully) complained about that kind of overly tight coupling, and we figured out the diff method you can see on the tooling side: we copy files but don't let them stay forked too long: we detect differences and warn about them in a soft fashion (just emit a warning), without breaking the tooling side or the kernel side. And you are perfectly right that this should be made an integral, easy to utilize part of the tooling build system. > Or if the goal is only to make it possible to compile kernel headers in user > space, then we may only need to copy or recreate some headers and I may have > been overzealous with my copying. So the goal is to have all the benefits of sharing code (kernel libraries and headers are cool and well-maintained), without any of the disadvantages of such tight code sharing! ;-) That's why we came up with this method, which is essentially a distributed file system with a manual, high latency cache coherency protocol. Thanks, Ingo -- 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