/
abnormalexitwrapper.c
92 lines (72 loc) · 2.18 KB
/
abnormalexitwrapper.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
/**
@file abnormalexitwrapper.c
A simple test driver and test cases for DSME
<p>
Copyright (C) 2011 Nokia Corporation
@author Jyrki Hämäläinen <ext-jyrki.pe.hamalainen@nokia.com>
This file is part of Dsme.
Dsme is free software; you can redistribute it and/or modify
it under the terms of the GNU Lesser General Public License
version 2.1 as published by the Free Software Foundation.
Dsme is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with Dsme. If not, see <http://www.gnu.org/licenses/>.
*/
#include <unistd.h>
#include <dlfcn.h>
#include <stdio.h>
#include <stdlib.h>
#include <signal.h>
#include <dbus/dbus.h>
#include <string.h>
int failfork = 0;
void __attribute__ ((constructor)) my_init(void);
void usr2_handler(int signum);
void usr2_handler(int signum)
{
if (signum == SIGUSR2) {
fprintf(stderr, "\nUSR2 received\n");
failfork = 1;
}
}
void __attribute__ ((constructor)) my_init(void)
{
fprintf(stderr, "\nInitializing fork wrapper\n");
signal(SIGUSR2, usr2_handler);
}
pid_t fork(void)
{
pid_t return_code = -1;
fprintf(stderr, "\n!!!Wrapped fork!!!\n");
if (failfork) {
return_code = -1;
} else {
pid_t (*realfork)(void) = dlsym(RTLD_NEXT, "fork");
if (dlerror()) {
return_code = -1;
} else {
return_code = realfork();
}
}
return return_code;
}
DBusConnection* dbus_connection_open_private(
const char *address,
DBusError *error)
{
DBusConnection* conn = NULL;
if (failfork && (strcmp(address, "unix:abstract=/com/ubuntu/upstart") == 0)) {
conn = NULL;
} else {
DBusConnection* (*realopen)(const char*, DBusError*) = dlsym(RTLD_NEXT, "dbus_connection_open_private");
if (dlerror()) {
conn = NULL;
} else {
conn = realopen(address, error);
}
}
return conn;
}