* [PATCH net-next] selftests: net: rebuild YNL if dependencies changed
@ 2024-10-10 22:08 Jakub Kicinski
2024-10-10 22:16 ` Jakub Kicinski
2024-10-10 22:42 ` Stanislav Fomichev
0 siblings, 2 replies; 3+ messages in thread
From: Jakub Kicinski @ 2024-10-10 22:08 UTC (permalink / raw)
To: davem; +Cc: netdev, edumazet, pabeni, Jakub Kicinski, sdf
Try to rebuild YNL if either user added a new family or the specs
of the families have changed. Stanislav's ncdevmem cause a false
positive build failure in NIPA because libynl.a isn't rebuilt
after ethtool is added to YNL_GENS.
Note that sha1sum is already used in other parts of the build system.
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
---
CC: sdf@fomichev.me
---
tools/testing/selftests/net/ynl.mk | 15 +++++++++++++--
1 file changed, 13 insertions(+), 2 deletions(-)
diff --git a/tools/testing/selftests/net/ynl.mk b/tools/testing/selftests/net/ynl.mk
index 1ef24119def0..07bc011e6d9a 100644
--- a/tools/testing/selftests/net/ynl.mk
+++ b/tools/testing/selftests/net/ynl.mk
@@ -9,6 +9,8 @@
# YNL_GEN_FILES: TEST_GEN_FILES which need YNL
YNL_OUTPUTS := $(patsubst %,$(OUTPUT)/%,$(YNL_GEN_FILES))
+YNL_SPECS := \
+ $(patsubst %,$(top_srcdir)/Documentation/netlink/specs/%.yaml,$(YNL_GENS))
$(YNL_OUTPUTS): $(OUTPUT)/libynl.a
$(YNL_OUTPUTS): CFLAGS += \
@@ -16,10 +18,19 @@ $(YNL_OUTPUTS): CFLAGS += \
-I$(top_srcdir)/tools/net/ynl/lib/ \
-I$(top_srcdir)/tools/net/ynl/generated/
-$(OUTPUT)/libynl.a:
+# Make sure we rebuild libynl if user added a new family. We can't easily
+# depend on the contents of a variable so create a fake file with a hash.
+YNL_GENS_HASH := $(shell echo $(YNL_GENS) | sha1sum | cut -c1-8)
+$(OUTPUT)/libynl-$(YNL_GENS_HASH).sig:
+ $(Q)rm -f $(OUTPUT)/libynl-*.sig
+ $(Q)touch $(OUTPUT)/libynl-$(YNL_GENS_HASH).sig
+
+$(OUTPUT)/libynl.a: $(YNL_SPECS) $(OUTPUT)/libynl-$(YNL_GENS_HASH).sig
+ $(Q)rm -f $(top_srcdir)/tools/net/ynl/libynl.a
$(Q)$(MAKE) -C $(top_srcdir)/tools/net/ynl GENS="$(YNL_GENS)" libynl.a
$(Q)cp $(top_srcdir)/tools/net/ynl/libynl.a $(OUTPUT)/libynl.a
EXTRA_CLEAN += \
$(top_srcdir)/tools/net/ynl/lib/__pycache__ \
- $(top_srcdir)/tools/net/ynl/lib/*.[ado]
+ $(top_srcdir)/tools/net/ynl/lib/*.[ado] \
+ $(OUTPUT)/libynl-*.sig
--
2.46.2
^ permalink raw reply related [flat|nested] 3+ messages in thread
* Re: [PATCH net-next] selftests: net: rebuild YNL if dependencies changed
2024-10-10 22:08 [PATCH net-next] selftests: net: rebuild YNL if dependencies changed Jakub Kicinski
@ 2024-10-10 22:16 ` Jakub Kicinski
2024-10-10 22:42 ` Stanislav Fomichev
1 sibling, 0 replies; 3+ messages in thread
From: Jakub Kicinski @ 2024-10-10 22:16 UTC (permalink / raw)
To: davem; +Cc: netdev, edumazet, pabeni, sdf
On Thu, 10 Oct 2024 15:08:26 -0700 Jakub Kicinski wrote:
> + $(Q)rm -f $(OUTPUT)/libynl-*.sig
> + $(Q)touch $(OUTPUT)/libynl-$(YNL_GENS_HASH).sig
I forgot about .gitignore :(
--
pw-bot: cr
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH net-next] selftests: net: rebuild YNL if dependencies changed
2024-10-10 22:08 [PATCH net-next] selftests: net: rebuild YNL if dependencies changed Jakub Kicinski
2024-10-10 22:16 ` Jakub Kicinski
@ 2024-10-10 22:42 ` Stanislav Fomichev
1 sibling, 0 replies; 3+ messages in thread
From: Stanislav Fomichev @ 2024-10-10 22:42 UTC (permalink / raw)
To: Jakub Kicinski; +Cc: davem, netdev, edumazet, pabeni, sdf
On 10/10, Jakub Kicinski wrote:
> Try to rebuild YNL if either user added a new family or the specs
> of the families have changed. Stanislav's ncdevmem cause a false
> positive build failure in NIPA because libynl.a isn't rebuilt
> after ethtool is added to YNL_GENS.
>
> Note that sha1sum is already used in other parts of the build system.
>
> Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Acked-by: Stanislav Fomichev <sdf@fomichev.me>
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2024-10-10 22:42 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-10-10 22:08 [PATCH net-next] selftests: net: rebuild YNL if dependencies changed Jakub Kicinski
2024-10-10 22:16 ` Jakub Kicinski
2024-10-10 22:42 ` Stanislav Fomichev
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).