Code

ipmi: use SIGIO instead of SIGUSR2 to avoid conflict with JVM
authorVincent Bernat <vincent@bernat.im>
Fri, 23 Jan 2015 17:55:04 +0000 (18:55 +0100)
committerVincent Bernat <vincent@bernat.im>
Fri, 23 Jan 2015 17:57:05 +0000 (18:57 +0100)
Java uses SIGUSR2 to suspend/resume threads. The OpenIPMI plugins also
need a signal to resume its event loop when setting a timer. They can't
both use the same signal. We ask OpenIPMI to use SIGIO instead.

This should fix #114.

src/ipmi.c

index 47ceacaefeb96d7faa50a44eaa9cd3f8c7eaee45..51d33dcb79635733d395fec6338c3ec4a7fe0036 100644 (file)
@@ -557,7 +557,7 @@ static int thread_init (os_handler_t **ret_os_handler)
   ipmi_domain_id_t domain_id;
   int status;
 
-  os_handler = ipmi_posix_thread_setup_os_handler (SIGUSR2);
+  os_handler = ipmi_posix_thread_setup_os_handler (SIGIO);
   if (os_handler == NULL)
   {
     ERROR ("ipmi plugin: ipmi_posix_thread_setup_os_handler failed.");