* [Qemu-devel] [PATCH v2] Support running QEMU on Valgrind
@ 2011-10-31 20:29 Stefan Weil
2011-11-01 16:21 ` Anthony Liguori
0 siblings, 1 reply; 2+ messages in thread
From: Stefan Weil @ 2011-10-31 20:29 UTC (permalink / raw)
To: qemu-devel; +Cc: Stefan Weil, Anthony Liguori, Avi Kivity
Valgrind is a tool which can automatically detect many kinds of bugs.
Running QEMU on Valgrind with x86_64 hosts was not possible because
Valgrind aborts when memalign is called with an alignment larger than
1 MiB. QEMU normally uses 2 MiB on Linux x86_64.
Now the alignment is reduced to the page size when QEMU is running on
Valgrind.
v2:
Instead of using the macro RUNNING_ON_VALGRIND from valgrind.h,
the patch now uses a hack from libvirt which tests for the pre-loaded
vgpreload_*.so shared libraries. This avoids the need for valgrind.h.
Signed-off-by: Stefan Weil <sw@weilnetz.de>
---
oslib-posix.c | 22 +++++++++++++++++++---
1 files changed, 19 insertions(+), 3 deletions(-)
diff --git a/oslib-posix.c b/oslib-posix.c
index dbc8ee8..6f29762 100644
--- a/oslib-posix.c
+++ b/oslib-posix.c
@@ -36,8 +36,11 @@ extern int daemon(int, int);
#endif
#if defined(__linux__) && defined(__x86_64__)
- /* Use 2MB alignment so transparent hugepages can be used by KVM */
+ /* Use 2 MiB alignment so transparent hugepages can be used by KVM.
+ Valgrind does not support alignments larger than 1 MiB,
+ therefore we need special code which handles running on Valgrind. */
# define QEMU_VMALLOC_ALIGN (512 * 4096)
+# define CONFIG_VALGRIND
#else
# define QEMU_VMALLOC_ALIGN getpagesize()
#endif
@@ -47,7 +50,11 @@ extern int daemon(int, int);
#include "trace.h"
#include "qemu_socket.h"
-
+#if defined(CONFIG_VALGRIND)
+static int running_on_valgrind = -1;
+#else
+# define running_on_valgrind 0
+#endif
int qemu_daemon(int nochdir, int noclose)
{
@@ -89,7 +96,16 @@ void *qemu_vmalloc(size_t size)
void *ptr;
size_t align = QEMU_VMALLOC_ALIGN;
- if (size < align) {
+#if defined(CONFIG_VALGRIND)
+ if (running_on_valgrind < 0) {
+ /* First call, test whether we are running on Valgrind.
+ This is a substitute for RUNNING_ON_VALGRIND from valgrind.h. */
+ const char *ld = getenv("LD_PRELOAD");
+ running_on_valgrind = (ld != NULL && strstr(ld, "vgpreload"));
+ }
+#endif
+
+ if (size < align || running_on_valgrind) {
align = getpagesize();
}
ptr = qemu_memalign(align, size);
--
1.7.2.5
^ permalink raw reply related [flat|nested] 2+ messages in thread
* Re: [Qemu-devel] [PATCH v2] Support running QEMU on Valgrind
2011-10-31 20:29 [Qemu-devel] [PATCH v2] Support running QEMU on Valgrind Stefan Weil
@ 2011-11-01 16:21 ` Anthony Liguori
0 siblings, 0 replies; 2+ messages in thread
From: Anthony Liguori @ 2011-11-01 16:21 UTC (permalink / raw)
To: Stefan Weil; +Cc: qemu-devel, Avi Kivity
On 10/31/2011 03:29 PM, Stefan Weil wrote:
> Valgrind is a tool which can automatically detect many kinds of bugs.
>
> Running QEMU on Valgrind with x86_64 hosts was not possible because
> Valgrind aborts when memalign is called with an alignment larger than
> 1 MiB. QEMU normally uses 2 MiB on Linux x86_64.
>
> Now the alignment is reduced to the page size when QEMU is running on
> Valgrind.
>
> v2:
> Instead of using the macro RUNNING_ON_VALGRIND from valgrind.h,
> the patch now uses a hack from libvirt which tests for the pre-loaded
> vgpreload_*.so shared libraries. This avoids the need for valgrind.h.
>
> Signed-off-by: Stefan Weil<sw@weilnetz.de>
Applied. Thanks.
Regards,
Anthony Liguori
> ---
> oslib-posix.c | 22 +++++++++++++++++++---
> 1 files changed, 19 insertions(+), 3 deletions(-)
>
> diff --git a/oslib-posix.c b/oslib-posix.c
> index dbc8ee8..6f29762 100644
> --- a/oslib-posix.c
> +++ b/oslib-posix.c
> @@ -36,8 +36,11 @@ extern int daemon(int, int);
> #endif
>
> #if defined(__linux__)&& defined(__x86_64__)
> - /* Use 2MB alignment so transparent hugepages can be used by KVM */
> + /* Use 2 MiB alignment so transparent hugepages can be used by KVM.
> + Valgrind does not support alignments larger than 1 MiB,
> + therefore we need special code which handles running on Valgrind. */
> # define QEMU_VMALLOC_ALIGN (512 * 4096)
> +# define CONFIG_VALGRIND
> #else
> # define QEMU_VMALLOC_ALIGN getpagesize()
> #endif
> @@ -47,7 +50,11 @@ extern int daemon(int, int);
> #include "trace.h"
> #include "qemu_socket.h"
>
> -
> +#if defined(CONFIG_VALGRIND)
> +static int running_on_valgrind = -1;
> +#else
> +# define running_on_valgrind 0
> +#endif
>
> int qemu_daemon(int nochdir, int noclose)
> {
> @@ -89,7 +96,16 @@ void *qemu_vmalloc(size_t size)
> void *ptr;
> size_t align = QEMU_VMALLOC_ALIGN;
>
> - if (size< align) {
> +#if defined(CONFIG_VALGRIND)
> + if (running_on_valgrind< 0) {
> + /* First call, test whether we are running on Valgrind.
> + This is a substitute for RUNNING_ON_VALGRIND from valgrind.h. */
> + const char *ld = getenv("LD_PRELOAD");
> + running_on_valgrind = (ld != NULL&& strstr(ld, "vgpreload"));
> + }
> +#endif
> +
> + if (size< align || running_on_valgrind) {
> align = getpagesize();
> }
> ptr = qemu_memalign(align, size);
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2011-11-01 16:29 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2011-10-31 20:29 [Qemu-devel] [PATCH v2] Support running QEMU on Valgrind Stefan Weil
2011-11-01 16:21 ` Anthony Liguori
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).