xref: /openbmc/linux/drivers/net/wireguard/device.h (revision af794a64)
1e7096c13SJason A. Donenfeld /* SPDX-License-Identifier: GPL-2.0 */
2e7096c13SJason A. Donenfeld /*
3e7096c13SJason A. Donenfeld  * Copyright (C) 2015-2019 Jason A. Donenfeld <Jason@zx2c4.com>. All Rights Reserved.
4e7096c13SJason A. Donenfeld  */
5e7096c13SJason A. Donenfeld 
6e7096c13SJason A. Donenfeld #ifndef _WG_DEVICE_H
7e7096c13SJason A. Donenfeld #define _WG_DEVICE_H
8e7096c13SJason A. Donenfeld 
9e7096c13SJason A. Donenfeld #include "noise.h"
10e7096c13SJason A. Donenfeld #include "allowedips.h"
11e7096c13SJason A. Donenfeld #include "peerlookup.h"
12e7096c13SJason A. Donenfeld #include "cookie.h"
13e7096c13SJason A. Donenfeld 
14e7096c13SJason A. Donenfeld #include <linux/types.h>
15e7096c13SJason A. Donenfeld #include <linux/netdevice.h>
16e7096c13SJason A. Donenfeld #include <linux/workqueue.h>
17e7096c13SJason A. Donenfeld #include <linux/mutex.h>
18e7096c13SJason A. Donenfeld #include <linux/net.h>
19e7096c13SJason A. Donenfeld #include <linux/ptr_ring.h>
20e7096c13SJason A. Donenfeld 
21e7096c13SJason A. Donenfeld struct wg_device;
22e7096c13SJason A. Donenfeld 
23e7096c13SJason A. Donenfeld struct multicore_worker {
24e7096c13SJason A. Donenfeld 	void *ptr;
25e7096c13SJason A. Donenfeld 	struct work_struct work;
26e7096c13SJason A. Donenfeld };
27e7096c13SJason A. Donenfeld 
28e7096c13SJason A. Donenfeld struct crypt_queue {
29e7096c13SJason A. Donenfeld 	struct ptr_ring ring;
30e7096c13SJason A. Donenfeld 	struct multicore_worker __percpu *worker;
31e7096c13SJason A. Donenfeld 	int last_cpu;
32e7096c13SJason A. Donenfeld };
338b5553acSJason A. Donenfeld 
348b5553acSJason A. Donenfeld struct prev_queue {
358b5553acSJason A. Donenfeld 	struct sk_buff *head, *tail, *peeked;
368b5553acSJason A. Donenfeld 	struct { struct sk_buff *next, *prev; } empty; // Match first 2 members of struct sk_buff.
378b5553acSJason A. Donenfeld 	atomic_t count;
38e7096c13SJason A. Donenfeld };
39e7096c13SJason A. Donenfeld 
40e7096c13SJason A. Donenfeld struct wg_device {
41e7096c13SJason A. Donenfeld 	struct net_device *dev;
42*af794a64SJason A. Donenfeld 	struct crypt_queue encrypt_queue, decrypt_queue, handshake_queue;
43e7096c13SJason A. Donenfeld 	struct sock __rcu *sock4, *sock6;
44900575aaSJason A. Donenfeld 	struct net __rcu *creating_net;
45e7096c13SJason A. Donenfeld 	struct noise_static_identity static_identity;
46*af794a64SJason A. Donenfeld 	struct workqueue_struct *packet_crypt_wq,*handshake_receive_wq, *handshake_send_wq;
47e7096c13SJason A. Donenfeld 	struct cookie_checker cookie_checker;
48e7096c13SJason A. Donenfeld 	struct pubkey_hashtable *peer_hashtable;
49e7096c13SJason A. Donenfeld 	struct index_hashtable *index_hashtable;
50e7096c13SJason A. Donenfeld 	struct allowedips peer_allowedips;
51e7096c13SJason A. Donenfeld 	struct mutex device_update_lock, socket_update_lock;
52e7096c13SJason A. Donenfeld 	struct list_head device_list, peer_list;
53*af794a64SJason A. Donenfeld 	atomic_t handshake_queue_len;
54e7096c13SJason A. Donenfeld 	unsigned int num_peers, device_update_gen;
55e7096c13SJason A. Donenfeld 	u32 fwmark;
56e7096c13SJason A. Donenfeld 	u16 incoming_port;
57e7096c13SJason A. Donenfeld };
58e7096c13SJason A. Donenfeld 
59e7096c13SJason A. Donenfeld int wg_device_init(void);
60e7096c13SJason A. Donenfeld void wg_device_uninit(void);
61e7096c13SJason A. Donenfeld 
62e7096c13SJason A. Donenfeld #endif /* _WG_DEVICE_H */
63