lsquic_alarmset.h revision b8fa6195
17d09751dSDmitri Tikhonov/* Copyright (c) 2017 - 2020 LiteSpeed Technologies Inc. See LICENSE. */ 250aadb33SDmitri Tikhonov/* 350aadb33SDmitri Tikhonov * lsquic_alarmset.h -- A set of alarms 450aadb33SDmitri Tikhonov */ 550aadb33SDmitri Tikhonov 650aadb33SDmitri Tikhonov#ifndef LSQUIC_ALARM_H 750aadb33SDmitri Tikhonov#define LSQUIC_ALARM_H 1 850aadb33SDmitri Tikhonov 950aadb33SDmitri Tikhonov#include "lsquic_int_types.h" 1050aadb33SDmitri Tikhonov 115392f7a3SLiteSpeed Techenum alarm_id; 125392f7a3SLiteSpeed Techstruct lsquic_conn; 135392f7a3SLiteSpeed Tech 145392f7a3SLiteSpeed Techtypedef void (*lsquic_alarm_cb_f)(enum alarm_id, void *cb_ctx, 1550aadb33SDmitri Tikhonov lsquic_time_t expiry, lsquic_time_t now); 1650aadb33SDmitri Tikhonov 1750aadb33SDmitri Tikhonovtypedef struct lsquic_alarm { 1850aadb33SDmitri Tikhonov lsquic_alarm_cb_f callback; 1950aadb33SDmitri Tikhonov void *cb_ctx; 2050aadb33SDmitri Tikhonov} lsquic_alarm_t; 2150aadb33SDmitri Tikhonov 2250aadb33SDmitri Tikhonov 2350aadb33SDmitri Tikhonovenum alarm_id { 2450aadb33SDmitri Tikhonov AL_HANDSHAKE, 255392f7a3SLiteSpeed Tech AL_RETX_INIT, 265392f7a3SLiteSpeed Tech AL_RETX_HSK = AL_RETX_INIT + PNS_HSK, 275392f7a3SLiteSpeed Tech AL_RETX_APP = AL_RETX_INIT + PNS_APP, 2850aadb33SDmitri Tikhonov AL_PING, 29b8fa6195SDmitri Tikhonov AL_MTU_PROBE, 3050aadb33SDmitri Tikhonov AL_IDLE, 31bc520ef7SDmitri Tikhonov AL_ACK_APP, 325392f7a3SLiteSpeed Tech AL_RET_CIDS, 335392f7a3SLiteSpeed Tech AL_CID_THROT, 345392f7a3SLiteSpeed Tech AL_PATH_CHAL, 355392f7a3SLiteSpeed Tech AL_PATH_CHAL_0 = AL_PATH_CHAL, 365392f7a3SLiteSpeed Tech AL_PATH_CHAL_1, 37fb73393fSDmitri Tikhonov AL_PATH_CHAL_2, 38fb73393fSDmitri Tikhonov AL_PATH_CHAL_3, 3965728dc5SDmitri Tikhonov AL_SESS_TICKET, 409fc12041SDmitri Tikhonov AL_BLOCKED_KA, /* Blocked Keep-Alive */ 4150aadb33SDmitri Tikhonov MAX_LSQUIC_ALARMS 4250aadb33SDmitri Tikhonov}; 4350aadb33SDmitri Tikhonov 4450aadb33SDmitri Tikhonov 4550aadb33SDmitri Tikhonovenum alarm_id_bit { 4650aadb33SDmitri Tikhonov ALBIT_HANDSHAKE = 1 << AL_HANDSHAKE, 475392f7a3SLiteSpeed Tech ALBIT_RETX_INIT = 1 << AL_RETX_INIT, 485392f7a3SLiteSpeed Tech ALBIT_RETX_HSK = 1 << AL_RETX_HSK, 495392f7a3SLiteSpeed Tech ALBIT_RETX_APP = 1 << AL_RETX_APP, 505392f7a3SLiteSpeed Tech ALBIT_ACK_APP = 1 << AL_ACK_APP, 5150aadb33SDmitri Tikhonov ALBIT_PING = 1 << AL_PING, 5250aadb33SDmitri Tikhonov ALBIT_IDLE = 1 << AL_IDLE, 535392f7a3SLiteSpeed Tech ALBIT_RET_CIDS = 1 << AL_RET_CIDS, 545392f7a3SLiteSpeed Tech ALBIT_CID_THROT = 1 << AL_CID_THROT, 555392f7a3SLiteSpeed Tech ALBIT_PATH_CHAL_0 = 1 << AL_PATH_CHAL_0, 565392f7a3SLiteSpeed Tech ALBIT_PATH_CHAL_1 = 1 << AL_PATH_CHAL_1, 57fb73393fSDmitri Tikhonov ALBIT_PATH_CHAL_2 = 1 << AL_PATH_CHAL_2, 58fb73393fSDmitri Tikhonov ALBIT_PATH_CHAL_3 = 1 << AL_PATH_CHAL_3, 5965728dc5SDmitri Tikhonov ALBIT_SESS_TICKET = 1 << AL_SESS_TICKET, 609fc12041SDmitri Tikhonov ALBIT_BLOCKED_KA = 1 << AL_BLOCKED_KA, 61b8fa6195SDmitri Tikhonov ALBIT_MTU_PROBE = 1 << AL_MTU_PROBE, 6250aadb33SDmitri Tikhonov}; 6350aadb33SDmitri Tikhonov 6450aadb33SDmitri Tikhonov 6550aadb33SDmitri Tikhonovtypedef struct lsquic_alarmset { 6650aadb33SDmitri Tikhonov enum alarm_id_bit as_armed_set; 6750aadb33SDmitri Tikhonov lsquic_time_t as_expiry[MAX_LSQUIC_ALARMS]; 685392f7a3SLiteSpeed Tech const struct lsquic_conn *as_conn; /* Used for logging */ 6950aadb33SDmitri Tikhonov struct lsquic_alarm as_alarms[MAX_LSQUIC_ALARMS]; 7050aadb33SDmitri Tikhonov} lsquic_alarmset_t; 7150aadb33SDmitri Tikhonov 7250aadb33SDmitri Tikhonov 7350aadb33SDmitri Tikhonovvoid 745392f7a3SLiteSpeed Techlsquic_alarmset_init (lsquic_alarmset_t *, const struct lsquic_conn *); 7550aadb33SDmitri Tikhonov 7650aadb33SDmitri Tikhonovvoid 7750aadb33SDmitri Tikhonovlsquic_alarmset_init_alarm (lsquic_alarmset_t *, enum alarm_id, 7850aadb33SDmitri Tikhonov lsquic_alarm_cb_f, void *cb_ctx); 7950aadb33SDmitri Tikhonov 8050aadb33SDmitri Tikhonov#define lsquic_alarmset_set(alarmset, al_id, exp) do { \ 8150aadb33SDmitri Tikhonov (alarmset)->as_armed_set |= 1 << (al_id); \ 8250aadb33SDmitri Tikhonov (alarmset)->as_expiry[al_id] = exp; \ 8350aadb33SDmitri Tikhonov} while (0) 8450aadb33SDmitri Tikhonov 8550aadb33SDmitri Tikhonov#define lsquic_alarmset_unset(alarmset, al_id) do { \ 8650aadb33SDmitri Tikhonov (alarmset)->as_armed_set &= ~(1 << (al_id)); \ 8750aadb33SDmitri Tikhonov} while (0) 8850aadb33SDmitri Tikhonov 8950aadb33SDmitri Tikhonov#define lsquic_alarmset_is_set(alarmset, al_id) \ 9050aadb33SDmitri Tikhonov ((alarmset)->as_armed_set & (1 << (al_id))) 9150aadb33SDmitri Tikhonov 925392f7a3SLiteSpeed Tech#define lsquic_alarmset_are_set(alarmset, flags) \ 935392f7a3SLiteSpeed Tech ((alarmset)->as_armed_set & (flags)) 945392f7a3SLiteSpeed Tech 9550aadb33SDmitri Tikhonov/* Timers "fire," alarms "ring." */ 9650aadb33SDmitri Tikhonovvoid 9750aadb33SDmitri Tikhonovlsquic_alarmset_ring_expired (lsquic_alarmset_t *, lsquic_time_t now); 9850aadb33SDmitri Tikhonov 99e8bd737dSDmitri Tikhonovlsquic_time_t 1000adf085aSDmitri Tikhonovlsquic_alarmset_mintime (const lsquic_alarmset_t *, enum alarm_id *); 1010adf085aSDmitri Tikhonov 1020adf085aSDmitri Tikhonovextern const char *const lsquic_alid2str[]; 103e8bd737dSDmitri Tikhonov 10450aadb33SDmitri Tikhonov#endif 105