Linux cpanel.rrshost.in 5.15.0-25-generic #25-Ubuntu SMP Wed Mar 30 15:54:22 UTC 2022 x86_64
Apache
: 109.123.238.221 | : 172.70.130.36
128 Domain
8.2.28
aev999
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
CREATE RDP
PHP Mailer
BACKCONNECT
HASH IDENTIFIER
README
+ Create Folder
+ Create File
/
usr /
src /
linux-headers-5.15.0-25 /
include /
net /
[ HOME SHELL ]
Name
Size
Permission
Action
9p
[ DIR ]
drwxr-xr-x
bluetooth
[ DIR ]
drwxr-xr-x
caif
[ DIR ]
drwxr-xr-x
iucv
[ DIR ]
drwxr-xr-x
netfilter
[ DIR ]
drwxr-xr-x
netns
[ DIR ]
drwxr-xr-x
nfc
[ DIR ]
drwxr-xr-x
phonet
[ DIR ]
drwxr-xr-x
sctp
[ DIR ]
drwxr-xr-x
tc_act
[ DIR ]
drwxr-xr-x
6lowpan.h
10.03
KB
-rw-r--r--
Space.h
737
B
-rw-r--r--
act_api.h
8.42
KB
-rw-r--r--
addrconf.h
13.95
KB
-rw-r--r--
af_ieee802154.h
1.19
KB
-rw-r--r--
af_rxrpc.h
2.73
KB
-rw-r--r--
af_unix.h
2.92
KB
-rw-r--r--
af_vsock.h
7.37
KB
-rw-r--r--
ah.h
382
B
-rw-r--r--
arp.h
2.03
KB
-rw-r--r--
atmclip.h
1.48
KB
-rw-r--r--
ax25.h
14.84
KB
-rw-r--r--
ax88796.h
1.41
KB
-rw-r--r--
bareudp.h
572
B
-rw-r--r--
bond_3ad.h
9.49
KB
-rw-r--r--
bond_alb.h
6.09
KB
-rw-r--r--
bond_options.h
3.76
KB
-rw-r--r--
bonding.h
20.18
KB
-rw-r--r--
bpf_sk_storage.h
1.74
KB
-rw-r--r--
busy_poll.h
3.85
KB
-rw-r--r--
calipso.h
1.55
KB
-rw-r--r--
cfg80211-wext.h
1.81
KB
-rw-r--r--
cfg80211.h
291.42
KB
-rw-r--r--
cfg802154.h
10.5
KB
-rw-r--r--
checksum.h
4.74
KB
-rw-r--r--
cipso_ipv4.h
7.37
KB
-rw-r--r--
cls_cgroup.h
2.04
KB
-rw-r--r--
codel.h
5.65
KB
-rw-r--r--
codel_impl.h
7.98
KB
-rw-r--r--
codel_qdisc.h
2.9
KB
-rw-r--r--
compat.h
2.53
KB
-rw-r--r--
datalink.h
619
B
-rw-r--r--
dcbevent.h
742
B
-rw-r--r--
dcbnl.h
4.22
KB
-rw-r--r--
devlink.h
62.1
KB
-rw-r--r--
dn.h
6.88
KB
-rw-r--r--
dn_dev.h
5.36
KB
-rw-r--r--
dn_fib.h
3.99
KB
-rw-r--r--
dn_neigh.h
968
B
-rw-r--r--
dn_nsp.h
5.39
KB
-rw-r--r--
dn_route.h
3.96
KB
-rw-r--r--
dsa.h
34.12
KB
-rw-r--r--
dsfield.h
1.12
KB
-rw-r--r--
dst.h
14.46
KB
-rw-r--r--
dst_cache.h
2.96
KB
-rw-r--r--
dst_metadata.h
5.39
KB
-rw-r--r--
dst_ops.h
2.07
KB
-rw-r--r--
erspan.h
8.96
KB
-rw-r--r--
esp.h
1.23
KB
-rw-r--r--
espintcp.h
966
B
-rw-r--r--
ethoc.h
391
B
-rw-r--r--
failover.h
1.15
KB
-rw-r--r--
fib_notifier.h
1.35
KB
-rw-r--r--
fib_rules.h
6.3
KB
-rw-r--r--
firewire.h
636
B
-rw-r--r--
flow.h
5.53
KB
-rw-r--r--
flow_dissector.h
9.89
KB
-rw-r--r--
flow_offload.h
15.34
KB
-rw-r--r--
fou.h
549
B
-rw-r--r--
fq.h
2.47
KB
-rw-r--r--
fq_impl.h
7.89
KB
-rw-r--r--
garp.h
2.62
KB
-rw-r--r--
gen_stats.h
2.82
KB
-rw-r--r--
genetlink.h
13.32
KB
-rw-r--r--
geneve.h
1.85
KB
-rw-r--r--
gre.h
3.29
KB
-rw-r--r--
gro.h
783
B
-rw-r--r--
gro_cells.h
443
B
-rw-r--r--
gtp.h
633
B
-rw-r--r--
gue.h
3.24
KB
-rw-r--r--
hwbm.h
969
B
-rw-r--r--
icmp.h
1.87
KB
-rw-r--r--
ieee80211_radiotap.h
13.2
KB
-rw-r--r--
ieee802154_netdev.h
8.75
KB
-rw-r--r--
if_inet6.h
6.3
KB
-rw-r--r--
ife.h
1.03
KB
-rw-r--r--
ila.h
291
B
-rw-r--r--
inet6_connection_sock.h
765
B
-rw-r--r--
inet6_hashtables.h
3.44
KB
-rw-r--r--
inet_common.h
2.55
KB
-rw-r--r--
inet_connection_sock.h
11.06
KB
-rw-r--r--
inet_ecn.h
7.45
KB
-rw-r--r--
inet_frag.h
4.93
KB
-rw-r--r--
inet_hashtables.h
13.99
KB
-rw-r--r--
inet_sock.h
9.25
KB
-rw-r--r--
inet_timewait_sock.h
3.65
KB
-rw-r--r--
inetpeer.h
3.29
KB
-rw-r--r--
ioam6.h
1.17
KB
-rw-r--r--
ip.h
22.08
KB
-rw-r--r--
ip6_checksum.h
2.71
KB
-rw-r--r--
ip6_fib.h
15.82
KB
-rw-r--r--
ip6_route.h
9.99
KB
-rw-r--r--
ip6_tunnel.h
4.97
KB
-rw-r--r--
ip_fib.h
15.86
KB
-rw-r--r--
ip_tunnels.h
14.14
KB
-rw-r--r--
ip_vs.h
49.38
KB
-rw-r--r--
ipcomp.h
659
B
-rw-r--r--
ipconfig.h
811
B
-rw-r--r--
ipv6.h
35.34
KB
-rw-r--r--
ipv6_frag.h
3.28
KB
-rw-r--r--
ipv6_stubs.h
3.23
KB
-rw-r--r--
iw_handler.h
20.91
KB
-rw-r--r--
kcm.h
4.82
KB
-rw-r--r--
l3mdev.h
6.99
KB
-rw-r--r--
lag.h
409
B
-rw-r--r--
lapb.h
4.81
KB
-rw-r--r--
lib80211.h
3.92
KB
-rw-r--r--
llc.h
4.41
KB
-rw-r--r--
llc_c_ac.h
9.31
KB
-rw-r--r--
llc_c_ev.h
10.68
KB
-rw-r--r--
llc_c_st.h
1.72
KB
-rw-r--r--
llc_conn.h
4.06
KB
-rw-r--r--
llc_if.h
2.16
KB
-rw-r--r--
llc_pdu.h
14.44
KB
-rw-r--r--
llc_s_ac.h
1.55
KB
-rw-r--r--
llc_s_ev.h
2.2
KB
-rw-r--r--
llc_s_st.h
947
B
-rw-r--r--
llc_sap.h
1.08
KB
-rw-r--r--
lwtunnel.h
6.49
KB
-rw-r--r--
mac80211.h
266.84
KB
-rw-r--r--
mac802154.h
14.88
KB
-rw-r--r--
macsec.h
6.9
KB
-rw-r--r--
mctp.h
6.01
KB
-rw-r--r--
mctpdevice.h
735
B
-rw-r--r--
mip6.h
1016
B
-rw-r--r--
mld.h
2.85
KB
-rw-r--r--
mpls.h
943
B
-rw-r--r--
mpls_iptunnel.h
429
B
-rw-r--r--
mptcp.h
6.34
KB
-rw-r--r--
mrp.h
3.03
KB
-rw-r--r--
ncsi.h
1.92
KB
-rw-r--r--
ndisc.h
14.79
KB
-rw-r--r--
neighbour.h
15.97
KB
-rw-r--r--
net_failover.h
1023
B
-rw-r--r--
net_namespace.h
11.87
KB
-rw-r--r--
net_ratelimit.h
220
B
-rw-r--r--
netevent.h
1.02
KB
-rw-r--r--
netlabel.h
20.19
KB
-rw-r--r--
netlink.h
60.21
KB
-rw-r--r--
netprio_cgroup.h
1.02
KB
-rw-r--r--
netrom.h
7.71
KB
-rw-r--r--
nexthop.h
12.27
KB
-rw-r--r--
nl802154.h
12.09
KB
-rw-r--r--
nsh.h
12.31
KB
-rw-r--r--
p8022.h
447
B
-rw-r--r--
page_pool.h
8.88
KB
-rw-r--r--
pie.h
3.6
KB
-rw-r--r--
ping.h
2.9
KB
-rw-r--r--
pkt_cls.h
23.86
KB
-rw-r--r--
pkt_sched.h
5.37
KB
-rw-r--r--
pptp.h
557
B
-rw-r--r--
protocol.h
4
KB
-rw-r--r--
psample.h
1.06
KB
-rw-r--r--
psnap.h
351
B
-rw-r--r--
raw.h
2.08
KB
-rw-r--r--
rawv6.h
854
B
-rw-r--r--
red.h
11.38
KB
-rw-r--r--
regulatory.h
10.65
KB
-rw-r--r--
request_sock.h
6.47
KB
-rw-r--r--
rose.h
7.62
KB
-rw-r--r--
route.h
11.24
KB
-rw-r--r--
rpl.h
972
B
-rw-r--r--
rsi_91x.h
1.67
KB
-rw-r--r--
rtnetlink.h
6.72
KB
-rw-r--r--
rtnh.h
859
B
-rw-r--r--
sch_generic.h
33.86
KB
-rw-r--r--
scm.h
3.58
KB
-rw-r--r--
secure_seq.h
855
B
-rw-r--r--
seg6.h
2.18
KB
-rw-r--r--
seg6_hmac.h
1.44
KB
-rw-r--r--
seg6_local.h
644
B
-rw-r--r--
selftests.h
582
B
-rw-r--r--
slhc_vj.h
6.67
KB
-rw-r--r--
smc.h
2.45
KB
-rw-r--r--
snmp.h
5.14
KB
-rw-r--r--
sock.h
79.96
KB
-rw-r--r--
sock_reuseport.h
1.74
KB
-rw-r--r--
stp.h
383
B
-rw-r--r--
strparser.h
4.1
KB
-rw-r--r--
switchdev.h
13.96
KB
-rw-r--r--
tcp.h
71.78
KB
-rw-r--r--
tcp_states.h
1.2
KB
-rw-r--r--
timewait_sock.h
925
B
-rw-r--r--
tipc.h
2.35
KB
-rw-r--r--
tls.h
20.91
KB
-rw-r--r--
tls_toe.h
2.94
KB
-rw-r--r--
transp_v6.h
1.95
KB
-rw-r--r--
tso.h
566
B
-rw-r--r--
tun_proto.h
988
B
-rw-r--r--
udp.h
16.42
KB
-rw-r--r--
udp_tunnel.h
11.75
KB
-rw-r--r--
udplite.h
3.83
KB
-rw-r--r--
vsock_addr.h
662
B
-rw-r--r--
vxlan.h
13.91
KB
-rw-r--r--
wext.h
1.47
KB
-rw-r--r--
x25.h
9.49
KB
-rw-r--r--
x25device.h
387
B
-rw-r--r--
xdp.h
8.48
KB
-rw-r--r--
xdp_priv.h
446
B
-rw-r--r--
xdp_sock.h
2.04
KB
-rw-r--r--
xdp_sock_drv.h
5.53
KB
-rw-r--r--
xfrm.h
55.02
KB
-rw-r--r--
xsk_buff_pool.h
4.98
KB
-rw-r--r--
Delete
Unzip
Zip
${this.title}
Close
Code Editor : request_sock.h
/* SPDX-License-Identifier: GPL-2.0-or-later */ /* * NET Generic infrastructure for Network protocols. * * Definitions for request_sock * * Authors: Arnaldo Carvalho de Melo <acme@conectiva.com.br> * * From code originally in include/net/tcp.h */ #ifndef _REQUEST_SOCK_H #define _REQUEST_SOCK_H #include <linux/slab.h> #include <linux/spinlock.h> #include <linux/types.h> #include <linux/bug.h> #include <linux/refcount.h> #include <net/sock.h> struct request_sock; struct sk_buff; struct dst_entry; struct proto; struct request_sock_ops { int family; unsigned int obj_size; struct kmem_cache *slab; char *slab_name; int (*rtx_syn_ack)(const struct sock *sk, struct request_sock *req); void (*send_ack)(const struct sock *sk, struct sk_buff *skb, struct request_sock *req); void (*send_reset)(const struct sock *sk, struct sk_buff *skb); void (*destructor)(struct request_sock *req); void (*syn_ack_timeout)(const struct request_sock *req); }; int inet_rtx_syn_ack(const struct sock *parent, struct request_sock *req); struct saved_syn { u32 mac_hdrlen; u32 network_hdrlen; u32 tcp_hdrlen; u8 data[]; }; /* struct request_sock - mini sock to represent a connection request */ struct request_sock { struct sock_common __req_common; #define rsk_refcnt __req_common.skc_refcnt #define rsk_hash __req_common.skc_hash #define rsk_listener __req_common.skc_listener #define rsk_window_clamp __req_common.skc_window_clamp #define rsk_rcv_wnd __req_common.skc_rcv_wnd struct request_sock *dl_next; u16 mss; u8 num_retrans; /* number of retransmits */ u8 syncookie:1; /* syncookie: encode tcpopts in timestamp */ u8 num_timeout:7; /* number of timeouts */ u32 ts_recent; struct timer_list rsk_timer; const struct request_sock_ops *rsk_ops; struct sock *sk; struct saved_syn *saved_syn; u32 secid; u32 peer_secid; }; static inline struct request_sock *inet_reqsk(const struct sock *sk) { return (struct request_sock *)sk; } static inline struct sock *req_to_sk(struct request_sock *req) { return (struct sock *)req; } static inline struct request_sock * reqsk_alloc(const struct request_sock_ops *ops, struct sock *sk_listener, bool attach_listener) { struct request_sock *req; req = kmem_cache_alloc(ops->slab, GFP_ATOMIC | __GFP_NOWARN); if (!req) return NULL; req->rsk_listener = NULL; if (attach_listener) { if (unlikely(!refcount_inc_not_zero(&sk_listener->sk_refcnt))) { kmem_cache_free(ops->slab, req); return NULL; } req->rsk_listener = sk_listener; } req->rsk_ops = ops; req_to_sk(req)->sk_prot = sk_listener->sk_prot; sk_node_init(&req_to_sk(req)->sk_node); sk_tx_queue_clear(req_to_sk(req)); req->saved_syn = NULL; req->num_timeout = 0; req->num_retrans = 0; req->sk = NULL; refcount_set(&req->rsk_refcnt, 0); return req; } static inline void __reqsk_free(struct request_sock *req) { req->rsk_ops->destructor(req); if (req->rsk_listener) sock_put(req->rsk_listener); kfree(req->saved_syn); kmem_cache_free(req->rsk_ops->slab, req); } static inline void reqsk_free(struct request_sock *req) { WARN_ON_ONCE(refcount_read(&req->rsk_refcnt) != 0); __reqsk_free(req); } static inline void reqsk_put(struct request_sock *req) { if (refcount_dec_and_test(&req->rsk_refcnt)) reqsk_free(req); } /* * For a TCP Fast Open listener - * lock - protects the access to all the reqsk, which is co-owned by * the listener and the child socket. * qlen - pending TFO requests (still in TCP_SYN_RECV). * max_qlen - max TFO reqs allowed before TFO is disabled. * * XXX (TFO) - ideally these fields can be made as part of "listen_sock" * structure above. But there is some implementation difficulty due to * listen_sock being part of request_sock_queue hence will be freed when * a listener is stopped. But TFO related fields may continue to be * accessed even after a listener is closed, until its sk_refcnt drops * to 0 implying no more outstanding TFO reqs. One solution is to keep * listen_opt around until sk_refcnt drops to 0. But there is some other * complexity that needs to be resolved. E.g., a listener can be disabled * temporarily through shutdown()->tcp_disconnect(), and re-enabled later. */ struct fastopen_queue { struct request_sock *rskq_rst_head; /* Keep track of past TFO */ struct request_sock *rskq_rst_tail; /* requests that caused RST. * This is part of the defense * against spoofing attack. */ spinlock_t lock; int qlen; /* # of pending (TCP_SYN_RECV) reqs */ int max_qlen; /* != 0 iff TFO is currently enabled */ struct tcp_fastopen_context __rcu *ctx; /* cipher context for cookie */ }; /** struct request_sock_queue - queue of request_socks * * @rskq_accept_head - FIFO head of established children * @rskq_accept_tail - FIFO tail of established children * @rskq_defer_accept - User waits for some data after accept() * */ struct request_sock_queue { spinlock_t rskq_lock; u8 rskq_defer_accept; u32 synflood_warned; atomic_t qlen; atomic_t young; struct request_sock *rskq_accept_head; struct request_sock *rskq_accept_tail; struct fastopen_queue fastopenq; /* Check max_qlen != 0 to determine * if TFO is enabled. */ }; void reqsk_queue_alloc(struct request_sock_queue *queue); void reqsk_fastopen_remove(struct sock *sk, struct request_sock *req, bool reset); static inline bool reqsk_queue_empty(const struct request_sock_queue *queue) { return READ_ONCE(queue->rskq_accept_head) == NULL; } static inline struct request_sock *reqsk_queue_remove(struct request_sock_queue *queue, struct sock *parent) { struct request_sock *req; spin_lock_bh(&queue->rskq_lock); req = queue->rskq_accept_head; if (req) { sk_acceptq_removed(parent); WRITE_ONCE(queue->rskq_accept_head, req->dl_next); if (queue->rskq_accept_head == NULL) queue->rskq_accept_tail = NULL; } spin_unlock_bh(&queue->rskq_lock); return req; } static inline void reqsk_queue_removed(struct request_sock_queue *queue, const struct request_sock *req) { if (req->num_timeout == 0) atomic_dec(&queue->young); atomic_dec(&queue->qlen); } static inline void reqsk_queue_added(struct request_sock_queue *queue) { atomic_inc(&queue->young); atomic_inc(&queue->qlen); } static inline int reqsk_queue_len(const struct request_sock_queue *queue) { return atomic_read(&queue->qlen); } static inline int reqsk_queue_len_young(const struct request_sock_queue *queue) { return atomic_read(&queue->young); } #endif /* _REQUEST_SOCK_H */
Close