X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Fsrc%2Fpalacios%2Fvmm_intr.c;h=fa8c69fedca386c6bd911fb488a29d89e489c705;hb=366a20deaf086107d75a2004fec076db4705e7c2;hp=ee54bef7357c0e005cc98e89684b6bb294ccb5e3;hpb=e0711262cc7bef8962813f713d36cc8cabf80cb4;p=palacios.git diff --git a/palacios/src/palacios/vmm_intr.c b/palacios/src/palacios/vmm_intr.c index ee54bef..fa8c69f 100644 --- a/palacios/src/palacios/vmm_intr.c +++ b/palacios/src/palacios/vmm_intr.c @@ -69,11 +69,13 @@ void v3_deinit_intr_controllers(struct guest_info * core) { struct intr_controller * tmp; // clear out any controllers that were left around - list_for_each_entry_safe(ctrlr, tmp, &(intr_state->controller_list), ctrl_node) { - v3_remove_intr_controller(core, ctrlr); - } + if (*(void**)&intr_state->controller_list) { + list_for_each_entry_safe(ctrlr, tmp, &(intr_state->controller_list), ctrl_node) { + v3_remove_intr_controller(core, ctrlr); + } - v3_lock_deinit(&(intr_state->irq_lock)); + v3_lock_deinit(&(intr_state->irq_lock)); + } } @@ -92,12 +94,14 @@ void v3_deinit_intr_routers(struct v3_vm_info * vm) { struct intr_router * rtr = NULL; struct intr_router * tmp = NULL; - // clear out any controllers that were left around - list_for_each_entry_safe(rtr, tmp, &(vm->intr_routers.router_list), router_node) { - v3_remove_intr_router(vm, rtr); - } + // clear out any routers that were left around + if (*(void**)&vm->intr_routers.router_list) { + list_for_each_entry_safe(rtr, tmp, &(vm->intr_routers.router_list), router_node) { + v3_remove_intr_router(vm, rtr); + } - v3_lock_deinit(&(vm->intr_routers.irq_lock)); + v3_lock_deinit(&(vm->intr_routers.irq_lock)); + } } void * v3_register_intr_controller(struct guest_info * info, struct intr_ctrl_ops * ops, void * priv_data) {