Buildroot Archive on lore.kernel.org
 help / color / mirror / Atom feed
* [Buildroot] [PATCH] valgrind: allow selecting which tools to install
@ 2012-03-14 16:50 Thomas De Schampheleire
  2012-03-23 14:52 ` Thomas De Schampheleire
                   ` (2 more replies)
  0 siblings, 3 replies; 4+ messages in thread
From: Thomas De Schampheleire @ 2012-03-14 16:50 UTC (permalink / raw)
  To: buildroot

The full valgrind installation takes more than 20 MB, while one typically does
not use all of its tools. This patch adds extra config options to select which
tools to install.

Signed-off-by: Thomas De Schampheleire <thomas.de.schampheleire@gmail.com>

---
 package/valgrind/Config.in   |  70 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 package/valgrind/valgrind.mk |  95 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 2 files changed, 165 insertions(+), 0 deletions(-)

diff --git a/package/valgrind/Config.in b/package/valgrind/Config.in
--- a/package/valgrind/Config.in
+++ b/package/valgrind/Config.in
@@ -6,3 +6,73 @@ config BR2_PACKAGE_VALGRIND
 	  Tool for debugging and profiling Linux programs.
 
 	  http://valgrind.kde.org/
+
+if BR2_PACKAGE_VALGRIND
+
+config BR2_PACKAGE_VALGRIND_MEMCHECK
+	bool "Memcheck: a memory error detector"
+	default y
+	help
+	  This option allows to install the Memcheck tool
+
+config BR2_PACKAGE_VALGRIND_CACHEGRIND
+	bool "Cachegrind: a cache and branch-prediction profiler"
+	default y
+	help
+	  This option allows to install the Cachegrind tool
+
+config BR2_PACKAGE_VALGRIND_CALLGRIND
+	bool "Callgrind: a call-graph generating cache and branch prediction profiler"
+	default y
+	help
+	  This option allows to install the Callgrind tool
+
+config BR2_PACKAGE_VALGRIND_HELGRIND
+	bool "Helgrind: a thread error detector"
+	default y
+	help
+	  This option allows to install the Helgrind tool
+
+config BR2_PACKAGE_VALGRIND_DRD
+	bool "DRD: a thread error detector"
+	default y
+	help
+	  This option allows to install the DRD tool
+
+config BR2_PACKAGE_VALGRIND_MASSIF
+	bool "Massif: a heap profiler"
+	default y
+	help
+	  This option allows to install the Massif tool
+
+config BR2_PACKAGE_VALGRIND_DHAT
+	bool "DHAT: a dynamic heap analysis tool"
+	default y
+	help
+	  This option allows to install the DHAT tool
+
+config BR2_PACKAGE_VALGRIND_PTRCHECK
+	bool "Ptrcheck: an experimental head, stack and global array overrun detector"
+	default y
+	help
+	  This option allows to install the Ptrcheck tool
+
+config BR2_PACKAGE_VALGRIND_BBV
+	bool "BBV: an experimental basic block vector generation tool"
+	default y
+	help
+	  This option allows to install the BBV tool
+
+config BR2_PACKAGE_VALGRIND_LACKEY
+	bool "Lackey: an example tool"
+	default y
+	help
+	  This option allows to install the Lackey tool
+
+config BR2_PACKAGE_VALGRIND_NULGRIND
+	bool "Nulgrind: the minimal Valgrind tool"
+	default y
+	help
+	  This option allows to install the Nulgrind tool
+
+endif
diff --git a/package/valgrind/valgrind.mk b/package/valgrind/valgrind.mk
--- a/package/valgrind/valgrind.mk
+++ b/package/valgrind/valgrind.mk
@@ -25,4 +25,99 @@ endef
 
 VALGRIND_POST_INSTALL_TARGET_HOOKS += VALGRIND_INSTALL_UCLIBC_SUPP
 
