aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNeels Hofmeyr <neels@hofmeyr.de>2019-08-05 23:02:21 +0200
committerNeels Hofmeyr <neels@hofmeyr.de>2019-08-05 23:25:16 +0200
commit62c0a2a4ab226a863d049ff662499c5d35a22b8a (patch)
tree996afb058e1e22fe2443a5b822ef2df2bd99bc52
parent14c34d8bec898f8a483c4f94e2052fa77ea16cdc (diff)
doc/sequence_charts/mncc_fsm.msc: add SIP messages, tweak
- add SIP messages, taken from OS#1683 - change some wording and clarify some message ordering - have a separate sipcon1 and sipcon2 for the MO and MT sides Change-Id: I6782e416dbd8ee88d093cbef722b0c5084f3865c
-rw-r--r--doc/sequence_charts/mncc_fsm.msc90
1 files changed, 55 insertions, 35 deletions
diff --git a/doc/sequence_charts/mncc_fsm.msc b/doc/sequence_charts/mncc_fsm.msc
index ae5e0a211..45a77cacf 100644
--- a/doc/sequence_charts/mncc_fsm.msc
+++ b/doc/sequence_charts/mncc_fsm.msc
@@ -1,84 +1,104 @@
msc {
- hscale=2;
- msc1[label="osmo-msc"], mncc1[label="MNCC FSM"], pbx[label="MNCC server (osmo-sip-connector)"], mncc2[label="MNCC FSM"], msc2[label="osmo-msc"];
+ hscale=3;
+ msc1[label="osmo-msc"], mncc1[label="MNCC FSM\n(osmo-msc mncc_fsm.c)"], sipcon1[label="osmo-sip-connector"], sip[label="PBX"], sipcon2[label="osmo-sip-connector"], mncc2[label="MNCC FSM\n(osmo-msc mncc_fsm.c)"], msc2[label="osmo-msc"];
- mncc1 note mncc1 [label="The typical progression of an outgoing call, i.e. a call initiated by osmo-msc, as
- implemented in mncc_fsm.h, mncc_fsm.c"];
- mncc2 note mncc2 [label="The typical progression of an incoming call, i.e. a call initiated by the PBX, as
- implemented in mncc_fsm.h, mncc_fsm.c"];
+ msc1 note sipcon1 [label="MO call"];
+ sipcon2 note msc2 [label="MT call"];
mncc1 abox mncc1 [label="MNCC_ST_NOT_STARTED"];
msc1 rbox msc1 [label="mncc_outgoing_start()"];
msc1 -> mncc1 [label="MNCC_EV_OUTGOING_START"];
mncc1 abox mncc1 [label="MNCC_ST_OUTGOING_WAIT_PROCEEDING"];
- mncc1 => pbx [label="MNCC_SETUP_IND
- \n callref, IMSI, called and calling number"];
- mncc1 <= pbx [label="MNCC_RTP_CREATE
+ mncc1 => sipcon1 [label="MNCC_SETUP_IND
+ \n callref, IMSI, called and calling number, SDP"];
+ sipcon1 => sip [label="SIP INVITE
+ \n from, to, SDP"];
+ sipcon1 <= sip [label="SIP 100 Trying"];
+ mncc1 <= sipcon1 [label="MNCC_RTP_CREATE
\n callref"];
mncc1 rbox mncc1 [label="mncc_rx_rtp_create()"];
- mncc1 => pbx [label="MNCC_RTP_CREATE
+ mncc1 => sipcon1 [label="MNCC_RTP_CREATE
\n callref, RTP IP address and port"];
- mncc1 <= pbx [label="MNCC_CALL_PROC_REQ
+ mncc1 <= sipcon1 [label="MNCC_CALL_PROC_REQ
\n callref, RTP IP address and port"];
mncc1 abox mncc1 [label="MNCC_ST_OUTGOING_WAIT_COMPLETE"];
- msc2 <= pbx [label="MNCC_SETUP_REQ
- \n callref, called and calling number"];
+ sip => sipcon2 [label="SIP INVITE
+ \n from, to, SDP"];
+ sipcon2 => sip [label="SIP 100 Trying"];
+ msc2 <= sipcon2 [label="MNCC_SETUP_REQ
+ \n callref, called and calling number
+ \n SDP"];
mncc2 abox mncc2 [label="MNCC_ST_NOT_STARTED"];
msc2 rbox msc2 [label="mncc_incoming_start()"];
msc2 -> mncc2 [label="MNCC_EV_INCOMING_START"];
mncc2 abox mncc2 [label="MNCC_ST_INCOMING_WAIT_COMPLETE"];
- mncc2 => pbx [label="MNCC_CALL_CONF_IND
- \n callref, bearer capabilities, cccap and IMSI"];
- mncc2 <= pbx [label="MNCC_RTP_CREATE
+ mncc2 => sipcon2 [label="MNCC_CALL_CONF_IND
+ \n callref, bearer capabilities, cccap and IMSI, SDP?"];
+ mncc2 <= sipcon2 [label="MNCC_RTP_CREATE
\n callref"];
mncc2 rbox mncc2 [label="mncc_rx_rtp_create()"];
- mncc2 => pbx [label="MNCC_RTP_CREATE
- \n callref, RTP IP address and port"];
- mncc2 => pbx [label="MNCC_ALERT_IND
+ mncc2 => sipcon2 [label="MNCC_RTP_CREATE
+ \n callref, RTP IP address and port, SDP?"];
+ mncc2 => sipcon2 [label="MNCC_ALERT_IND
\n callref"];
+ sipcon2 => sip [label="SIP 180 Ringing
+ \n SDP"];
- mncc1 <= pbx [label="MNCC_ALERT_REQ
+ sipcon1 <= sip [label="SIP 180 Ringing
+ \n SDP"];
+ mncc1 <= sipcon1 [label="MNCC_ALERT_REQ
\n callref and progress"];
+ sipcon1 => sip [label="SIP PRACK 180 Ringing"];
+ sipcon1 <= sip [label="SIP PRACK 200"];
+
+ mncc1 <= sipcon1 [label="MNCC_RTP_CONNECT
+ \n callref, RTP IP and port"];
+ mncc1 rbox mncc1 [label="mncc_rx_rtp_connect()"];
+ msc1 <- mncc1 [label="rtp_stream_set_remote_addr()"];
- mncc2 => pbx [label="MNCC_SETUP_CNF
- \n callref, imsi and connected number"];
- mncc2 <= pbx [label="MNCC_RTP_CONNECT
+ mncc2 => sipcon2 [label="MNCC_SETUP_CNF
+ \n callref, imsi and connected number, SDP?"];
+ sipcon2 => sip [label="SIP 200 OK
+ \n SDP"];
+ mncc2 <= sipcon2 [label="MNCC_RTP_CONNECT
\n callref, RTP IP and port"];
mncc2 rbox mncc2 [label="mncc_rx_rtp_connect()"];
- mncc2 <= pbx [label="MNCC_SETUP_COMPL_REQ
+ mncc2 <= sipcon2 [label="MNCC_SETUP_COMPL_REQ
\n callref"];
mncc2 abox mncc2 [label="MNCC_ST_TALKING"];
- mncc1 <= pbx [label="MNCC_RTP_CONNECT
- \n callref, RTP IP and port"];
- mncc1 rbox mncc1 [label="mncc_rx_rtp_connect()"];
- msc1 <- mncc1 [label="rtp_stream_set_remote_addr()"];
- mncc1 <= pbx [label="MNCC_SETUP_RSP
+ sipcon1 <= sip [label="SIP 200 OK INVITE"];
+ mncc1 <= sipcon1 [label="MNCC_SETUP_RSP
\n callref"];
- mncc1 => pbx [label="MNCC_SETUP_COMPL_IND
+ mncc1 => sipcon1 [label="MNCC_SETUP_COMPL_IND
\n callref"];
mncc1 abox mncc1 [label="MNCC_ST_TALKING"];
+ sipcon1 => sip [label="SIP ACK"];
...;
... [label="Call goes on for a while..."];
...;
mncc1 rbox mncc1 [label="mncc_release()"];
- mncc1 => pbx [label="MNCC_DISC_IND
+ mncc1 => sipcon1 [label="MNCC_DISC_IND
\n callref and cause"];
mncc1 abox mncc1 [label="MNCC_ST_WAIT_RELEASE_ACK"];
- mncc1 <= pbx [label="MNCC_REL_REQ
+ sipcon1 => sip [label="SIP BYE"];
+ sipcon1 <= sip [label="SIP 200 OK"];
+ mncc1 <= sipcon1 [label="MNCC_REL_REQ
\n callref and cause"];
- mncc2 <= pbx [label="MNCC_DISC_REQ
+ sip => sipcon2 [label="SIP BYE"];
+ sip <= sipcon2 [label="SIP 200 OK"];
+ mncc2 <= sipcon2 [label="MNCC_DISC_REQ
\n callref and cause"];
- mncc2 => pbx [label="MNCC_REL_IND
+ mncc2 => sipcon2 [label="MNCC_REL_IND
\n callref and cause"];
mncc2 abox mncc2 [label="terminated"];
- mncc1 => pbx [label="MNCC_REL_CNF
+ mncc1 => sipcon1 [label="MNCC_REL_CNF
\n callref"];
mncc1 abox mncc1 [label="terminated"];
}