FreeCalypso > hg > themwi-system-sw
diff sip-out/shutdown.c @ 154:e54b0a9e322f
beginning of themwi-sip-out
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Tue, 11 Oct 2022 23:04:01 -0800 |
parents | sip-in/shutdown.c@c1c94b7fc2e2 |
children | baaa6c1a3d3b |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/sip-out/shutdown.c Tue Oct 11 23:04:01 2022 -0800 @@ -0,0 +1,63 @@ +/* + * In this module we handle the scenarios of themwi-mncc and/or themwi-mgw + * shutting down while we are connected to them. In both scenarios we + * terminate all active calls (in the case of MNCC socket closing, only + * those calls that came on that socket), but our themwi-sip-out process + * itself stays running. This way once the other required processes restart, + * outbound calls will start working once again, without needing to restart + * themwi-sip-out. + */ + +#include <sys/types.h> +#include <sys/socket.h> +#include <sys/time.h> +#include <netinet/in.h> +#include <stdio.h> +#include <stdint.h> +#include <stdlib.h> +#include <string.h> +#include <strings.h> +#include <syslog.h> +#include "../include/mncc.h" +#include "../include/gsm48_const.h" +#include "../include/out_routes.h" +#include "call.h" + +extern struct call *call_list; + +void +shutdown_mncc_socket(mncc) + struct mncc_conn *mncc; +{ + struct call *call; + + for (call = call_list; call; call = call->next) { + if (call->mncc != mncc) + continue; + call->mncc = 0; + if (call->overall_state < OVERALL_STATE_TEARDOWN) { + call->overall_state = OVERALL_STATE_TEARDOWN; + disconnect_tmgw(call); + disconnect_sip(call); + check_dead_call(call); + } + } +} + +void +shutdown_mgw_conn() +{ + struct call *call; + + for (call = call_list; call; call = call->next) { + call->mgw_state = MGW_STATE_NO_EXIST; + call->mgw_xact = 0; + if (call->overall_state < OVERALL_STATE_TEARDOWN) { + call->overall_state = OVERALL_STATE_TEARDOWN; + disconnect_mncc(call, GSM48_CAUSE_LOC_PRN_S_LU, + GSM48_CC_CAUSE_NETWORK_OOO); + disconnect_sip(call); + check_dead_call(call); + } + } +}