[Bug 993193] Re: Error with Valgrind on variadic functions
Launchpad Bug Tracker
993193 at bugs.launchpad.net
Sun Jul 22 20:17:05 UTC 2012
Status changed to 'Confirmed' because the bug affects multiple users.
** Changed in: gcc-defaults (Ubuntu)
Status: New => Confirmed
--
You received this bug notification because you are a member of Ubuntu
Foundations Bugs, which is subscribed to gcc-defaults in Ubuntu.
https://bugs.launchpad.net/bugs/993193
Title:
Error with Valgrind on variadic functions
Status in “gcc-defaults” package in Ubuntu:
Confirmed
Bug description:
I'm using Ubuntu 12.10 dev with gcc 4:4.7.0-5ubuntu1 and valgrind
1:3.7.0-0ubuntu3. Here is the code example:
#include <stdarg.h>
#include <stdio.h>
void test(char *var1, char *var2, char *var3, char *var4, char *var5, char *var6, int argc, ...)
{
va_list list;
va_start(list, argc);
if(va_arg(list, long int) == 1)
printf("Test\n");
va_end(list);
}
int main()
{
test(NULL, NULL, NULL, NULL, NULL, NULL, 1, 1);
return 0;
}
I have compiled it with "gcc -O3 -Wall -Wextra -o test -pedantic test.c" and tested with "valgrind ./test". The output is:
==11060== Memcheck, a memory error detector
==11060== Copyright (C) 2002-2011, and GNU GPL'd, by Julian Seward et al.
==11060== Using Valgrind-3.7.0 and LibVEX; rerun with -h for copyright info
==11060== Command: ./test
==11060==
==11060== Conditional jump or move depends on uninitialised value(s)
==11060== at 0x400575: test (in /home/sworddragon/data/test)
==11060== by 0x400437: main (in /home/sworddragon/data/test)
==11060==
Test
==11060==
==11060== HEAP SUMMARY:
==11060== in use at exit: 0 bytes in 0 blocks
==11060== total heap usage: 0 allocs, 0 frees, 0 bytes allocated
==11060==
==11060== All heap blocks were freed -- no leaks are possible
==11060==
==11060== For counts of detected and suppressed errors, rerun with: -v
==11060== Use --track-origins=yes to see where uninitialised values come from
==11060== ERROR SUMMARY: 1 errors from 1 contexts (suppressed: 2 from 2)
Interestingly with 5 instead of 6 char * arguments before I'm getting the same error but without the output "Test". WIth less than 5 char * arguments before all is working fine.
To manage notifications about this bug go to:
https://bugs.launchpad.net/ubuntu/+source/gcc-defaults/+bug/993193/+subscriptions
More information about the foundations-bugs
mailing list