tools: ynl: work around stale system headers
authorJakub Kicinski <kuba@kernel.org>
Wed, 14 Jun 2023 00:28:00 +0000 (17:28 -0700)
committerDavid S. Miller <davem@davemloft.net>
Thu, 15 Jun 2023 10:44:37 +0000 (11:44 +0100)
commitf0ec58d557d65838974035ffd8a8862cf8166a81
treeea77ee95c881927a10d7c3794b5ce5f03b08754b
parented3c9a2fcab3b60b0766eb5d7566fd3b10df9a8e
tools: ynl: work around stale system headers

The inability to include the uAPI headers directly in tools/
is one of the bigger annoyances of compiling user space code.
Most projects trade the pain for smaller inconvenience of having
to copy the headers under tools/include.

In case of netlink headers I think that we can avoid both.
Netlink family headers are simple and should be self-contained.
We can try to twiddle the Makefile a little to force-include
just the family header, and use system headers for the rest.

This works fairly well. There are two warts - for some reason
if we specify -include $path/family.h as a compilation flag,
the #ifdef header guard does not seem to work. So we need
to throw the guard in on the command line as well. Seems like
GCC detects that the header is different and tries to include
both. Second problem is that make wants hash sign to be escaped
or not depending on the version. Sigh.

Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
tools/net/ynl/Makefile.deps [new file with mode: 0644]
tools/net/ynl/generated/Makefile
tools/net/ynl/samples/Makefile