Add additional checks for NULL pointers to fix several crashes reported.


			
			
				changes/42/42/1
			
			
		
Igor Goncharovskiy 11 years ago
parent 0ddc3bde24
commit c866ced76b

@ -2634,6 +2634,9 @@ static void *unistim_ss(void *data)
struct unistimsession *s = l->parent->session;
int res;
if (!s) {
return NULL;
}
ast_verb(3, "Starting switch on '%s@%s-%d' to %s\n", l->name, l->parent->name, sub->softkey, s->device->phone_number);
ast_channel_lock(chan);
ast_channel_exten_set(chan, s->device->phone_number);
@ -3404,6 +3407,9 @@ static void key_call(struct unistimsession *pte, char keycode)
struct unistim_subchannel *sub = get_sub(pte->device, SUB_REAL);
struct unistim_subchannel *sub_3way = get_sub(pte->device, SUB_THREEWAY);
if (!sub) {
return;
}
if ((keycode >= KEY_0) && (keycode <= KEY_SHARP)) {
if (keycode == KEY_SHARP) {
keycode = '#';
@ -3417,7 +3423,7 @@ static void key_call(struct unistimsession *pte, char keycode)
}
switch (keycode) {
case KEY_FUNC1:
if (ast_channel_state(sub->owner) == AST_STATE_UP) {
if (sub->owner && ast_channel_state(sub->owner) == AST_STATE_UP) {
if (sub_3way) {
close_call(pte);
}

Loading…
Cancel
Save