blob: d6fe41f21e5999ecd98800fce794a1931fc41b97 [file] [log] [blame]
Pau Espin Pedroldc2aaac2021-05-14 12:50:46 +02001/* tbf_fsm.h
2 *
3 * Copyright (C) 2021 by sysmocom - s.f.m.c. GmbH <info@sysmocom.de>
4 * Author: Pau Espin Pedrol <pespin@sysmocom.de>
5 *
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public License
8 * as published by the Free Software Foundation; either version 2
9 * of the License, or (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
19 */
20#pragma once
21
22#include <osmocom/core/fsm.h>
23#include <osmocom/core/tdef.h>
24
25#include <gprs_pcu.h>
26
27struct gprs_rlcmac_tbf;
28
29enum tbf_fsm_event {
Pau Espin Pedrol33e80072021-07-22 19:20:50 +020030 TBF_EV_ASSIGN_ADD_CCCH, /* An assignment is sent over CCCH and confirmation from MS is pending */
31 TBF_EV_ASSIGN_ADD_PACCH, /* An assignment is sent over PACCH and confirmation from MS is pending */
Pau Espin Pedrol720e19e2021-07-22 19:56:37 +020032 TBF_EV_ASSIGN_ACK_PACCH, /* We received a CTRL ACK confirming assignment started on PACCH */
33 TBF_EV_ASSIGN_READY_CCCH, /* TBF Start Time timer triggered */
Pau Espin Pedrol32252902021-07-29 16:44:11 +020034 TBF_EV_ASSIGN_PCUIF_CNF, /* Transmission of IMM.ASS for DL TBF to the MS confirmed by BTS over PCUIF */
35 TBF_EV_DL_ACKNACK_MISS, /* DL TBF: We polled for DL ACK/NACK but we received none (POLL timeout) */
Pau Espin Pedrolc32c4a32021-07-23 18:27:57 +020036 TBF_EV_LAST_DL_DATA_SENT, /* DL TBF sends RLCMAC block containing last DL avilable data buffered */
37 TBF_EV_LAST_UL_DATA_RECVD, /* UL TBF sends RLCMAC block containing last UL data (cv=0) */
Pau Espin Pedrolefcb0462021-07-26 12:33:39 +020038 TBF_EV_FINAL_ACK_RECVD, /* DL ACK/NACK with FINAL_ACK=1 received from MS */
Pau Espin Pedrol55f600b2021-07-26 15:54:39 +020039 TBF_EV_MAX_N3101, /* MAX N3101 (max usf timeout) reached (UL TBF) */
40 TBF_EV_MAX_N3103, /* MAX N3103 (max Pkt Ctrl Ack for last UL ACK/NACK timeout) reached (UL TBF) */
41 TBF_EV_MAX_N3105, /* MAX N3105 (max poll timeout) reached (UL/DL TBF) */
Pau Espin Pedroldc2aaac2021-05-14 12:50:46 +020042};
43
44enum tbf_fsm_states {
45 TBF_ST_NULL = 0, /* new created TBF */
46 TBF_ST_ASSIGN, /* wait for downlink assignment */
47 TBF_ST_FLOW, /* RLC/MAC flow, resource needed */
48 TBF_ST_FINISHED, /* flow finished, wait for release */
49 TBF_ST_WAIT_RELEASE,/* wait for release or restart of DL TBF */
50 TBF_ST_RELEASING, /* releasing, wait to free TBI/USF */
51};
52
53struct tbf_fsm_ctx {
54 struct osmo_fsm_inst *fi;
55 struct gprs_rlcmac_tbf* tbf; /* back pointer */
Pau Espin Pedrol33e80072021-07-22 19:20:50 +020056 uint32_t state_flags;
Pau Espin Pedrolcfb61d92021-07-26 17:17:02 +020057 unsigned int T_release; /* Timer to be used to end release: T3169 or T3195 */
Pau Espin Pedroldc2aaac2021-05-14 12:50:46 +020058};
59
60extern const struct osmo_tdef_state_timeout tbf_fsm_timeouts[32];
Pau Espin Pedrol628d8812021-07-29 13:46:34 +020061/* Transition to a state, using the T timer defined in tbf_fsm_timeouts.
Pau Espin Pedroldc2aaac2021-05-14 12:50:46 +020062 * The actual timeout value is in turn obtained from conn->T_defs.
63 * Assumes local variable fi exists. */
64#define tbf_fsm_state_chg(fi, NEXT_STATE) \
65 osmo_tdef_fsm_inst_state_chg(fi, NEXT_STATE, \
66 tbf_fsm_timeouts, \
67 the_pcu->T_defs, \
68 -1)
69
70extern struct osmo_fsm tbf_fsm;