aboutsummaryrefslogtreecommitdiffstats
path: root/doc/handover-inter-bsc-in.msc
blob: 9534f908a4987833dce543f00dd5203cc9467f4b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
msc {
	hscale=2;
	ms [label="MS/BTS"], lchan[label="BSC lchan FSM"], ho[label="BSC Handover FSM"],
	gscon[label="BSC conn FSM"], msc_[label="MSC"];

	ms note msc_ [label="inter-BSC Handover Incoming"];

	gscon <= msc_ [label="N-Connect: BSSMAP Handover Request"];
	gscon box gscon [label="bsc_subscr_con_allocate()"];
	gscon abox gscon [label="ST_INIT"];
	gscon -> gscon [label="GSCON_EV_A_CONN_IND"];
	ho <- gscon [label="handover_start_inter_bsc_in()"];

	ho abox ho [label="allocate\nHO_ST_NOT_STARTED"];
	ho box ho [label="lchan_select_by_chan_mode()"];
	ho abox ho [label="HO_ST_WAIT_\nLCHAN_ACTIVE"];
	lchan <- ho [label="lchan_activate(FOR_HANDOVER)"];
	lchan rbox lchan [label="(most details omitted, see lchan_fsm diagrams)"];

	...;
	...;
	--- [label="On any error or timeout"];
	ho box ho [label="handover_end(fail)"];
	ho -> gscon [label="GSCON_EV_HANDOVER_END"];
	gscon note msc_ [label="There is no specific BSSMAP Handover Request NACK message."];
	gscon => msc_ [label="BSSMAP Clear Request"];
	gscon abox gscon [label="ST_CLEARING"];
	gscon rbox msc_ [label="the usual disconnect dance"];
	--- [label="END: 'On any error or timeout'"];
	...;
	...;

	lchan abox lchan [label="LCHAN_ST_WAIT_\nACTIV_ACK"];
	ms <= lchan [label="RSL Chan Activ"];
	...;
	ms => lchan [label="RSL Chan Activ ACK"];
	lchan -> ho [label="HO_EV_LCHAN_ACTIVE"];
	ho abox ho [label="HO_ST_WAIT_\nRR_HO_DETECT"];
	ho => msc_ [label="BSSMAP Handover Request Acknowledge\nwith RR Handover Command"];

	...;

	ms => ho [label="RR Handover Detect\nHO_EV_RR_HO_DETECT"];
	ho => msc_ [label="BSSMAP Handover Detect"];
	ho abox ho [label="HO_ST_WAIT_\nRR_HO_COMPLETE"];

	...;
	lchan note ho [label="The lchan FSM will continue with RSL and RTP while the HO FSM waits.
		HO_EV_LCHAN_ESTABLISHED means that both RSL and RTP are established.
		Usually, RTP will be done first, and the HO_EV_LCHAN_ESTABLISHED may be
		received even before HO_EV_RR_HO_COMPLETE.
		ho_fsm_wait_lchan_established_onenter() decides whether to wait or not."];
	...;
	ms => lchan [label="RSL EST IND"];
	lchan -> ho [label="HO_EV_LCHAN_ESTABLISHED",ID="(may come as early as this, or...)"];
	ms => ho [label="RR Handover Complete (from EST IND)\n HO_EV_RR_HO_COMPLETE"];
	ho abox ho [label="HO_ST_WAIT_\nLCHAN_ESTABLISHED"];
	...;
	lchan rbox lchan [label="when lchan FSM is done with setting up RTP"];
	lchan -> ho [label="HO_EV_LCHAN_ESTABLISHED",ID="(...may come only now)"];
	ho abox ho [label="HO_ST_WAIT_\nMGW_ENDPOINT_TO_MSC"];
	ho -> gscon [label="gscon_connect_mgw_to_msc()"];
	...;
	ho <- gscon [label="HO_EV_MSC_MGW_OK"];
	ho box ho [label="handover_end(OK)"];
	ho => msc_ [label="BSSMAP Handover Complete"];

	ho -> gscon [label="gscon_change_primary_lchan()"];
	lchan <- gscon [label="LCHAN_RTP_EV_ESTABLISHED"];
	ho -> gscon [label="GSCON_EV_HANDOVER_END"];
	gscon abox gscon [label="ST_ACTIVE"];
	ho box ho [label="detach from parent to not fire another meaningless GSCON_EV_HANDOVER_END"];
	ho abox ho [label="terminate"];
}