Ok

i have found this article about valgrind and gtk :
http://live.gnome.org/Valgrind

"G_SLICE and G_DEBUG env vars make sure to turn off glib's memory
optimizations, so that they do not confuse valgrind."
when i use :

G_SLICE=always-malloc G_DEBUG=gc-friendly valgrind --tool=memcheck
--leak-check=full --leak-resolution=high --num-callers=20
--log-file=vgdump your-program
i get the same errors.
i comple and run the application in x86_64 platform. Gtkmm is compatible
with x86_64 ?

Thanks
Sylvain

2011/8/5 Krzesimir Nowak <[email protected]>

> 2011/8/4 sylvain mouquet <[email protected]>:
> > Hi,
> > I use this little example :
> > #include <gtkmm.h>
> > int main(int argc, char *argv[])
> > {
> >   Gtk::Main kit(argc, argv);
> >   Gtk::Window window;
> >   Gtk::Main::run(window);
> >   return EXIT_SUCCESS;
> > }
> > g++ sample.cpp -o simple `pkg-config gtkmm-3.0 --cflags --libs`
> > i get this error with valgrind :
> > sylvain2@sylvain-desktop:~/Bureau/dev/gtkmm3$ valgrind ./simple
> > ==25595== Memcheck, a memory error detector
> > ==25595== Copyright (C) 2002-2010, and GNU GPL'd, by Julian Seward et al.
> > ==25595== Using Valgrind-3.6.1 and LibVEX; rerun with -h for copyright
> info
> > ==25595== Command: ./simple
> > ==25595==
> > ==25595== Conditional jump or move depends on uninitialised value(s)
> > ==25595==    at 0x9AC30CB: __GI___strcasecmp_l (strcmp.S:243)
> > ==25595==    by 0x9A5CF60: __gconv_open (gconv_open.c:70)
> > ==25595==    by 0x9A6B106: _nl_find_msg (dcigettext.c:990)
> > ==25595==    by 0x9A6B818: __dcigettext (dcigettext.c:654)
> > ==25595==    by 0x5FCF98E: gtk_get_option_group (gtkmain.c:976)
> > ==25595==    by 0x5FCFBA1: gtk_parse_args (gtkmain.c:1088)
> > ==25595==    by 0x5FCFC18: gtk_init_check (gtkmain.c:1129)
> > ==25595==    by 0x5FCFC48: gtk_init (gtkmain.c:1184)
> > ==25595==    by 0x51269BB: Gtk::Main::init(int*, char***, bool)
> > (main.cc:304)
> > ==25595==    by 0x5126B55: Gtk::Main::Main(int&, char**&, bool)
> > (main.cc:257)
> > ==25595==    by 0x400B8C: main (in
> /home/sylvain2/Bureau/dev/gtkmm3/simple)
> > ==25595==
> > ==25595== Use of uninitialised value of size 8
> > ==25595==    at 0x9AC5204: __GI___strcasecmp_l (strcmp.S:2257)
> > ==25595==    by 0x9A5CF60: __gconv_open (gconv_open.c:70)
> > ==25595==    by 0x9A6B106: _nl_find_msg (dcigettext.c:990)
> > ==25595==    by 0x9A6B818: __dcigettext (dcigettext.c:654)
> > ==25595==    by 0x5FCF98E: gtk_get_option_group (gtkmain.c:976)
> > ==25595==    by 0x5FCFBA1: gtk_parse_args (gtkmain.c:1088)
> > ==25595==    by 0x5FCFC18: gtk_init_check (gtkmain.c:1129)
> > ==25595==    by 0x5FCFC48: gtk_init (gtkmain.c:1184)
> > ==25595==    by 0x51269BB: Gtk::Main::init(int*, char***, bool)
> > (main.cc:304)
> > ==25595==    by 0x5126B55: Gtk::Main::Main(int&, char**&, bool)
> > (main.cc:257)
> > ==25595==    by 0x400B8C: main (in
> /home/sylvain2/Bureau/dev/gtkmm3/simple)
> > ==25595==
> > ==25595== Use of uninitialised value of size 8
> > ==25595==    at 0x9AC5208: __GI___strcasecmp_l (strcmp.S:2258)
> > ==25595==    by 0x9A5CF60: __gconv_open (gconv_open.c:70)
> > ==25595==    by 0x9A6B106: _nl_find_msg (dcigettext.c:990)
> > ==25595==    by 0x9A6B818: __dcigettext (dcigettext.c:654)
> > ==25595==    by 0x5FCF98E: gtk_get_option_group (gtkmain.c:976)
> > ==25595==    by 0x5FCFBA1: gtk_parse_args (gtkmain.c:1088)
> > ==25595==    by 0x5FCFC18: gtk_init_check (gtkmain.c:1129)
> > ==25595==    by 0x5FCFC48: gtk_init (gtkmain.c:1184)
> > ==25595==    by 0x51269BB: Gtk::Main::init(int*, char***, bool)
> > (main.cc:304)
> > ==25595==    by 0x5126B55: Gtk::Main::Main(int&, char**&, bool)
> > (main.cc:257)
> > ==25595==    by 0x400B8C: main (in
> /home/sylvain2/Bureau/dev/gtkmm3/simple)
> > ==25595==
> > ==25595== Invalid read of size 8
> > ==25595==    at 0x9AC532F: __GI___strncasecmp_l (strcmp.S:213)
> > ==25595==    by 0x9A7BFAE: ____strtod_l_internal (strtod_l.c:577)
> > ==25595==    by 0x8DF14D0: g_ascii_strtod (in
> > /lib/x86_64-linux-gnu/libglib-2.0.so.0.2800.6)
> > ==25595==    by 0xF249D66: ??? (in /usr/lib/librsvg-2.so.2.32.1)
> > ==25595==    by 0xF261483: ??? (in /usr/lib/librsvg-2.so.2.32.1)
> > ==25595==    by 0xF262BD1: ??? (in /usr/lib/librsvg-2.so.2.32.1)
> > ==25595==    by 0xF2639B4: ??? (in /usr/lib/librsvg-2.so.2.32.1)
> > ==25595==    by 0xF266C3E: ??? (in /usr/lib/librsvg-2.so.2.32.1)
> > ==25595==    by 0xF2675EA: ??? (in /usr/lib/librsvg-2.so.2.32.1)
> > ==25595==    by 0xF6F1728: xmlParseStartTag (in
> /usr/lib/libxml2.so.2.7.8)
> > ==25595==    by 0xF6F9F1E: ??? (in /usr/lib/libxml2.so.2.7.8)
> > ==25595==    by 0xF6FACEF: xmlParseChunk (in /usr/lib/libxml2.so.2.7.8)
> > ==25595==  Address 0xd16e060 is 0 bytes inside a block of size 7 alloc'd
> > ==25595==    at 0x4C2901C: malloc (vg_replace_malloc.c:236)
> > ==25595==    by 0x8DD8A62: g_malloc (in
> > /lib/x86_64-linux-gnu/libglib-2.0.so.0.2800.6)
> > ==25595==    by 0x8DF106D: g_strdup (in
> > /lib/x86_64-linux-gnu/libglib-2.0.so.0.2800.6)
> > ==25595==    by 0xF262B9E: ??? (in /usr/lib/librsvg-2.so.2.32.1)
> > ==25595==    by 0xF2639B4: ??? (in /usr/lib/librsvg-2.so.2.32.1)
> > ==25595==    by 0xF266C3E: ??? (in /usr/lib/librsvg-2.so.2.32.1)
> > ==25595==    by 0xF2675EA: ??? (in /usr/lib/librsvg-2.so.2.32.1)
> > ==25595==    by 0xF6F1728: xmlParseStartTag (in
> /usr/lib/libxml2.so.2.7.8)
> > ==25595==    by 0xF6F9F1E: ??? (in /usr/lib/libxml2.so.2.7.8)
> > ==25595==    by 0xF6FACEF: xmlParseChunk (in /usr/lib/libxml2.so.2.7.8)
> > ==25595==    by 0xF26878E: rsvg_handle_write (in
> > /usr/lib/librsvg-2.so.2.32.1)
> > ==25595==    by 0xF03EC10: ??? (in
> > /usr/lib/gdk-pixbuf-2.0/2.10.0/loaders/libpixbufloader-svg.so)
> > ==25595==
> > ==25595== Invalid read of size 8
> > ==25595==    at 0x9AC5337: __GI___strncasecmp_l (strcmp.S:215)
> > ==25595==    by 0x9A7BFAE: ____strtod_l_internal (strtod_l.c:577)
> > ==25595==    by 0x8DF14D0: g_ascii_strtod (in
> > /lib/x86_64-linux-gnu/libglib-2.0.so.0.2800.6)
> > ==25595==    by 0xF249D66: ??? (in /usr/lib/librsvg-2.so.2.32.1)
> > ==25595==    by 0xF261483: ??? (in /usr/lib/librsvg-2.so.2.32.1)
> > ==25595==    by 0xF262BD1: ??? (in /usr/lib/librsvg-2.so.2.32.1)
> > ==25595==    by 0xF2639B4: ??? (in /usr/lib/librsvg-2.so.2.32.1)
> > ==25595==    by 0xF266C3E: ??? (in /usr/lib/librsvg-2.so.2.32.1)
> > ==25595==    by 0xF2675EA: ??? (in /usr/lib/librsvg-2.so.2.32.1)
> > ==25595==    by 0xF6F1728: xmlParseStartTag (in
> /usr/lib/libxml2.so.2.7.8)
> > ==25595==    by 0xF6F9F1E: ??? (in /usr/lib/libxml2.so.2.7.8)
> > ==25595==    by 0xF6FACEF: xmlParseChunk (in /usr/lib/libxml2.so.2.7.8)
> > ==25595==  Address 0xd16e068 is 1 bytes after a block of size 7 alloc'd
> > ==25595==    at 0x4C2901C: malloc (vg_replace_malloc.c:236)
> > ==25595==    by 0x8DD8A62: g_malloc (in
> > /lib/x86_64-linux-gnu/libglib-2.0.so.0.2800.6)
> > ==25595==    by 0x8DF106D: g_strdup (in
> > /lib/x86_64-linux-gnu/libglib-2.0.so.0.2800.6)
> > ==25595==    by 0xF262B9E: ??? (in /usr/lib/librsvg-2.so.2.32.1)
> > ==25595==    by 0xF2639B4: ??? (in /usr/lib/librsvg-2.so.2.32.1)
> > ==25595==    by 0xF266C3E: ??? (in /usr/lib/librsvg-2.so.2.32.1)
> > ==25595==    by 0xF2675EA: ??? (in /usr/lib/librsvg-2.so.2.32.1)
> > ==25595==    by 0xF6F1728: xmlParseStartTag (in
> /usr/lib/libxml2.so.2.7.8)
> > ==25595==    by 0xF6F9F1E: ??? (in /usr/lib/libxml2.so.2.7.8)
> > ==25595==    by 0xF6FACEF: xmlParseChunk (in /usr/lib/libxml2.so.2.7.8)
> > ==25595==    by 0xF26878E: rsvg_handle_write (in
> > /usr/lib/librsvg-2.so.2.32.1)
> > ==25595==    by 0xF03EC10: ??? (in
> > /usr/lib/gdk-pixbuf-2.0/2.10.0/loaders/libpixbufloader-svg.so)
> > ==25595==
> > What is the problem ?
> > Thanks,
> > Sylvain
> >
> > _______________________________________________
> > gtkmm-list mailing list
> > [email protected]
> > http://mail.gnome.org/mailman/listinfo/gtkmm-list
> >
> >
>
> Maybe try running your application with G_SLICE environment variable
> set to always-malloc. In general, this doesn't have anything to do
> with gtkmm - more like with GTK+, which gtkmm is wrapping.
>



-- 
Cordialement,
Sylvain
_______________________________________________
gtkmm-list mailing list
[email protected]
http://mail.gnome.org/mailman/listinfo/gtkmm-list

Reply via email to