cregit-Linux how code gets into the kernel

Release 4.7 net/netrom/nr_timer.c

Directory: net/netrom
/*
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * Copyright (C) Jonathan Naylor G4KLX (g4klx@g4klx.demon.co.uk)
 * Copyright (C) 2002 Ralf Baechle DO1GRB (ralf@gnu.org)
 */
#include <linux/errno.h>
#include <linux/types.h>
#include <linux/socket.h>
#include <linux/in.h>
#include <linux/kernel.h>
#include <linux/jiffies.h>
#include <linux/timer.h>
#include <linux/string.h>
#include <linux/sockios.h>
#include <linux/net.h>
#include <net/ax25.h>
#include <linux/inet.h>
#include <linux/netdevice.h>
#include <linux/skbuff.h>
#include <net/sock.h>
#include <net/tcp_states.h>
#include <linux/uaccess.h>
#include <linux/fcntl.h>
#include <linux/mm.h>
#include <linux/interrupt.h>
#include <net/netrom.h>

static void nr_heartbeat_expiry(unsigned long);
static void nr_t1timer_expiry(unsigned long);
static void nr_t2timer_expiry(unsigned long);
static void nr_t4timer_expiry(unsigned long);
static void nr_idletimer_expiry(unsigned long);


void nr_init_timers(struct sock *sk) { struct nr_sock *nr = nr_sk(sk); setup_timer(&nr->t1timer, nr_t1timer_expiry, (unsigned long)sk); setup_timer(&nr->t2timer, nr_t2timer_expiry, (unsigned long)sk); setup_timer(&nr->t4timer, nr_t4timer_expiry, (unsigned long)sk); setup_timer(&nr->idletimer, nr_idletimer_expiry, (unsigned long)sk); /* initialized by sock_init_data */ sk->sk_timer.data = (unsigned long)sk; sk->sk_timer.function = &nr_heartbeat_expiry; }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git4037.74%120.00%
vinay k nallamothuvinay k nallamothu3533.02%120.00%
pavel emelianovpavel emelianov2018.87%120.00%
david s. millerdavid s. miller98.49%120.00%
ralf baechleralf baechle21.89%120.00%
Total106100.00%5100.00%


void nr_start_t1timer(struct sock *sk) { struct nr_sock *nr = nr_sk(sk); mod_timer(&nr->t1timer, jiffies + nr->t1); }

Contributors

PersonTokensPropCommitsCommitProp
vinay k nallamothuvinay k nallamothu2573.53%133.33%
pre-gitpre-git720.59%133.33%
ralf baechleralf baechle25.88%133.33%
Total34100.00%3100.00%


