blob: 8ad8df5948536483c3467bff68ec0796b0712e67 [file] [log] [blame]
Thomas Gleixner2874c5f2019-05-27 08:55:01 +02001/* SPDX-License-Identifier: GPL-2.0-or-later */
Linus Torvalds1da177e2005-04-16 15:20:36 -07002/*
3 * INET An implementation of the TCP/IP protocol suite for the LINUX
4 * operating system. INET is implemented using the BSD Socket
5 * interface as the means of communication with the user level.
6 *
7 * Definitions for the RAW-IP module.
8 *
9 * Version: @(#)raw.h 1.0.2 05/07/93
10 *
11 * Author: Fred N. van Kempen, <waltje@uWalt.NL.Mugnet.ORG>
Linus Torvalds1da177e2005-04-16 15:20:36 -070012 */
13#ifndef _RAW_H
14#define _RAW_H
15
Duncan Eastoe70554202018-11-07 15:36:06 +000016#include <net/inet_sock.h>
Arnaldo Carvalho de Melo14c85022005-12-27 02:43:12 -020017#include <net/protocol.h>
Patrick McHardyf74e49b2010-04-13 05:03:18 +000018#include <linux/icmp.h>
Arnaldo Carvalho de Melo14c85022005-12-27 02:43:12 -020019
Linus Torvalds1da177e2005-04-16 15:20:36 -070020extern struct proto raw_prot;
21
Cyrill Gorcunov432490f2016-10-21 13:03:44 +030022extern struct raw_hashinfo raw_v4_hashinfo;
23struct sock *__raw_v4_lookup(struct net *net, struct sock *sk,
24 unsigned short num, __be32 raddr,
David Ahern67359932017-08-07 08:44:18 -070025 __be32 laddr, int dif, int sdif);
Cyrill Gorcunov432490f2016-10-21 13:03:44 +030026
27int raw_abort(struct sock *sk, int err);
Pavel Emelyanov7bc54c92007-11-19 22:35:07 -080028void raw_icmp_error(struct sk_buff *, int, u32);
29int raw_local_deliver(struct sk_buff *, int);
30
Joe Perches0ad6ad92013-09-22 10:32:19 -070031int raw_rcv(struct sock *, struct sk_buff *);
Linus Torvalds1da177e2005-04-16 15:20:36 -070032
Pavel Emelyanovb673e4d2007-11-19 22:36:45 -080033#define RAW_HTABLE_SIZE MAX_INET_PROTOS
34
35struct raw_hashinfo {
36 rwlock_t lock;
37 struct hlist_head ht[RAW_HTABLE_SIZE];
38};
39
Arnaldo Carvalho de Melo20380732005-08-16 02:18:02 -030040#ifdef CONFIG_PROC_FS
Joe Perches0ad6ad92013-09-22 10:32:19 -070041int raw_proc_init(void);
42void raw_proc_exit(void);
Pavel Emelyanov42a73802007-11-19 22:38:33 -080043
44struct raw_iter_state {
Pavel Emelyanovf51d5992008-01-14 05:35:57 -080045 struct seq_net_private p;
Pavel Emelyanov42a73802007-11-19 22:38:33 -080046 int bucket;
Pavel Emelyanov42a73802007-11-19 22:38:33 -080047};
48
Joe Perchese3634162010-09-07 05:55:38 +000049static inline struct raw_iter_state *raw_seq_private(struct seq_file *seq)
50{
51 return seq->private;
52}
Pavel Emelyanov42a73802007-11-19 22:38:33 -080053void *raw_seq_start(struct seq_file *seq, loff_t *pos);
54void *raw_seq_next(struct seq_file *seq, void *v, loff_t *pos);
55void raw_seq_stop(struct seq_file *seq, void *v);
Arnaldo Carvalho de Melo20380732005-08-16 02:18:02 -030056#endif
57
Craig Gallek086c6532016-02-10 11:50:35 -050058int raw_hash_sk(struct sock *sk);
Pavel Emelyanovfc8717b2008-03-22 16:56:51 -070059void raw_unhash_sk(struct sock *sk);
Mike Manning68974452018-11-07 15:36:05 +000060void raw_init(void);
Pavel Emelyanov65b4c502007-11-19 22:37:24 -080061
Patrick McHardyf74e49b2010-04-13 05:03:18 +000062struct raw_sock {
63 /* inet_sock has to be the first member */
64 struct inet_sock inet;
65 struct icmp_filter filter;
Patrick McHardyf0ad0862010-04-13 05:03:23 +000066 u32 ipmr_table;
Patrick McHardyf74e49b2010-04-13 05:03:18 +000067};
68
69static inline struct raw_sock *raw_sk(const struct sock *sk)
70{
71 return (struct raw_sock *)sk;
72}
73
Duncan Eastoe70554202018-11-07 15:36:06 +000074static inline bool raw_sk_bound_dev_eq(struct net *net, int bound_dev_if,
75 int dif, int sdif)
76{
77#if IS_ENABLED(CONFIG_NET_L3_MASTER_DEV)
78 return inet_bound_dev_eq(!!net->ipv4.sysctl_raw_l3mdev_accept,
79 bound_dev_if, dif, sdif);
80#else
81 return inet_bound_dev_eq(true, bound_dev_if, dif, sdif);
82#endif
83}
84
Linus Torvalds1da177e2005-04-16 15:20:36 -070085#endif /* _RAW_H */