Loading...
1/* SPDX-License-Identifier: GPL-2.0 */
2#ifndef NET_COMPAT_H
3#define NET_COMPAT_H
4
5
6struct sock;
7
8#if defined(CONFIG_COMPAT)
9
10#include <linux/compat.h>
11
12struct compat_msghdr {
13 compat_uptr_t msg_name; /* void * */
14 compat_int_t msg_namelen;
15 compat_uptr_t msg_iov; /* struct compat_iovec * */
16 compat_size_t msg_iovlen;
17 compat_uptr_t msg_control; /* void * */
18 compat_size_t msg_controllen;
19 compat_uint_t msg_flags;
20};
21
22struct compat_mmsghdr {
23 struct compat_msghdr msg_hdr;
24 compat_uint_t msg_len;
25};
26
27struct compat_cmsghdr {
28 compat_size_t cmsg_len;
29 compat_int_t cmsg_level;
30 compat_int_t cmsg_type;
31};
32
33#else /* defined(CONFIG_COMPAT) */
34/*
35 * To avoid compiler warnings:
36 */
37#define compat_msghdr msghdr
38#define compat_mmsghdr mmsghdr
39#endif /* defined(CONFIG_COMPAT) */
40
41int get_compat_msghdr(struct msghdr *, struct compat_msghdr __user *,
42 struct sockaddr __user **, struct iovec **);
43struct sock_fprog __user *get_compat_bpf_fprog(char __user *optval);
44int put_cmsg_compat(struct msghdr*, int, int, int, void *);
45
46int cmsghdr_from_user_compat_to_kern(struct msghdr *, struct sock *,
47 unsigned char *, int);
48
49int compat_mc_setsockopt(struct sock *, int, int, char __user *, unsigned int,
50 int (*)(struct sock *, int, int, char __user *,
51 unsigned int));
52int compat_mc_getsockopt(struct sock *, int, int, char __user *, int __user *,
53 int (*)(struct sock *, int, int, char __user *,
54 int __user *));
55
56#endif /* NET_COMPAT_H */
1/* SPDX-License-Identifier: GPL-2.0 */
2#ifndef NET_COMPAT_H
3#define NET_COMPAT_H
4
5
6struct sock;
7
8#include <linux/compat.h>
9
10struct compat_msghdr {
11 compat_uptr_t msg_name; /* void * */
12 compat_int_t msg_namelen;
13 compat_uptr_t msg_iov; /* struct compat_iovec * */
14 compat_size_t msg_iovlen;
15 compat_uptr_t msg_control; /* void * */
16 compat_size_t msg_controllen;
17 compat_uint_t msg_flags;
18};
19
20struct compat_mmsghdr {
21 struct compat_msghdr msg_hdr;
22 compat_uint_t msg_len;
23};
24
25struct compat_cmsghdr {
26 compat_size_t cmsg_len;
27 compat_int_t cmsg_level;
28 compat_int_t cmsg_type;
29};
30
31struct compat_rtentry {
32 u32 rt_pad1;
33 struct sockaddr rt_dst; /* target address */
34 struct sockaddr rt_gateway; /* gateway addr (RTF_GATEWAY) */
35 struct sockaddr rt_genmask; /* target network mask (IP) */
36 unsigned short rt_flags;
37 short rt_pad2;
38 u32 rt_pad3;
39 unsigned char rt_tos;
40 unsigned char rt_class;
41 short rt_pad4;
42 short rt_metric; /* +1 for binary compatibility! */
43 compat_uptr_t rt_dev; /* forcing the device at add */
44 u32 rt_mtu; /* per route MTU/Window */
45 u32 rt_window; /* Window clamping */
46 unsigned short rt_irtt; /* Initial RTT */
47};
48
49int __get_compat_msghdr(struct msghdr *kmsg, struct compat_msghdr __user *umsg,
50 struct sockaddr __user **save_addr, compat_uptr_t *ptr,
51 compat_size_t *len);
52int get_compat_msghdr(struct msghdr *, struct compat_msghdr __user *,
53 struct sockaddr __user **, struct iovec **);
54int put_cmsg_compat(struct msghdr*, int, int, int, void *);
55
56int cmsghdr_from_user_compat_to_kern(struct msghdr *, struct sock *,
57 unsigned char *, int);
58
59struct compat_group_req {
60 __u32 gr_interface;
61 struct __kernel_sockaddr_storage gr_group
62 __aligned(4);
63} __packed;
64
65struct compat_group_source_req {
66 __u32 gsr_interface;
67 struct __kernel_sockaddr_storage gsr_group
68 __aligned(4);
69 struct __kernel_sockaddr_storage gsr_source
70 __aligned(4);
71} __packed;
72
73struct compat_group_filter {
74 __u32 gf_interface;
75 struct __kernel_sockaddr_storage gf_group
76 __aligned(4);
77 __u32 gf_fmode;
78 __u32 gf_numsrc;
79 struct __kernel_sockaddr_storage gf_slist[1]
80 __aligned(4);
81} __packed;
82
83#endif /* NET_COMPAT_H */