2010-02-22 17:01:34 -07:00
*#*#
*.#*#
2008-10-28 17:47:12 +00:00
*.a
2010-04-28 21:36:03 -06:00
*.exe
2010-06-09 12:35:49 -06:00
*.gcda
*.gcno
*.gcov
Prevent crash from dlclose() of libvirt.so
When libvirt calls virInitialize it creates a thread local
for the virErrorPtr storage, and registers a callback to
cleanup memory when a thread exits. When libvirt is dlclose()d
or otherwise made non-resident, the callback function is
removed from memory, but the thread local may still exist
and if a thread later exists, it will invoke the callback
and SEGV. There may also be other thread locals with callbacks
pointing to libvirt code, so it is in general never safe to
unload libvirt.so from memory once initialized.
To allow dlclose() to succeed, but keep libvirt.so resident
in memory, link with '-z nodelete'. This issue was first
found with the libvirt CIM provider, but can potentially
hit many of the dynamic language bindings which all ultimately
involve dlopen() in some way, either on libvirt.so itself,
or on the glue code for the binding which in turns links
to libvirt
* configure.ac, src/Makefile.am: Ensure libvirt.so is linked
with -z nodelete
* cfg.mk, .gitignore, tests/Makefile.am, tests/shunloadhelper.c,
tests/shunloadtest.c: A test case to unload libvirt while
a thread is still running.
2011-09-01 17:57:06 +01:00
*.la
*.lo
2008-10-28 17:47:12 +00:00
*.o
2010-02-22 17:01:34 -07:00
*.orig
*.rej
2008-10-28 17:47:12 +00:00
*~
2008-10-17 10:03:15 +00:00
.git
2009-07-10 10:01:04 +02:00
.git-module-status
2011-03-17 10:35:17 +08:00
.lvimrc
2010-04-21 09:55:03 -06:00
.sc-start-sc_*
2010-11-16 12:29:09 -07:00
/ABOUT-NLS
/COPYING
/ChangeLog
2010-02-22 17:01:34 -07:00
/GNUmakefile
2010-11-16 12:29:09 -07:00
/INSTALL
/NEWS
/aclocal.m4
/autom4te.cache
2011-01-04 03:37:17 +01:00
/build-aux
2010-11-16 12:29:09 -07:00
/build-aux/
2010-04-30 08:52:54 -06:00
/build/
2010-11-16 12:29:09 -07:00
/config.cache
/config.guess
/config.h
/config.h.in
/config.log
/config.rpath
/config.status
/config.sub
/configure
/configure.lineno
2011-05-16 18:13:11 +01:00
/daemon/*_dispatch.h
2011-05-16 09:33:56 -06:00
/docs/hvsupport.html.in
2011-09-14 09:30:33 -06:00
/docs/libvirt-qemu-*.xml
2011-07-28 14:55:21 +02:00
/gnulib/lib/*
/gnulib/m4/*
/gnulib/tests/*
2010-11-16 12:29:09 -07:00
/libtool
/libvirt-*.tar.gz
2010-05-19 16:16:47 -06:00
/libvirt-[0-9]*
2010-11-16 12:29:09 -07:00
/libvirt.pc
/libvirt.spec
/ltconfig
/ltmain.sh
2011-04-05 13:06:31 -06:00
/m4/*
2010-02-22 17:01:34 -07:00
/maint.mk
2010-11-16 12:29:09 -07:00
/mingw32-libvirt.spec
/mkinstalldirs
2011-04-05 13:06:31 -06:00
/po/*
2010-11-09 11:45:14 +01:00
/proxy/
2011-07-19 07:34:34 -06:00
/python/generator.py.stamp
2011-09-14 09:30:33 -06:00
/python/libvirt-qemu-export.c
/python/libvirt-qemu.[ch]
/python/libvirt_qemu.py
2011-08-18 17:03:26 -06:00
/sc_*
2011-07-13 17:05:19 +02:00
/src/hyperv/*.generated.*
2011-03-29 07:05:12 -06:00
/src/libvirt_iohelper
2011-08-15 14:42:43 -06:00
/src/locking/qemu-sanlock.conf
2011-05-06 14:11:32 +01:00
/src/remote/*_client_bodies.h
/src/remote/*_protocol.[ch]
2010-12-06 17:03:10 +00:00
/src/rpc/virnetprotocol.[ch]
2011-07-21 15:32:34 +08:00
/src/util/virkeymaps.h
2010-11-16 12:29:09 -07:00
/tests/*.log
2010-12-01 16:48:19 -07:00
/tests/cputest
2011-09-22 14:29:00 -06:00
/tests/domainsnapshotxml2xmltest
2011-04-18 09:30:49 -06:00
/tests/hashtest
2011-06-30 12:13:51 -06:00
/tests/jsontest
2011-06-24 15:30:00 -06:00
/tests/networkxml2argvtest
2010-11-16 12:29:09 -07:00
/tests/nwfilterxml2xmltest
2011-05-31 11:35:32 -06:00
/tests/openvzutilstest
2011-10-19 13:49:59 -06:00
/tests/qemuxmlnstest
Prevent crash from dlclose() of libvirt.so
When libvirt calls virInitialize it creates a thread local
for the virErrorPtr storage, and registers a callback to
cleanup memory when a thread exits. When libvirt is dlclose()d
or otherwise made non-resident, the callback function is
removed from memory, but the thread local may still exist
and if a thread later exists, it will invoke the callback
and SEGV. There may also be other thread locals with callbacks
pointing to libvirt code, so it is in general never safe to
unload libvirt.so from memory once initialized.
To allow dlclose() to succeed, but keep libvirt.so resident
in memory, link with '-z nodelete'. This issue was first
found with the libvirt CIM provider, but can potentially
hit many of the dynamic language bindings which all ultimately
involve dlopen() in some way, either on libvirt.so itself,
or on the glue code for the binding which in turns links
to libvirt
* configure.ac, src/Makefile.am: Ensure libvirt.so is linked
with -z nodelete
* cfg.mk, .gitignore, tests/Makefile.am, tests/shunloadhelper.c,
tests/shunloadtest.c: A test case to unload libvirt while
a thread is still running.
2011-09-01 17:57:06 +01:00
/tests/shunloadtest
2010-11-16 12:29:09 -07:00
/update.log
2008-10-17 10:03:15 +00:00
Makefile
2008-10-28 17:47:12 +00:00
Makefile.in
2010-12-01 16:48:19 -07:00
TAGS
2008-10-28 17:47:12 +00:00
coverage
2009-07-03 14:32:17 +00:00
cscope.files
cscope.out
2008-10-28 17:47:12 +00:00
results.log
stamp-h
stamp-h.in
stamp-h1
2011-07-28 14:55:21 +02:00
!/gnulib/lib/Makefile.am
!/gnulib/tests/Makefile.am
2011-04-05 13:06:31 -06:00
!/m4/virt-*.m4
!/po/*.po
!/po/POTFILES.in
!/po/libvirt.pot