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