Утечка объекта GDI при перефокусировке в cairo или gtk в windows?

У меня есть программа (gummi), которая использует cairo, poppler и gtk+. Каждый раз, когда я переключаю фокус с помощью alt-tab (но не так часто, когда я переключаю фокус с помощью других средств), диспетчер задач сообщает мне, что он получает 10-20 объектов GDI. GDIView сообщает мне, что это в основном растровые изображения и контроллеры домена, хотя на них приходится только большая часть «общего значения GDI»; "All GDI" в 3-4 раза больше, чем "GDI Total".

Как мне выяснить, является ли это ошибкой в ​​гамми (я думаю, что это маловероятно, поскольку я не думаю, что гуми ничего не делает при перефокусировке/перерисовке), каиро, попплере или gtk? Как мне найти, где находится ошибка, чтобы я мог отправить отчет об ошибке? (В качестве альтернативы, если это известная ошибка с gtk/cairo/poppler, может ли кто-нибудь указать мне на отчет об ошибке?)

Как уже упоминалось в других потоках ( Win32Exception: операция завершена успешно ), Windows ограничивает процесс до 10 000 дескрипторов. , и у меня был segfault гамми, предположительно из-за достижения этого предела. След gdb от такого события скопирован ниже.

(gummi.exe:14008): Gdk-WARNING **: gdkgc-win32.c:830: SaveDC failed: The operation completed successfully.

(gummi.exe:14008): Gdk-WARNING **: gdkgc-win32.c:970: RestoreDC failed: The operation completed successfully.
pnc=: T
Program received signal SIGSEGV, Segmentation fault.
0x68de05bd in cairo_image_surface_get_data ()
   from d:\opt\gtk\bin\libcairo-2.dll
(gdb) bt
#0  0x68de05bd in cairo_image_surface_get_data ()
   from d:\opt\gtk\bin\libcairo-2.dll
#1  0x6c38d268 in _gdk_pixmap_new ()
   from d:\opt\gtk\bin\libgdk-win32-2.0-0.dll
#2  0x62d453a5 in draw_extension ()
   from d:\opt\gtk\lib\gtk-2.0\2.10.0\engines\libwimp.dll
#3  0x0155fdb6 in gtk_notebook_draw_tab ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#4  0x015601d7 in gtk_notebook_expose ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#5  0x0153b916 in _gtk_marshal_BOOLEAN__BOXED ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#6  0x63a451f9 in g_closure_invoke ()
   from d:\opt\gtk\bin\libgobject-2.0-0.dll
#7  0x63a54512 in signal_emit_unlocked_R ()
   from d:\opt\gtk\bin\libgobject-2.0-0.dll
#8  0x63a5b614 in g_signal_emit_valist ()
   from d:\opt\gtk\bin\libgobject-2.0-0.dll
#9  0x63a5b962 in g_signal_emit ()
   from d:\opt\gtk\bin\libgobject-2.0-0.dll
#10 0x0165b557 in gtk_widget_event_internal ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#11 0x014b6b0d in gtk_container_propagate_expose ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#12 0x014b6b48 in gtk_container_expose_child ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#13 0x0147c026 in gtk_box_forall ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#14 0x014b5436 in gtk_container_forall ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#15 0x014b5611 in gtk_container_expose ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#16 0x0153b916 in _gtk_marshal_BOOLEAN__BOXED ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#17 0x63a451f9 in g_closure_invoke ()
   from d:\opt\gtk\bin\libgobject-2.0-0.dll
#18 0x63a54512 in signal_emit_unlocked_R ()
   from d:\opt\gtk\bin\libgobject-2.0-0.dll
#19 0x63a5b614 in g_signal_emit_valist ()
   from d:\opt\gtk\bin\libgobject-2.0-0.dll
#20 0x63a5b962 in g_signal_emit ()
   from d:\opt\gtk\bin\libgobject-2.0-0.dll
#21 0x0165b557 in gtk_widget_event_internal ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#22 0x014b6b0d in gtk_container_propagate_expose ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#23 0x014b6b48 in gtk_container_expose_child ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#24 0x0156a555 in gtk_paned_forall ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#25 0x014b5436 in gtk_container_forall ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#26 0x014b5611 in gtk_container_expose ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#27 0x0156a894 in gtk_paned_expose ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#28 0x0153b916 in _gtk_marshal_BOOLEAN__BOXED ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#29 0x63a451f9 in g_closure_invoke ()
   from d:\opt\gtk\bin\libgobject-2.0-0.dll
#30 0x63a54512 in signal_emit_unlocked_R ()
   from d:\opt\gtk\bin\libgobject-2.0-0.dll
#31 0x63a5b614 in g_signal_emit_valist ()
   from d:\opt\gtk\bin\libgobject-2.0-0.dll
#32 0x63a5b962 in g_signal_emit ()
   from d:\opt\gtk\bin\libgobject-2.0-0.dll