+ifeq ($(BR2_PACKAGE_VALGRIND_MEMCHECK),)
+define VALGRIND_REMOVE_MEMCHECK
+	rm -f $(TARGET_DIR)/usr/lib/valgrind/*memcheck*
+endef
+
+VALGRIND_POST_INSTALL_TARGET_HOOKS += VALGRIND_REMOVE_MEMCHECK
+endif
+
+ifeq ($(BR2_PACKAGE_VALGRIND_CACHEGRIND),)
+define VALGRIND_REMOVE_CACHEGRIND
+	rm -f $(TARGET_DIR)/usr/lib/valgrind/*cachegrind*
+	for i in cg_annotate cg_diff cg_merge; do \
+		rm -f $(TARGET_DIR)/usr/bin/$$i ; \
+	done
+endef
+
+VALGRIND_POST_INSTALL_TARGET_HOOKS += VALGRIND_REMOVE_CACHEGRIND
+endif
+
+ifeq ($(BR2_PACKAGE_VALGRIND_CALLGRIND),)
+define VALGRIND_REMOVE_CALLGRIND
+	rm -f $(TARGET_DIR)/usr/lib/valgrind/*callgrind*
+	for i in callgrind_annotate callgrind_control ; do \
+		rm -f $(TARGET_DIR)/usr/bin/$$i ; \
+	done
+endef
+
+VALGRIND_POST_INSTALL_TARGET_HOOKS += VALGRIND_REMOVE_CALLGRIND
+endif
+
+ifeq ($(BR2_PACKAGE_VALGRIND_HELGRIND),)
+define VALGRIND_REMOVE_HELGRIND
+	rm -f $(TARGET_DIR)/usr/lib/valgrind/*helgrind*
+endef
+
+VALGRIND_POST_INSTALL_TARGET_HOOKS += VALGRIND_REMOVE_HELGRIND
+endif
+
+ifeq ($(BR2_PACKAGE_VALGRIND_DRD),)
+define VALGRIND_REMOVE_DRD
+	rm -f $(TARGET_DIR)/usr/lib/valgrind/*drd*
+endef
+
+VALGRIND_POST_INSTALL_TARGET_HOOKS += VALGRIND_REMOVE_DRD
+endif
+
+ifeq ($(BR2_PACKAGE_VALGRIND_MASSIF),)
+define VALGRIND_REMOVE_MASSIF
+	rm -f $(TARGET_DIR)/usr/lib/valgrind/*massif*
+	rm -f $(TARGET_DIR)/usr/bin/ms_script
+endef
+
+VALGRIND_POST_INSTALL_TARGET_HOOKS += VALGRIND_REMOVE_MASSIF
+endif
+
+ifeq ($(BR2_PACKAGE_VALGRIND_DHAT),)
+define VALGRIND_REMOVE_DHAT
+	rm -f $(TARGET_DIR)/usr/lib/valgrind/*dhat*
+endef
+
+VALGRIND_POST_INSTALL_TARGET_HOOKS += VALGRIND_REMOVE_DHAT
+endif
+
+ifeq ($(BR2_PACKAGE_VALGRIND_PTRCHECK),)
+define VALGRIND_REMOVE_PTRCHECK
+	rm -f $(TARGET_DIR)/usr/lib/valgrind/*ptrcheck*
+endef
+
+VALGRIND_POST_INSTALL_TARGET_HOOKS += VALGRIND_REMOVE_PTRCHECK
+endif
+
+ifeq ($(BR2_PACKAGE_VALGRIND_BBV),)
+define VALGRIND_REMOVE_BBV
+	rm -f $(TARGET_DIR)/usr/lib/valgrind/*bbv*
+endef
+
+VALGRIND_POST_INSTALL_TARGET_HOOKS += VALGRIND_REMOVE_BBV
+endif
+
+ifeq ($(BR2_PACKAGE_VALGRIND_LACKEY),)
+define VALGRIND_REMOVE_LACKEY
+	rm -f $(TARGET_DIR)/usr/lib/valgrind/*lackey*
+endef
+
+VALGRIND_POST_INSTALL_TARGET_HOOKS += VALGRIND_REMOVE_LACKEY
+endif
+
+ifeq ($(BR2_PACKAGE_VALGRIND_NULGRIND),)
+define VALGRIND_REMOVE_NULGRIND
+	rm -f $(TARGET_DIR)/usr/lib/valgrind/*none*
+endef
+
+VALGRIND_POST_INSTALL_TARGET_HOOKS += VALGRIND_REMOVE_NULGRIND
+endif
+
 $(eval $(call AUTOTARGETS))

^ permalink raw reply	[flat|nested] 4+ messages in thread

* [Buildroot] [PATCH] valgrind: allow selecting which tools to install
  2012-03-14 16:50 [Buildroot] [PATCH] valgrind: allow selecting which tools to install Thomas De Schampheleire
@ 2012-03-23 14:52 ` Thomas De Schampheleire
  2012-03-25 18:51 ` Arnout Vandecappelle
  2012-04-05 14:40 ` Peter Korsgaard
  2 siblings, 0 replies; 4+ messages in thread
From: Thomas De Schampheleire @ 2012-03-23 14:52 UTC (permalink / raw)
  To: buildroot

On Wed, Mar 14, 2012 at 5:50 PM, Thomas De Schampheleire
<patrickdepinguin+buildroot@gmail.com> wrote:
> The full valgrind installation takes more than 20 MB, while one typically does
> not use all of its tools. This patch adds extra config options to select which
> tools to install.
>
> Signed-off-by: Thomas De Schampheleire <thomas.de.schampheleire@gmail.com>
>
> ---
> ?package/valgrind/Config.in ? | ?70 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
> ?package/valgrind/valgrind.mk | ?95 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
> ?2 files changed, 165 insertions(+), 0 deletions(-)
>
> diff --git a/package/valgrind/Config.in b/package/valgrind/Config.in
> --- a/package/valgrind/Config.in
> +++ b/package/valgrind/Config.in
> @@ -6,3 +6,73 @@ config BR2_PACKAGE_VALGRIND
> ? ? ? ? ?Tool for debugging and profiling Linux programs.
>
> ? ? ? ? ?http://valgrind.kde.org/
> +
> +if BR2_PACKAGE_VALGRIND
> +
> +config BR2_PACKAGE_VALGRIND_MEMCHECK
> + ? ? ? bool "Memcheck: a memory error detector"
> + ? ? ? default y
> + ? ? ? help
> + ? ? ? ? This option allows to install the Memcheck tool
> +
> +config BR2_PACKAGE_VALGRIND_CACHEGRIND
> + ? ? ? bool "Cachegrind: a cache and branch-prediction profiler"
> + ? ? ? default y
> + ? ? ? help
> + ? ? ? ? This option allows to install the Cachegrind tool
> +
> +config BR2_PACKAGE_VALGRIND_CALLGRIND
> + ? ? ? bool "Callgrind: a call-graph generating cache and branch prediction profiler"
> + ? ? ? default y
> + ? ? ? help
> + ? ? ? ? This option allows to install the Callgrind tool
> +
> +config BR2_PACKAGE_VALGRIND_HELGRIND
> + ? ? ? bool "Helgrind: a thread error detector"
> + ? ? ? default y
> + ? ? ? help
> + ? ? ? ? This option allows to install the Helgrind tool
> +
> +config BR2_PACKAGE_VALGRIND_DRD
> + ? ? ? bool "DRD: a thread error detector"
> + ? ? ? default y
> + ? ? ? help
> + ? ? ? ? This option allows to install the DRD tool
> +
> +config BR2_PACKAGE_VALGRIND_MASSIF
> + ? ? ? bool "Massif: a heap profiler"
> + ? ? ? default y
> + ? ? ? help
> + ? ? ? ? This option allows to install the Massif tool
> +
> +config BR2_PACKAGE_VALGRIND_DHAT
> + ? ? ? bool "DHAT: a dynamic heap analysis tool"
> + ? ? ? default y
> + ? ? ? help
> + ? ? ? ? This option allows to install the DHAT tool
> +
> +config BR2_PACKAGE_VALGRIND_PTRCHECK
> + ? ? ? bool "Ptrcheck: an experimental head, stack and global array overrun detector"
> + ? ? ? default y
> + ? ? ? help
> + ? ? ? ? This option allows to install the Ptrcheck tool
> +
> +config BR2_PACKAGE_VALGRIND_BBV
> + ? ? ? bool "BBV: an experimental basic block vector generation tool"
> + ? ? ? default y
> + ? ? ? help
> + ? ? ? ? This option allows to install the BBV tool
> +
> +config BR2_PACKAGE_VALGRIND_LACKEY
> + ? ? ? bool "Lackey: an example tool"
> + ? ? ? default y
> + ? ? ? help
> + ? ? ? ? This option allows to install the Lackey tool
> +
> +config BR2_PACKAGE_VALGRIND_NULGRIND
> + ? ? ? bool "Nulgrind: the minimal Valgrind tool"
> + ? ? ? default y
> + ? ? ? help
> + ? ? ? ? This option allows to install the Nulgrind tool
> +
> +endif
> diff --git a/package/valgrind/valgrind.mk b/package/valgrind/valgrind.mk
> --- a/package/valgrind/valgrind.mk
> +++ b/package/valgrind/valgrind.mk
> @@ -25,4 +25,99 @@ endef
>
> ?VALGRIND_POST_INSTALL_TARGET_HOOKS += VALGRIND_INSTALL_UCLIBC_SUPP
>
> +ifeq ($(BR2_PACKAGE_VALGRIND_MEMCHECK),)
> +define VALGRIND_REMOVE_MEMCHECK
> + ? ? ? rm -f $(TARGET_DIR)/usr/lib/valgrind/*memcheck*
> +endef
> +
> +VALGRIND_POST_INSTALL_TARGET_HOOKS += VALGRIND_REMOVE_MEMCHECK
> +endif
> +
> +ifeq ($(BR2_PACKAGE_VALGRIND_CACHEGRIND),)
> +define VALGRIND_REMOVE_CACHEGRIND
> + ? ? ? rm -f $(TARGET_DIR)/usr/lib/valgrind/*cachegrind*
> + ? ? ? for i in cg_annotate cg_diff cg_merge; do \
> + ? ? ? ? ? ? ? rm -f $(TARGET_DIR)/usr/bin/$$i ; \
> + ? ? ? done
> +endef
> +
> +VALGRIND_POST_INSTALL_TARGET_HOOKS += VALGRIND_REMOVE_CACHEGRIND
> +endif
> +
> +ifeq ($(BR2_PACKAGE_VALGRIND_CALLGRIND),)
> +define VALGRIND_REMOVE_CALLGRIND
> + ? ? ? rm -f $(TARGET_DIR)/usr/lib/valgrind/*callgrind*
> + ? ? ? for i in callgrind_annotate callgrind_control ; do \
> + ? ? ? ? ? ? ? rm -f $(TARGET_DIR)/usr/bin/$$i ; \
> + ? ? ? done
> +endef
> +
> +VALGRIND_POST_INSTALL_TARGET_HOOKS += VALGRIND_REMOVE_CALLGRIND
> +endif
> +
> +ifeq ($(BR2_PACKAGE_VALGRIND_HELGRIND),)
> +define VALGRIND_REMOVE_HELGRIND
> + ? ? ? rm -f $(TARGET_DIR)/usr/lib/valgrind/*helgrind*
> +endef
> +
> +VALGRIND_POST_INSTALL_TARGET_HOOKS += VALGRIND_REMOVE_HELGRIND
> +endif
> +
> +ifeq ($(BR2_PACKAGE_VALGRIND_DRD),)
> +define VALGRIND_REMOVE_DRD
> + ? ? ? rm -f $(TARGET_DIR)/usr/lib/valgrind/*drd*
> +endef
> +
> +VALGRIND_POST_INSTALL_TARGET_HOOKS += VALGRIND_REMOVE_DRD
> +endif
> +
> +ifeq ($(BR2_PACKAGE_VALGRIND_MASSIF),)
> +define VALGRIND_REMOVE_MASSIF
> + ? ? ? rm -f $(TARGET_DIR)/usr/lib/valgrind/*massif*
> + ? ? ? rm -f $(TARGET_DIR)/usr/bin/ms_script
> +endef
> +
> +VALGRIND_POST_INSTALL_TARGET_HOOKS += VALGRIND_REMOVE_MASSIF
> +endif
> +
> +ifeq ($(BR2_PACKAGE_VALGRIND_DHAT),)
> +define VALGRIND_REMOVE_DHAT
> + ? ? ? rm -f $(TARGET_DIR)/usr/lib/valgrind/*dhat*
> +endef
> +
> +VALGRIND_POST_INSTALL_TARGET_HOOKS += VALGRIND_REMOVE_DHAT
> +endif
> +
> +ifeq ($(BR2_PACKAGE_VALGRIND_PTRCHECK),)
> +define VALGRIND_REMOVE_PTRCHECK
> + ? ? ? rm -f $(TARGET_DIR)/usr/lib/valgrind/*ptrcheck*
> +endef
> +
> +VALGRIND_POST_INSTALL_TARGET_HOOKS += VALGRIND_REMOVE_PTRCHECK
> +endif
> +
> +ifeq ($(BR2_PACKAGE_VALGRIND_BBV),)
> +define VALGRIND_REMOVE_BBV
> + ? ? ? rm -f $(TARGET_DIR)/usr/lib/valgrind/*bbv*
> +endef
> +
> +VALGRIND_POST_INSTALL_TARGET_HOOKS += VALGRIND_REMOVE_BBV
> +endif
> +
> +ifeq ($(BR2_PACKAGE_VALGRIND_LACKEY),)
> +define VALGRIND_REMOVE_LACKEY
> + ? ? ? rm -f $(TARGET_DIR)/usr/lib/valgrind/*lackey*
> +endef
> +
> +VALGRIND_POST_INSTALL_TARGET_HOOKS += VALGRIND_REMOVE_LACKEY
> +endif
> +
> +ifeq ($(BR2_PACKAGE_VALGRIND_NULGRIND),)
> +define VALGRIND_REMOVE_NULGRIND
> + ? ? ? rm -f $(TARGET_DIR)/usr/lib/valgrind/*none*
> +endef
> +
> +VALGRIND_POST_INSTALL_TARGET_HOOKS += VALGRIND_REMOVE_NULGRIND
> +endif
> +
> ?$(eval $(call AUTOTARGETS))

bump

^ permalink raw reply	[flat|nested] 4+ messages in thread

* [Buildroot] [PATCH] valgrind: allow selecting which tools to install
  2012-03-14 16:50 [Buildroot] [PATCH] valgrind: allow selecting which tools to install Thomas De Schampheleire
  2012-03-23 14:52 ` Thomas De Schampheleire
@ 2012-03-25 18:51 ` Arnout Vandecappelle
  2012-04-05 14:40 ` Peter Korsgaard
  2 siblings, 0 replies; 4+ messages in thread
From: Arnout Vandecappelle @ 2012-03-25 18:51 UTC (permalink / raw)
  To: buildroot

On Wednesday 14 March 2012 17:50:59 Thomas De Schampheleire wrote:
> The full valgrind installation takes more than 20 MB, while one typically does
> not use all of its tools. This patch adds extra config options to select which
> tools to install.
> 
> Signed-off-by: Thomas De Schampheleire <thomas.de.schampheleire@gmail.com>

 Strange that this patch didn't get any feedback before...  I guess we
all trust Thomas enough to make good patches :-)

 I'm a bit at loss as to what to do now.  I believe this patch is useful
and good enough to go in as it is.  So:
Acked-by: Arnout Vandecappelle (Essensium/Mind) <arnout@mind.be>

 On the other hand, I do have some ideas how to make it even better.
But if I write these down, I'm afraid it will slow down the inclusion
of a useful and well-implemented feature...  Well, I'll take the risk:

[snip]
> +config BR2_PACKAGE_VALGRIND_MEMCHECK
> +	bool "Memcheck: a memory error detector"
> +	default y
> +	help
> +	  This option allows to install the Memcheck tool
> +
> +config BR2_PACKAGE_VALGRIND_CACHEGRIND
> +	bool "Cachegrind: a cache and branch-prediction profiler"
> +	default y
> +	help
> +	  This option allows to install the Cachegrind tool

 Even though this breaks existing configurations, I believe that all
tools (with the possible exception of memcheck) should default to
no.  For existing configurations, that's what most people will want
anyway.  And for new configurations, I think it's usually just one,
maybe two tools that are needed, so it's a lot of work to disable
all of them.

[snip]
> +config BR2_PACKAGE_VALGRIND_PTRCHECK
> +	bool "Ptrcheck: an experimental head, stack and global array overrun detector"
> +	default y
> +	help
> +	  This option allows to install the Ptrcheck tool

 At the very least, the experimental ones should default to no.

[snip]
> +config BR2_PACKAGE_VALGRIND_NULGRIND
> +	bool "Nulgrind: the minimal Valgrind tool"
> +	default y
> +	help
> +	  This option allows to install the Nulgrind tool

 And this one definitely should default to no.

[snip]
> +ifeq ($(BR2_PACKAGE_VALGRIND_MEMCHECK),)
> +define VALGRIND_REMOVE_MEMCHECK
> +	rm -f $(TARGET_DIR)/usr/lib/valgrind/*memcheck*
> +endef
> +
> +VALGRIND_POST_INSTALL_TARGET_HOOKS += VALGRIND_REMOVE_MEMCHECK
> +endif

 It's probably just personal preference, but I like to see:

define VALGRIND_REMOVE_MEMCHECK
	rm -f $(TARGET_DIR)/usr/lib/valgrind/*memcheck*
endef

VALGRIND_POST_INSTALL_TARGET_HOOKS += $(if $(BR2_PACKAGE_VALGRIND_MEMCHECK),,VALGRIND_REMOVE_MEMCHECK)

(although the double comma isn't making things very clear either...)


 It would actually be better to not build the unneeded tools at all, by 
setting
VALGRIND_MAKE_OPT = TOOLS="..." EXP_TOOLS="..."

 Unfortunately, Makefile.autotools.in doesn't use PKG_MAKE_OPT for the 
install targets (which is probably a bug...), so that won't work.

[snip]

 Regards,
 Arnout

-- 
Arnout Vandecappelle                               arnout at mind be
Senior Embedded Software Architect                 +32-16-286540
Essensium/Mind                                     http://www.mind.be
G.Geenslaan 9, 3001 Leuven, Belgium                BE 872 984 063 RPR Leuven
LinkedIn profile: http://www.linkedin.com/in/arnoutvandecappelle
GPG fingerprint:  7CB5 E4CC 6C2E EFD4 6E3D A754 F963 ECAB 2450 2F1F

^ permalink raw reply	[flat|nested] 4+ messages in thread

* [Buildroot] [PATCH] valgrind: allow selecting which tools to install
  2012-03-14 16:50 [Buildroot] [PATCH] valgrind: allow selecting which tools to install Thomas De Schampheleire
  2012-03-23 14:52 ` Thomas De Schampheleire
  2012-03-25 18:51 ` Arnout Vandecappelle
@ 2012-04-05 14:40 ` Peter Korsgaard
  2 siblings, 0 replies; 4+ messages in thread
From: Peter Korsgaard @ 2012-04-05 14:40 UTC (permalink / raw)
  To: buildroot

>>>>> "Thomas" == Thomas De Schampheleire <patrickdepinguin+buildroot@gmail.com> writes:

 Thomas> The full valgrind installation takes more than 20 MB, while one
 Thomas> typically does not use all of its tools. This patch adds extra
 Thomas> config options to select which tools to install.

Committed with Arnout's suggestion to not default the experimental tools
to 'y' - Thanks.

-- 
Bye, Peter Korsgaard

^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2012-04-05 14:40 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2012-03-14 16:50 [Buildroot] [PATCH] valgrind: allow selecting which tools to install Thomas De Schampheleire
2012-03-23 14:52 ` Thomas De Schampheleire
2012-03-25 18:51 ` Arnout Vandecappelle
2012-04-05 14:40 ` Peter Korsgaard

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox