cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

ax25_timer.c (5031B)


      1// SPDX-License-Identifier: GPL-2.0-or-later
      2/*
      3 *
      4 * Copyright (C) Alan Cox GW4PTS (alan@lxorguk.ukuu.org.uk)
      5 * Copyright (C) Jonathan Naylor G4KLX (g4klx@g4klx.demon.co.uk)
      6 * Copyright (C) Tomi Manninen OH2BNS (oh2bns@sral.fi)
      7 * Copyright (C) Darryl Miles G7LED (dlm@g7led.demon.co.uk)
      8 * Copyright (C) Joerg Reuter DL1BKE (jreuter@yaina.de)
      9 * Copyright (C) Frederic Rible F1OAT (frible@teaser.fr)
     10 * Copyright (C) 2002 Ralf Baechle DO1GRB (ralf@gnu.org)
     11 */
     12#include <linux/errno.h>
     13#include <linux/types.h>
     14#include <linux/socket.h>
     15#include <linux/in.h>
     16#include <linux/kernel.h>
     17#include <linux/module.h>
     18#include <linux/jiffies.h>
     19#include <linux/timer.h>
     20#include <linux/string.h>
     21#include <linux/sockios.h>
     22#include <linux/net.h>
     23#include <net/ax25.h>
     24#include <linux/inet.h>
     25#include <linux/netdevice.h>
     26#include <linux/skbuff.h>
     27#include <net/sock.h>
     28#include <linux/uaccess.h>
     29#include <linux/fcntl.h>
     30#include <linux/mm.h>
     31#include <linux/interrupt.h>
     32
     33static void ax25_heartbeat_expiry(struct timer_list *);
     34static void ax25_t1timer_expiry(struct timer_list *);
     35static void ax25_t2timer_expiry(struct timer_list *);
     36static void ax25_t3timer_expiry(struct timer_list *);
     37static void ax25_idletimer_expiry(struct timer_list *);
     38
     39void ax25_setup_timers(ax25_cb *ax25)
     40{
     41	timer_setup(&ax25->timer, ax25_heartbeat_expiry, 0);
     42	timer_setup(&ax25->t1timer, ax25_t1timer_expiry, 0);
     43	timer_setup(&ax25->t2timer, ax25_t2timer_expiry, 0);
     44	timer_setup(&ax25->t3timer, ax25_t3timer_expiry, 0);
     45	timer_setup(&ax25->idletimer, ax25_idletimer_expiry, 0);
     46}
     47
     48void ax25_start_heartbeat(ax25_cb *ax25)
     49{
     50	mod_timer(&ax25->timer, jiffies + 5 * HZ);
     51}
     52
     53void ax25_start_t1timer(ax25_cb *ax25)
     54{
     55	mod_timer(&ax25->t1timer, jiffies + ax25->t1);
     56}
     57
     58void ax25_start_t2timer(ax25_cb *ax25)
     59{
     60	mod_timer(&ax25->t2timer, jiffies + ax25->t2);
     61}
     62
     63void ax25_start_t3timer(ax25_cb *ax25)
     64{
     65	if (ax25->t3 > 0)
     66		mod_timer(&ax25->t3timer, jiffies + ax25->t3);
     67	else
     68		del_timer(&ax25->t3timer);
     69}
     70
     71void ax25_start_idletimer(ax25_cb *ax25)
     72{
     73	if (ax25->idle > 0)
     74		mod_timer(&ax25->idletimer, jiffies + ax25->idle);
     75	else
     76		del_timer(&ax25->idletimer);
     77}
     78
     79void ax25_stop_heartbeat(ax25_cb *ax25)
     80{
     81	del_timer(&ax25->timer);
     82}
     83
     84void ax25_stop_t1timer(ax25_cb *ax25)
     85{
     86	del_timer(&ax25->t1timer);
     87}
     88
     89void ax25_stop_t2timer(ax25_cb *ax25)
     90{
     91	del_timer(&ax25->t2timer);
     92}
     93
     94void ax25_stop_t3timer(ax25_cb *ax25)
     95{
     96	del_timer(&ax25->t3timer);
     97}
     98
     99void ax25_stop_idletimer(ax25_cb *ax25)
    100{
    101	del_timer(&ax25->idletimer);
    102}
    103
    104int ax25_t1timer_running(ax25_cb *ax25)
    105{
    106	return timer_pending(&ax25->t1timer);
    107}
    108
    109unsigned long ax25_display_timer(struct timer_list *timer)
    110{
    111	if (!timer_pending(timer))
    112		return 0;
    113
    114	return timer->expires - jiffies;
    115}
    116
    117EXPORT_SYMBOL(ax25_display_timer);
    118
    119static void ax25_heartbeat_expiry(struct timer_list *t)
    120{
    121	int proto = AX25_PROTO_STD_SIMPLEX;
    122	ax25_cb *ax25 = from_timer(ax25, t, timer);
    123
    124	if (ax25->ax25_dev)
    125		proto = ax25->ax25_dev->values[AX25_VALUES_PROTOCOL];
    126
    127	switch (proto) {
    128	case AX25_PROTO_STD_SIMPLEX:
    129	case AX25_PROTO_STD_DUPLEX:
    130		ax25_std_heartbeat_expiry(ax25);
    131		break;
    132
    133#ifdef CONFIG_AX25_DAMA_SLAVE
    134	case AX25_PROTO_DAMA_SLAVE:
    135		if (ax25->ax25_dev->dama.slave)
    136			ax25_ds_heartbeat_expiry(ax25);
    137		else
    138			ax25_std_heartbeat_expiry(ax25);
    139		break;
    140#endif
    141	}
    142}
    143
    144static void ax25_t1timer_expiry(struct timer_list *t)
    145{
    146	ax25_cb *ax25 = from_timer(ax25, t, t1timer);
    147
    148	switch (ax25->ax25_dev->values[AX25_VALUES_PROTOCOL]) {
    149	case AX25_PROTO_STD_SIMPLEX:
    150	case AX25_PROTO_STD_DUPLEX:
    151		ax25_std_t1timer_expiry(ax25);
    152		break;
    153
    154#ifdef CONFIG_AX25_DAMA_SLAVE
    155	case AX25_PROTO_DAMA_SLAVE:
    156		if (!ax25->ax25_dev->dama.slave)
    157			ax25_std_t1timer_expiry(ax25);
    158		break;
    159#endif
    160	}
    161}
    162
    163static void ax25_t2timer_expiry(struct timer_list *t)
    164{
    165	ax25_cb *ax25 = from_timer(ax25, t, t2timer);
    166
    167	switch (ax25->ax25_dev->values[AX25_VALUES_PROTOCOL]) {
    168	case AX25_PROTO_STD_SIMPLEX:
    169	case AX25_PROTO_STD_DUPLEX:
    170		ax25_std_t2timer_expiry(ax25);
    171		break;
    172
    173#ifdef CONFIG_AX25_DAMA_SLAVE
    174	case AX25_PROTO_DAMA_SLAVE:
    175		if (!ax25->ax25_dev->dama.slave)
    176			ax25_std_t2timer_expiry(ax25);
    177		break;
    178#endif
    179	}
    180}
    181
    182static void ax25_t3timer_expiry(struct timer_list *t)
    183{
    184	ax25_cb *ax25 = from_timer(ax25, t, t3timer);
    185
    186	switch (ax25->ax25_dev->values[AX25_VALUES_PROTOCOL]) {
    187	case AX25_PROTO_STD_SIMPLEX:
    188	case AX25_PROTO_STD_DUPLEX:
    189		ax25_std_t3timer_expiry(ax25);
    190		break;
    191
    192#ifdef CONFIG_AX25_DAMA_SLAVE
    193	case AX25_PROTO_DAMA_SLAVE:
    194		if (ax25->ax25_dev->dama.slave)
    195			ax25_ds_t3timer_expiry(ax25);
    196		else
    197			ax25_std_t3timer_expiry(ax25);
    198		break;
    199#endif
    200	}
    201}
    202
    203static void ax25_idletimer_expiry(struct timer_list *t)
    204{
    205	ax25_cb *ax25 = from_timer(ax25, t, idletimer);
    206
    207	switch (ax25->ax25_dev->values[AX25_VALUES_PROTOCOL]) {
    208	case AX25_PROTO_STD_SIMPLEX:
    209	case AX25_PROTO_STD_DUPLEX:
    210		ax25_std_idletimer_expiry(ax25);
    211		break;
    212
    213#ifdef CONFIG_AX25_DAMA_SLAVE
    214	case AX25_PROTO_DAMA_SLAVE:
    215		if (ax25->ax25_dev->dama.slave)
    216			ax25_ds_idletimer_expiry(ax25);
    217		else
    218			ax25_std_idletimer_expiry(ax25);
    219		break;
    220#endif
    221	}
    222}