#33 0x0165b557 in gtk_widget_event_internal ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#34 0x014b6b0d in gtk_container_propagate_expose ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#35 0x014b6b48 in gtk_container_expose_child ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#36 0x0147c026 in gtk_box_forall ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#37 0x014b5436 in gtk_container_forall ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#38 0x014b5611 in gtk_container_expose ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#39 0x0153b916 in _gtk_marshal_BOOLEAN__BOXED ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#40 0x63a451f9 in g_closure_invoke ()
   from d:\opt\gtk\bin\libgobject-2.0-0.dll
#41 0x63a54512 in signal_emit_unlocked_R ()
   from d:\opt\gtk\bin\libgobject-2.0-0.dll
#42 0x63a5b614 in g_signal_emit_valist ()
   from d:\opt\gtk\bin\libgobject-2.0-0.dll
#43 0x63a5b962 in g_signal_emit ()
   from d:\opt\gtk\bin\libgobject-2.0-0.dll
#44 0x0165b557 in gtk_widget_event_internal ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#45 0x014b6b0d in gtk_container_propagate_expose ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#46 0x014b6b48 in gtk_container_expose_child ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#47 0x014b5436 in gtk_container_forall ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#48 0x014b5611 in gtk_container_expose ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#49 0x0153b916 in _gtk_marshal_BOOLEAN__BOXED ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#50 0x63a452c2 in g_closure_invoke ()
   from d:\opt\gtk\bin\libgobject-2.0-0.dll
#51 0x63a54512 in signal_emit_unlocked_R ()
   from d:\opt\gtk\bin\libgobject-2.0-0.dll
#52 0x63a5b614 in g_signal_emit_valist ()
   from d:\opt\gtk\bin\libgobject-2.0-0.dll
#53 0x63a5b962 in g_signal_emit ()
   from d:\opt\gtk\bin\libgobject-2.0-0.dll
#54 0x0165b557 in gtk_widget_event_internal ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#55 0x0153a22f in gtk_main_do_event ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#56 0x6c3641dd in _gdk_window_process_updates_recurse ()
   from d:\opt\gtk\bin\libgdk-win32-2.0-0.dll
#57 0x6c35f6b6 in gdk_window_process_updates_internal ()
   from d:\opt\gtk\bin\libgdk-win32-2.0-0.dll
#58 0x6c361497 in gdk_window_process_all_updates ()
   from d:\opt\gtk\bin\libgdk-win32-2.0-0.dll
#59 0x6c361507 in gdk_window_update_idle ()
   from d:\opt\gtk\bin\libgdk-win32-2.0-0.dll
#60 0x6c34137c in gdk_threads_dispatch ()
   from d:\opt\gtk\bin\libgdk-win32-2.0-0.dll
#61 0x685eb167 in g_main_context_dispatch ()
   from d:\opt\gtk\bin\libglib-2.0-0.dll
#62 0x685eb90d in g_main_context_iterate.clone.5 ()
   from d:\opt\gtk\bin\libglib-2.0-0.dll
#63 0x685ebd9d in g_main_loop_run ()
   from d:\opt\gtk\bin\libglib-2.0-0.dll
#64 0x01539038 in gtk_main ()
   from d:\opt\gtk\bin\libgtk-win32-2.0-0.dll
#65 0x0040950e in gui_main (builder=0x33f5090) at gui/gui-main.c:281
#66 0x00428378 in main (argc=1, argv=0x3f56c8) at main.c:157
(gdb)

Я использую cairo и gtk+ из gtk+-bundle_2.24.10-20120208_win32 из 32-разрядной загрузки по адресу http://www.gtk.org/download/win32.php, http://ftp.gnome.org/pub/gnome/binaries/win32/gtk+/2.24/gtk+-bundle_2.24.10-20120208_win32.zip. В этом проекте также используются gtksourceview-2.10.0, libpng-1.5.10, openjpeg-1.5.0, poppler-0.18.4 и некоторые другие библиотеки, ~ все собранные из исходников под MinGW, которые, я думаю, не имеют отношения к графика.


person Jason Gross    schedule 27.04.2012    source источник


Ответы (1)


Такая проблема не могла остаться незамеченной командой GTK, скорее всего, это ошибка жевательной резинки. Проверьте обработчик сигнала expose-event для этой программы и убедитесь, что он не выделяет данные, не освобождая их.

Утечки GDI действительно сложны (с этим были проблемы в MFC, и проблема была в приложении).

ОБНОВЛЕНИЕ: кажется, я ошибался, это ошибка GTK 671538. Вы также можете найти некоторые советы в этой теме .

person liberforce    schedule 27.04.2012
comment
Я работаю в Windows 7, и в отчете об ошибке указано, что эта ошибка не возникает в Windows 7, но я проверю тестовые программы gtk, когда у меня будет возможность, сегодня позже. - person Jason Gross; 27.04.2012
comment
Я не уверен, что это та же самая ошибка; gtk-demo пропускает объекты GDI при перефокусировке с помощью alt-tab, но только до 320 или около того (как только счетчик достигает 320, кажется, что их утечка прекращается). - person Jason Gross; 28.04.2012