void nr_start_t2timer(struct sock *sk) { struct nr_sock *nr = nr_sk(sk); mod_timer(&nr->t2timer, jiffies + nr->t2); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git1544.12%125.00%
vinay k nallamothuvinay k nallamothu926.47%125.00%
david s. millerdavid s. miller823.53%125.00%
ralf baechleralf baechle25.88%125.00%
Total34100.00%4100.00%


void nr_start_t4timer(struct sock *sk) { struct nr_sock *nr = nr_sk(sk); mod_timer(&nr->t4timer, jiffies + nr->t4); }

Contributors

PersonTokensPropCommitsCommitProp
vinay k nallamothuvinay k nallamothu1955.88%133.33%
pre-gitpre-git1338.24%133.33%
ralf baechleralf baechle25.88%133.33%
Total34100.00%3100.00%


void nr_start_idletimer(struct sock *sk) { struct nr_sock *nr = nr_sk(sk); if (nr->idle > 0) mod_timer(&nr->idletimer, jiffies + nr->idle); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git2969.05%125.00%
david s. millerdavid s. miller819.05%125.00%
vinay k nallamothuvinay k nallamothu37.14%125.00%
ralf baechleralf baechle24.76%125.00%
Total42100.00%4100.00%


void nr_start_heartbeat(struct sock *sk) { mod_timer(&sk->sk_timer, jiffies + 5 * HZ); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git2187.50%133.33%
vinay k nallamothuvinay k nallamothu28.33%133.33%
arnaldo carvalho de meloarnaldo carvalho de melo14.17%133.33%
Total24100.00%3100.00%


void nr_stop_t1timer(struct sock *sk) { del_timer(&nr_sk(sk)->t1timer); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git1885.71%150.00%
david s. millerdavid s. miller314.29%150.00%
Total21100.00%2100.00%


void nr_stop_t2timer(struct sock *sk) { del_timer(&nr_sk(sk)->t2timer); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git1885.71%266.67%
david s. millerdavid s. miller314.29%133.33%
Total21100.00%3100.00%


void nr_stop_t4timer(struct sock *sk) { del_timer(&nr_sk(sk)->t4timer); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git1885.71%266.67%
david s. millerdavid s. miller314.29%133.33%
Total21100.00%3100.00%


void nr_stop_idletimer(struct sock *sk) { del_timer(&nr_sk(sk)->idletimer); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git1885.71%266.67%
david s. millerdavid s. miller314.29%133.33%
Total21100.00%3100.00%


void nr_stop_heartbeat(struct sock *sk) { del_timer(&sk->sk_timer); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git1794.44%266.67%
arnaldo carvalho de meloarnaldo carvalho de melo15.56%133.33%
Total18100.00%3100.00%


int nr_t1timer_running(struct sock *sk) { return timer_pending(&nr_sk(sk)->t1timer); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git1986.36%266.67%
david s. millerdavid s. miller313.64%133.33%
Total22100.00%3100.00%


static void nr_heartbeat_expiry(unsigned long param) { struct sock *sk = (struct sock *)param; struct nr_sock *nr = nr_sk(sk); bh_lock_sock(sk); switch (nr->state) { case NR_STATE_0: /* Magic here: If we listen() and a new link dies before it is accepted() it isn't 'dead' so doesn't get removed. */ if (sock_flag(sk, SOCK_DESTROY) || (sk->sk_state == TCP_LISTEN && sock_flag(sk, SOCK_DEAD))) { sock_hold(sk); bh_unlock_sock(sk); nr_destroy_socket(sk); sock_put(sk); return; } break; case NR_STATE_3: /* * Check for the state of the receive buffer. */ if (atomic_read(&sk->sk_rmem_alloc) < (sk->sk_rcvbuf / 2) && (nr->condition & NR_COND_OWN_RX_BUSY)) { nr->condition &= ~NR_COND_OWN_RX_BUSY; nr->condition &= ~NR_COND_ACK_PENDING; nr->vl = nr->vr; nr_write_internal(sk, NR_INFOACK); break; } break; } nr_start_heartbeat(sk); bh_unlock_sock(sk); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git11970.00%535.71%
ralf baechleralf baechle169.41%428.57%
jeroen vreekenjeroen vreeken148.24%17.14%
arnaldo carvalho de meloarnaldo carvalho de melo95.29%214.29%
david s. millerdavid s. miller84.71%17.14%
james morrisjames morris42.35%17.14%
Total170100.00%14100.00%


static void nr_t2timer_expiry(unsigned long param) { struct sock *sk = (struct sock *)param; struct nr_sock *nr = nr_sk(sk); bh_lock_sock(sk); if (nr->condition & NR_COND_ACK_PENDING) { nr->condition &= ~NR_COND_ACK_PENDING; nr_enquiry_response(sk); } bh_unlock_sock(sk); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git4468.75%350.00%
ralf baechleralf baechle1218.75%233.33%
david s. millerdavid s. miller812.50%116.67%
Total64100.00%6100.00%


static void nr_t4timer_expiry(unsigned long param) { struct sock *sk = (struct sock *)param; bh_lock_sock(sk); nr_sk(sk)->condition &= ~NR_COND_PEER_RX_BUSY; bh_unlock_sock(sk); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git2969.05%250.00%
ralf baechleralf baechle1023.81%125.00%
david s. millerdavid s. miller37.14%125.00%
Total42100.00%4100.00%


static void nr_idletimer_expiry(unsigned long param) { struct sock *sk = (struct sock *)param; struct nr_sock *nr = nr_sk(sk); bh_lock_sock(sk); nr_clear_queues(sk); nr->n2count = 0; nr_write_internal(sk, NR_DISCREQ); nr->state = NR_STATE_2; nr_start_t1timer(sk); nr_stop_t2timer(sk); nr_stop_t4timer(sk); sk->sk_state = TCP_CLOSE; sk->sk_err = 0; sk->sk_shutdown |= SEND_SHUTDOWN; if (!sock_flag(sk, SOCK_DEAD)) { sk->sk_state_change(sk); sock_set_flag(sk, SOCK_DEAD); } bh_unlock_sock(sk); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git8971.20%333.33%
arnaldo carvalho de meloarnaldo carvalho de melo129.60%222.22%
ralf baechleralf baechle129.60%222.22%
david s. millerdavid s. miller86.40%111.11%
james morrisjames morris43.20%111.11%
Total125100.00%9100.00%


static void nr_t1timer_expiry(unsigned long param) { struct sock *sk = (struct sock *)param; struct nr_sock *nr = nr_sk(sk); bh_lock_sock(sk); switch (nr->state) { case NR_STATE_1: if (nr->n2count == nr->n2) { nr_disconnect(sk, ETIMEDOUT); bh_unlock_sock(sk); return; } else { nr->n2count++; nr_write_internal(sk, NR_CONNREQ); } break; case NR_STATE_2: if (nr->n2count == nr->n2) { nr_disconnect(sk, ETIMEDOUT); bh_unlock_sock(sk); return; } else { nr->n2count++; nr_write_internal(sk, NR_DISCREQ); } break; case NR_STATE_3: if (nr->n2count == nr->n2) { nr_disconnect(sk, ETIMEDOUT); bh_unlock_sock(sk); return; } else { nr->n2count++; nr_requeue_frames(sk); } break; } nr_start_t1timer(sk); bh_unlock_sock(sk); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git15081.08%342.86%
jeroen vreekenjeroen vreeken158.11%114.29%
ralf baechleralf baechle126.49%228.57%
david s. millerdavid s. miller84.32%114.29%
Total185100.00%7100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git76270.04%733.33%
vinay k nallamothuvinay k nallamothu938.55%14.76%
david s. millerdavid s. miller777.08%14.76%
ralf baechleralf baechle736.71%419.05%
jeroen vreekenjeroen vreeken292.67%14.76%
arnaldo carvalho de meloarnaldo carvalho de melo242.21%314.29%
pavel emelianovpavel emelianov201.84%14.76%
james morrisjames morris80.74%14.76%
rusty russellrusty russell10.09%14.76%
fabian frederickfabian frederick10.09%14.76%
Total1088100.00%21100.00%
Directory: net/netrom
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
{% endraw %}