diff options
| author | Anthony Liguori <aliguori@us.ibm.com> | 2010-03-17 17:44:48 -0500 |
|---|---|---|
| committer | Anthony Liguori <aliguori@us.ibm.com> | 2010-03-19 15:27:38 -0500 |
| commit | 3b6304f706ef7eebc0b3b3f3a5093ec75448ee19 (patch) | |
| tree | 963d3fe64dab594aacd2b89c1cb92315d836fc3f | |
| parent | 3af12c86d9db42c826dc9a7577b657543baf7fab (diff) | |
| download | focaccia-qemu-3b6304f706ef7eebc0b3b3f3a5093ec75448ee19.tar.gz focaccia-qemu-3b6304f706ef7eebc0b3b3f3a5093ec75448ee19.zip | |
Add exit notifiers
Like atexit() but with state Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
| -rw-r--r-- | sysemu.h | 5 | ||||
| -rw-r--r-- | vl.c | 27 |
2 files changed, 32 insertions, 0 deletions
diff --git a/sysemu.h b/sysemu.h index 525efd13cb..bc33abfc9b 100644 --- a/sysemu.h +++ b/sysemu.h @@ -8,6 +8,7 @@ #include "qemu-timer.h" #include "qdict.h" #include "qerror.h" +#include "notify.h" #ifdef _WIN32 #include <windows.h> @@ -73,6 +74,10 @@ int qemu_savevm_state_complete(Monitor *mon, QEMUFile *f); void qemu_savevm_state_cancel(Monitor *mon, QEMUFile *f); int qemu_loadvm_state(QEMUFile *f); +void exit_notifier_add(Notifier *notifier); +void exit_notifier_remove(Notifier *notifier); + + #ifdef _WIN32 /* Polling handling */ diff --git a/vl.c b/vl.c index d69250ca26..183ec32a96 100644 --- a/vl.c +++ b/vl.c @@ -150,6 +150,7 @@ int main(int argc, char **argv) #include "qemu-option.h" #include "qemu-config.h" #include "qemu-objects.h" +#include "notify.h" #include "disas.h" @@ -553,6 +554,32 @@ static int socket_init(void) } #endif +/*********************/ +/* Exit notifiers */ +/*********************/ + +static NotifierList exit_notifiers = NOTIFIER_LIST_INITIALIZER(exit_notifiers); + +void exit_notifier_add(Notifier *notifier) +{ + notifier_list_add(&exit_notifiers, notifier); +} + +void exit_notifier_remove(Notifier *notifier) +{ + notifier_list_remove(&exit_notifiers, notifier); +} + +static void exit_notifier_notify(void) +{ + notifier_list_notify(&exit_notifiers); +} + +static void exit_notifier_init(void) +{ + atexit(exit_notifier_notify); +} + /***********************************************************/ /* Bluetooth support */ static int nb_hcis; |