|
|
|
@ -22,12 +22,28 @@ |
|
|
|
|
|
|
|
|
|
|
|
#define die(x...) do { fprintf(stderr, x); exit(-1); } while(0) |
|
|
|
#define dlresolve(m,n) do { \ |
|
|
|
n = dlsym(m, "mod_" #n); \ |
|
|
|
if (!n) \ |
|
|
|
die("Failed to resolve symbol from plugin: %s\n", #n); \ |
|
|
|
} while(0) |
|
|
|
|
|
|
|
#define dlresolve(n) do { \ |
|
|
|
n = dlsym(dlh, "mod_" #n); \ |
|
|
|
if (!n) \ |
|
|
|
die("Failed to resolve symbol from plugin: %s\n", "mod_" #n); \ |
|
|
|
} while(0) |
|
|
|
#define check_struct_size(x) do { \ |
|
|
|
unsigned long *uip; \ |
|
|
|
uip = dlsym(dlh, "__size_struct_" #x); \ |
|
|
|
if (!uip) \ |
|
|
|
die("Failed to resolve symbol from plugin: %s\n", "__size_struct_" #x); \ |
|
|
|
if (*uip != sizeof(struct x)) \ |
|
|
|
die("Struct size mismatch in plugin: %s\n", #x); \ |
|
|
|
} while(0) |
|
|
|
#define check_struct_offset(x,y) do { \ |
|
|
|
unsigned long *uip; \ |
|
|
|
uip = dlsym(dlh, "__offset_struct_" #x "_" #y); \ |
|
|
|
if (!uip) \ |
|
|
|
die("Failed to resolve symbol from plugin: %s\n", \ |
|
|
|
"__offset_struct_" #x "_" #y); \ |
|
|
|
if (*uip != (unsigned long) &(((struct x *) 0)->y)) \ |
|
|
|
die("Struct offset mismatch in plugin: %s->%s\n", #x, #y); \ |
|
|
|
} while(0) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -306,6 +322,41 @@ static void init_everything() { |
|
|
|
resources(); |
|
|
|
} |
|
|
|
|
|
|
|
void redis_mod_verify(void *dlh) { |
|
|
|
dlresolve(redis_new); |
|
|
|
dlresolve(redis_restore); |
|
|
|
dlresolve(redis_update); |
|
|
|
dlresolve(redis_delete); |
|
|
|
dlresolve(redis_wipe); |
|
|
|
|
|
|
|
check_struct_size(call); |
|
|
|
check_struct_size(callstream); |
|
|
|
|
|
|
|
check_struct_offset(call, callmaster); |
|
|
|
check_struct_offset(call, chunk); |
|
|
|
check_struct_offset(call, callstreams); |
|
|
|
check_struct_offset(call, branches); |
|
|
|
check_struct_offset(call, callid); |
|
|
|
check_struct_offset(call, calling_agent); |
|
|
|
check_struct_offset(call, called_agent); |
|
|
|
|
|
|
|
check_struct_offset(callstream, peers); |
|
|
|
check_struct_offset(callstream, call); |
|
|
|
|
|
|
|
check_struct_offset(peer, rtps); |
|
|
|
check_struct_offset(peer, tag); |
|
|
|
check_struct_offset(peer, mediatype); |
|
|
|
check_struct_offset(peer, up); |
|
|
|
|
|
|
|
check_struct_offset(streamrelay, fd); |
|
|
|
check_struct_offset(streamrelay, peer); |
|
|
|
check_struct_offset(streamrelay, up); |
|
|
|
check_struct_offset(streamrelay, last); |
|
|
|
|
|
|
|
check_struct_offset(stream, ip46); |
|
|
|
check_struct_offset(stream, mediatype); |
|
|
|
check_struct_offset(stream, num); |
|
|
|
} |
|
|
|
|
|
|
|
void create_everything(struct main_context *ctx) { |
|
|
|
struct callmaster_config mc; |
|
|
|
@ -378,13 +429,7 @@ void create_everything(struct main_context *ctx) { |
|
|
|
strp = dlsym(dlh, "__module_version"); |
|
|
|
if (!strp || !*strp || strcmp(*strp, "redis/1.0.1")) |
|
|
|
die("Incorrect redis module version: %s\n", *strp); |
|
|
|
|
|
|
|
dlresolve(dlh, redis_new); |
|
|
|
dlresolve(dlh, redis_restore); |
|
|
|
dlresolve(dlh, redis_update); |
|
|
|
dlresolve(dlh, redis_delete); |
|
|
|
dlresolve(dlh, redis_wipe); |
|
|
|
|
|
|
|
redis_mod_verify(dlh); |
|
|
|
mc.redis = redis_new(redis_ip, redis_port, redis_db); |
|
|
|
if (!mc.redis) |
|
|
|
die("Cannot start up without Redis database\n"); |
|
|
|
|