send.c (13044B)
1// SPDX-License-Identifier: GPL-2.0 2/* 3 * Copyright (C) 2015-2019 Jason A. Donenfeld <Jason@zx2c4.com>. All Rights Reserved. 4 */ 5 6#include "queueing.h" 7#include "timers.h" 8#include "device.h" 9#include "peer.h" 10#include "socket.h" 11#include "messages.h" 12#include "cookie.h" 13 14#include <linux/uio.h> 15#include <linux/inetdevice.h> 16#include <linux/socket.h> 17#include <net/ip_tunnels.h> 18#include <net/udp.h> 19#include <net/sock.h> 20 21static void wg_packet_send_handshake_initiation(struct wg_peer *peer) 22{ 23 struct message_handshake_initiation packet; 24 25 if (!wg_birthdate_has_expired(atomic64_read(&peer->last_sent_handshake), 26 REKEY_TIMEOUT)) 27 return; /* This function is rate limited. */ 28 29 atomic64_set(&peer->last_sent_handshake, ktime_get_coarse_boottime_ns()); 30 net_dbg_ratelimited("%s: Sending handshake initiation to peer %llu (%pISpfsc)\n", 31 peer->device->dev->name, peer->internal_id, 32 &peer->endpoint.addr); 33 34 if (wg_noise_handshake_create_initiation(&packet, &peer->handshake)) { 35 wg_cookie_add_mac_to_packet(&packet, sizeof(packet), peer); 36 wg_timers_any_authenticated_packet_traversal(peer); 37 wg_timers_any_authenticated_packet_sent(peer); 38 atomic64_set(&peer->last_sent_handshake, 39 ktime_get_coarse_boottime_ns()); 40 wg_socket_send_buffer_to_peer(peer, &packet, sizeof(packet), 41 HANDSHAKE_DSCP); 42 wg_timers_handshake_initiated(peer); 43 } 44} 45 46void wg_packet_handshake_send_worker(struct work_struct *work) 47{ 48 struct wg_peer *peer = container_of(work, struct wg_peer, 49 transmit_handshake_work); 50 51 wg_packet_send_handshake_initiation(peer); 52 wg_peer_put(peer); 53} 54 55void wg_packet_send_queued_handshake_initiation(struct wg_peer *peer, 56 bool is_retry) 57{ 58 if (!is_retry) 59 peer->timer_handshake_attempts = 0; 60 61 rcu_read_lock_bh(); 62 /* We check last_sent_handshake here in addition to the actual function 63 * we're queueing up, so that we don't queue things if not strictly 64 * necessary: 65 */ 66 if (!wg_birthdate_has_expired(atomic64_read(&peer->last_sent_handshake), 67 REKEY_TIMEOUT) || 68 unlikely(READ_ONCE(peer->is_dead))) 69 goto out; 70 71 wg_peer_get(peer); 72 /* Queues up calling packet_send_queued_handshakes(peer), where we do a 73 * peer_put(peer) after: 74 */ 75 if (!queue_work(peer->device->handshake_send_wq, 76 &peer->transmit_handshake_work)) 77 /* If the work was already queued, we want to drop the 78 * extra reference: 79 */ 80 wg_peer_put(peer); 81out: 82 rcu_read_unlock_bh(); 83} 84 85void wg_packet_send_handshake_response(struct wg_peer *peer) 86{ 87 struct message_handshake_response packet; 88 89 atomic64_set(&peer->last_sent_handshake, ktime_get_coarse_boottime_ns()); 90 net_dbg_ratelimited("%s: Sending handshake response to peer %llu (%pISpfsc)\n", 91 peer->device->dev->name, peer->internal_id, 92 &peer->endpoint.addr); 93 94 if (wg_noise_handshake_create_response(&packet, &peer->handshake)) { 95 wg_cookie_add_mac_to_packet(&packet, sizeof(packet), peer); 96 if (wg_noise_handshake_begin_session(&peer->handshake, 97 &peer->keypairs)) { 98 wg_timers_session_derived(peer); 99 wg_timers_any_authenticated_packet_traversal(peer); 100 wg_timers_any_authenticated_packet_sent(peer); 101 atomic64_set(&peer->last_sent_handshake, 102 ktime_get_coarse_boottime_ns()); 103 wg_socket_send_buffer_to_peer(peer, &packet, 104 sizeof(packet), 105 HANDSHAKE_DSCP); 106 } 107 } 108} 109 110void wg_packet_send_handshake_cookie(struct wg_device *wg, 111 struct sk_buff *initiating_skb, 112 __le32 sender_index) 113{ 114 struct message_handshake_cookie packet; 115 116 net_dbg_skb_ratelimited("%s: Sending cookie response for denied handshake message for %pISpfsc\n", 117 wg->dev->name, initiating_skb); 118 wg_cookie_message_create(&packet, initiating_skb, sender_index, 119 &wg->cookie_checker); 120 wg_socket_send_buffer_as_reply_to_skb(wg, initiating_skb, &packet, 121 sizeof(packet)); 122} 123 124static void keep_key_fresh(struct wg_peer *peer) 125{ 126 struct noise_keypair *keypair; 127 bool send; 128 129 rcu_read_lock_bh(); 130 keypair = rcu_dereference_bh(peer->keypairs.current_keypair); 131 send = keypair && READ_ONCE(keypair->sending.is_valid) && 132 (atomic64_read(&keypair->sending_counter) > REKEY_AFTER_MESSAGES || 133 (keypair->i_am_the_initiator && 134 wg_birthdate_has_expired(keypair->sending.birthdate, REKEY_AFTER_TIME))); 135 rcu_read_unlock_bh(); 136 137 if (unlikely(send)) 138 wg_packet_send_queued_handshake_initiation(peer, false); 139} 140 141static unsigned int calculate_skb_padding(struct sk_buff *skb) 142{ 143 unsigned int padded_size, last_unit = skb->len; 144 145 if (unlikely(!PACKET_CB(skb)->mtu)) 146 return ALIGN(last_unit, MESSAGE_PADDING_MULTIPLE) - last_unit; 147 148 /* We do this modulo business with the MTU, just in case the networking 149 * layer gives us a packet that's bigger than the MTU. In that case, we 150 * wouldn't want the final subtraction to overflow in the case of the 151 * padded_size being clamped. Fortunately, that's very rarely the case, 152 * so we optimize for that not happening. 153 */ 154 if (unlikely(last_unit > PACKET_CB(skb)->mtu)) 155 last_unit %= PACKET_CB(skb)->mtu; 156 157 padded_size = min(PACKET_CB(skb)->mtu, 158 ALIGN(last_unit, MESSAGE_PADDING_MULTIPLE)); 159 return padded_size - last_unit; 160} 161 162static bool encrypt_packet(struct sk_buff *skb, struct noise_keypair *keypair) 163{ 164 unsigned int padding_len, plaintext_len, trailer_len; 165 struct scatterlist sg[MAX_SKB_FRAGS + 8]; 166 struct message_data *header; 167 struct sk_buff *trailer; 168 int num_frags; 169 170 /* Force hash calculation before encryption so that flow analysis is 171 * consistent over the inner packet. 172 */ 173 skb_get_hash(skb); 174 175 /* Calculate lengths. */ 176 padding_len = calculate_skb_padding(skb); 177 trailer_len = padding_len + noise_encrypted_len(0); 178 plaintext_len = skb->len + padding_len; 179 180 /* Expand data section to have room for padding and auth tag. */ 181 num_frags = skb_cow_data(skb, trailer_len, &trailer); 182 if (unlikely(num_frags < 0 || num_frags > ARRAY_SIZE(sg))) 183 return false; 184 185 /* Set the padding to zeros, and make sure it and the auth tag are part 186 * of the skb. 187 */ 188 memset(skb_tail_pointer(trailer), 0, padding_len); 189 190 /* Expand head section to have room for our header and the network 191 * stack's headers. 192 */ 193 if (unlikely(skb_cow_head(skb, DATA_PACKET_HEAD_ROOM) < 0)) 194 return false; 195 196 /* Finalize checksum calculation for the inner packet, if required. */ 197 if (unlikely(skb->ip_summed == CHECKSUM_PARTIAL && 198 skb_checksum_help(skb))) 199 return false; 200 201 /* Only after checksumming can we safely add on the padding at the end 202 * and the header. 203 */ 204 skb_set_inner_network_header(skb, 0); 205 header = (struct message_data *)skb_push(skb, sizeof(*header)); 206 header->header.type = cpu_to_le32(MESSAGE_DATA); 207 header->key_idx = keypair->remote_index; 208 header->counter = cpu_to_le64(PACKET_CB(skb)->nonce); 209 pskb_put(skb, trailer, trailer_len); 210 211 /* Now we can encrypt the scattergather segments */ 212 sg_init_table(sg, num_frags); 213 if (skb_to_sgvec(skb, sg, sizeof(struct message_data), 214 noise_encrypted_len(plaintext_len)) <= 0) 215 return false; 216 return chacha20poly1305_encrypt_sg_inplace(sg, plaintext_len, NULL, 0, 217 PACKET_CB(skb)->nonce, 218 keypair->sending.key); 219} 220 221void wg_packet_send_keepalive(struct wg_peer *peer) 222{ 223 struct sk_buff *skb; 224 225 if (skb_queue_empty(&peer->staged_packet_queue)) { 226 skb = alloc_skb(DATA_PACKET_HEAD_ROOM + MESSAGE_MINIMUM_LENGTH, 227 GFP_ATOMIC); 228 if (unlikely(!skb)) 229 return; 230 skb_reserve(skb, DATA_PACKET_HEAD_ROOM); 231 skb->dev = peer->device->dev; 232 PACKET_CB(skb)->mtu = skb->dev->mtu; 233 skb_queue_tail(&peer->staged_packet_queue, skb); 234 net_dbg_ratelimited("%s: Sending keepalive packet to peer %llu (%pISpfsc)\n", 235 peer->device->dev->name, peer->internal_id, 236 &peer->endpoint.addr); 237 } 238 239 wg_packet_send_staged_packets(peer); 240} 241 242static void wg_packet_create_data_done(struct wg_peer *peer, struct sk_buff *first) 243{ 244 struct sk_buff *skb, *next; 245 bool is_keepalive, data_sent = false; 246 247 wg_timers_any_authenticated_packet_traversal(peer); 248 wg_timers_any_authenticated_packet_sent(peer); 249 skb_list_walk_safe(first, skb, next) { 250 is_keepalive = skb->len == message_data_len(0); 251 if (likely(!wg_socket_send_skb_to_peer(peer, skb, 252 PACKET_CB(skb)->ds) && !is_keepalive)) 253 data_sent = true; 254 } 255 256 if (likely(data_sent)) 257 wg_timers_data_sent(peer); 258 259 keep_key_fresh(peer); 260} 261 262void wg_packet_tx_worker(struct work_struct *work) 263{ 264 struct wg_peer *peer = container_of(work, struct wg_peer, transmit_packet_work); 265 struct noise_keypair *keypair; 266 enum packet_state state; 267 struct sk_buff *first; 268 269 while ((first = wg_prev_queue_peek(&peer->tx_queue)) != NULL && 270 (state = atomic_read_acquire(&PACKET_CB(first)->state)) != 271 PACKET_STATE_UNCRYPTED) { 272 wg_prev_queue_drop_peeked(&peer->tx_queue); 273 keypair = PACKET_CB(first)->keypair; 274 275 if (likely(state == PACKET_STATE_CRYPTED)) 276 wg_packet_create_data_done(peer, first); 277 else 278 kfree_skb_list(first); 279 280 wg_noise_keypair_put(keypair, false); 281 wg_peer_put(peer); 282 if (need_resched()) 283 cond_resched(); 284 } 285} 286 287void wg_packet_encrypt_worker(struct work_struct *work) 288{ 289 struct crypt_queue *queue = container_of(work, struct multicore_worker, 290 work)->ptr; 291 struct sk_buff *first, *skb, *next; 292 293 while ((first = ptr_ring_consume_bh(&queue->ring)) != NULL) { 294 enum packet_state state = PACKET_STATE_CRYPTED; 295 296 skb_list_walk_safe(first, skb, next) { 297 if (likely(encrypt_packet(skb, 298 PACKET_CB(first)->keypair))) { 299 wg_reset_packet(skb, true); 300 } else { 301 state = PACKET_STATE_DEAD; 302 break; 303 } 304 } 305 wg_queue_enqueue_per_peer_tx(first, state); 306 if (need_resched()) 307 cond_resched(); 308 } 309} 310 311static void wg_packet_create_data(struct wg_peer *peer, struct sk_buff *first) 312{ 313 struct wg_device *wg = peer->device; 314 int ret = -EINVAL; 315 316 rcu_read_lock_bh(); 317 if (unlikely(READ_ONCE(peer->is_dead))) 318 goto err; 319 320 ret = wg_queue_enqueue_per_device_and_peer(&wg->encrypt_queue, &peer->tx_queue, first, 321 wg->packet_crypt_wq, &wg->encrypt_queue.last_cpu); 322 if (unlikely(ret == -EPIPE)) 323 wg_queue_enqueue_per_peer_tx(first, PACKET_STATE_DEAD); 324err: 325 rcu_read_unlock_bh(); 326 if (likely(!ret || ret == -EPIPE)) 327 return; 328 wg_noise_keypair_put(PACKET_CB(first)->keypair, false); 329 wg_peer_put(peer); 330 kfree_skb_list(first); 331} 332 333void wg_packet_purge_staged_packets(struct wg_peer *peer) 334{ 335 spin_lock_bh(&peer->staged_packet_queue.lock); 336 peer->device->dev->stats.tx_dropped += peer->staged_packet_queue.qlen; 337 __skb_queue_purge(&peer->staged_packet_queue); 338 spin_unlock_bh(&peer->staged_packet_queue.lock); 339} 340 341void wg_packet_send_staged_packets(struct wg_peer *peer) 342{ 343 struct noise_keypair *keypair; 344 struct sk_buff_head packets; 345 struct sk_buff *skb; 346 347 /* Steal the current queue into our local one. */ 348 __skb_queue_head_init(&packets); 349 spin_lock_bh(&peer->staged_packet_queue.lock); 350 skb_queue_splice_init(&peer->staged_packet_queue, &packets); 351 spin_unlock_bh(&peer->staged_packet_queue.lock); 352 if (unlikely(skb_queue_empty(&packets))) 353 return; 354 355 /* First we make sure we have a valid reference to a valid key. */ 356 rcu_read_lock_bh(); 357 keypair = wg_noise_keypair_get( 358 rcu_dereference_bh(peer->keypairs.current_keypair)); 359 rcu_read_unlock_bh(); 360 if (unlikely(!keypair)) 361 goto out_nokey; 362 if (unlikely(!READ_ONCE(keypair->sending.is_valid))) 363 goto out_nokey; 364 if (unlikely(wg_birthdate_has_expired(keypair->sending.birthdate, 365 REJECT_AFTER_TIME))) 366 goto out_invalid; 367 368 /* After we know we have a somewhat valid key, we now try to assign 369 * nonces to all of the packets in the queue. If we can't assign nonces 370 * for all of them, we just consider it a failure and wait for the next 371 * handshake. 372 */ 373 skb_queue_walk(&packets, skb) { 374 /* 0 for no outer TOS: no leak. TODO: at some later point, we 375 * might consider using flowi->tos as outer instead. 376 */ 377 PACKET_CB(skb)->ds = ip_tunnel_ecn_encap(0, ip_hdr(skb), skb); 378 PACKET_CB(skb)->nonce = 379 atomic64_inc_return(&keypair->sending_counter) - 1; 380 if (unlikely(PACKET_CB(skb)->nonce >= REJECT_AFTER_MESSAGES)) 381 goto out_invalid; 382 } 383 384 packets.prev->next = NULL; 385 wg_peer_get(keypair->entry.peer); 386 PACKET_CB(packets.next)->keypair = keypair; 387 wg_packet_create_data(peer, packets.next); 388 return; 389 390out_invalid: 391 WRITE_ONCE(keypair->sending.is_valid, false); 392out_nokey: 393 wg_noise_keypair_put(keypair, false); 394 395 /* We orphan the packets if we're waiting on a handshake, so that they 396 * don't block a socket's pool. 397 */ 398 skb_queue_walk(&packets, skb) 399 skb_orphan(skb); 400 /* Then we put them back on the top of the queue. We're not too 401 * concerned about accidentally getting things a little out of order if 402 * packets are being added really fast, because this queue is for before 403 * packets can even be sent and it's small anyway. 404 */ 405 spin_lock_bh(&peer->staged_packet_queue.lock); 406 skb_queue_splice(&packets, &peer->staged_packet_queue); 407 spin_unlock_bh(&peer->staged_packet_queue.lock); 408 409 /* If we're exiting because there's something wrong with the key, it 410 * means we should initiate a new handshake. 411 */ 412 wg_packet_send_queued_handshake_initiation(peer, false); 413}