Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/net wg: Fix byte order on wire.



details:   https://anonhg.NetBSD.org/src/rev/9285789a9cf8
branches:  trunk
changeset: 1013595:9285789a9cf8
user:      riastradh <riastradh%NetBSD.org@localhost>
date:      Mon Aug 31 20:24:49 2020 +0000

description:
wg: Fix byte order on wire.

Give this a chance to work on big-endian systems.

diffstat:

 sys/net/if_wg.c |  49 +++++++++++++++++++++++++------------------------
 1 files changed, 25 insertions(+), 24 deletions(-)

diffs (197 lines):

diff -r a05da47117df -r 9285789a9cf8 sys/net/if_wg.c
--- a/sys/net/if_wg.c   Mon Aug 31 20:24:19 2020 +0000
+++ b/sys/net/if_wg.c   Mon Aug 31 20:24:49 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_wg.c,v 1.38 2020/08/31 20:24:19 riastradh Exp $     */
+/*     $NetBSD: if_wg.c,v 1.39 2020/08/31 20:24:49 riastradh Exp $     */
 
 /*
  * Copyright (C) Ryota Ozaki <ozaki.ryota%gmail.com@localhost>
@@ -41,7 +41,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_wg.c,v 1.38 2020/08/31 20:24:19 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_wg.c,v 1.39 2020/08/31 20:24:49 riastradh Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_inet.h"
@@ -1029,7 +1029,7 @@
        long long unsigned int outsize;
        int error __diagused;
 
-       memcpy(&nonce[4], &counter, sizeof(counter));
+       le64enc(&nonce[4], counter);
 
        error = crypto_aead_chacha20poly1305_ietf_encrypt(out, &outsize, plain,
            plainsize, auth, authlen, NULL, nonce, key);
@@ -1046,7 +1046,7 @@
        long long unsigned int outsize;
        int error;
 
-       memcpy(&nonce[4], &counter, sizeof(counter));
+       le64enc(&nonce[4], counter);
 
        error = crypto_aead_chacha20poly1305_ietf_decrypt(out, &outsize, NULL,
            encrypted, encryptedsize, auth, authlen, nonce, key);
@@ -1241,7 +1241,7 @@
        uint8_t pubkey[WG_EPHEMERAL_KEY_LEN];
        uint8_t privkey[WG_EPHEMERAL_KEY_LEN];
 
-       wgmi->wgmi_type = WG_MSG_TYPE_INIT;
+       wgmi->wgmi_type = htole32(WG_MSG_TYPE_INIT);
        wgmi->wgmi_sender = wg_assign_sender_index(wg, wgs);
 
        /* [W] 5.4.2: First Message: Initiator to Responder */
@@ -1657,7 +1657,7 @@
        memcpy(hash, wgs->wgs_handshake_hash, sizeof(hash));
        memcpy(ckey, wgs->wgs_chaining_key, sizeof(ckey));
 
-       wgmr->wgmr_type = WG_MSG_TYPE_RESP;
+       wgmr->wgmr_type = htole32(WG_MSG_TYPE_RESP);
        wgmr->wgmr_sender = wg_assign_sender_index(wg, wgs);
        wgmr->wgmr_receiver = wgmi->wgmi_sender;
 
@@ -1973,7 +1973,7 @@
        size_t addrlen;
        uint16_t uh_sport; /* be */
 
-       wgmc->wgmc_type = WG_MSG_TYPE_COOKIE;
+       wgmc->wgmc_type = htole32(WG_MSG_TYPE_COOKIE);
        wgmc->wgmc_receiver = sender;
        cprng_fast(wgmc->wgmc_salt, sizeof(wgmc->wgmc_salt));
 
@@ -2376,7 +2376,7 @@
        KASSERT(m->m_len >= sizeof(struct wg_msg_data));
        wgmd = mtod(m, struct wg_msg_data *);
 
-       KASSERT(wgmd->wgmd_type == WG_MSG_TYPE_DATA);
+       KASSERT(wgmd->wgmd_type == htole32(WG_MSG_TYPE_DATA));
        WG_TRACE("data");
 
        wgs = wg_lookup_session_by_index(wg, wgmd->wgmd_receiver, &psref);
@@ -2388,11 +2388,11 @@
        wgp = wgs->wgs_peer;
 
        error = sliwin_check_fast(&wgs->wgs_recvwin->window,
-           wgmd->wgmd_counter);
+           le64toh(wgmd->wgmd_counter));
        if (error) {
                WG_LOG_RATECHECK(&wgp->wgp_ppsratecheck, LOG_DEBUG,
                    "out-of-window packet: %"PRIu64"\n",
-                   wgmd->wgmd_counter);
+                   le64toh(wgmd->wgmd_counter));
                goto out;
        }
 
@@ -2438,7 +2438,7 @@
        WG_DLOG("mlen=%lu, encrypted_len=%lu\n", mlen, encrypted_len);
        error = wg_algo_aead_dec(decrypted_buf,
            encrypted_len - WG_AUTHTAG_LEN /* can be 0 */,
-           wgs->wgs_tkey_recv, wgmd->wgmd_counter, encrypted_buf,
+           wgs->wgs_tkey_recv, le64toh(wgmd->wgmd_counter), encrypted_buf,
            encrypted_len, NULL, 0);
        if (error != 0) {
                WG_LOG_RATECHECK(&wgp->wgp_ppsratecheck, LOG_DEBUG,
@@ -2450,12 +2450,12 @@
 
        mutex_enter(&wgs->wgs_recvwin->lock);
        error = sliwin_update(&wgs->wgs_recvwin->window,
-           wgmd->wgmd_counter);
+           le64toh(wgmd->wgmd_counter));
        mutex_exit(&wgs->wgs_recvwin->lock);
        if (error) {
                WG_LOG_RATECHECK(&wgp->wgp_ppsratecheck, LOG_DEBUG,
                    "replay or out-of-window packet: %"PRIu64"\n",
-                   wgmd->wgmd_counter);
+                   le64toh(wgmd->wgmd_counter));
                m_freem(n);
                goto out;
        }
@@ -2619,7 +2619,7 @@
         * worry about contiguity and alignment later.
         */
        m_copydata(m, 0, sizeof(wgm), &wgm);
-       switch (wgm.wgm_type) {
+       switch (le32toh(wgm.wgm_type)) {
        case WG_MSG_TYPE_INIT:
                msglen = sizeof(struct wg_msg_init);
                break;
@@ -2634,14 +2634,14 @@
                break;
        default:
                WG_LOG_RATECHECK(&wg->wg_ppsratecheck, LOG_DEBUG,
-                   "Unexpected msg type: %u\n", wgm.wgm_type);
+                   "Unexpected msg type: %u\n", le32toh(wgm.wgm_type));
                goto error;
        }
 
        /* Verify the mbuf chain is long enough for this type of message.  */
        if (__predict_false(mbuflen < msglen)) {
                WG_DLOG("Invalid msg size: mbuflen=%lu type=%u\n", mbuflen,
-                   wgm.wgm_type);
+                   le32toh(wgm.wgm_type));
                goto error;
        }
 
@@ -2671,7 +2671,7 @@
 
        KASSERT(m->m_len >= sizeof(struct wg_msg));
        wgm = mtod(m, struct wg_msg *);
-       switch (wgm->wgm_type) {
+       switch (le32toh(wgm->wgm_type)) {
        case WG_MSG_TYPE_INIT:
                wg_handle_msg_init(wg, (struct wg_msg_init *)wgm, src);
                break;
@@ -2686,7 +2686,7 @@
                /* wg_handle_msg_data frees m for us */
                return;
        default:
-               panic("invalid message type: %d", wgm->wgm_type);
+               panic("invalid message type: %d", le32toh(wgm->wgm_type));
        }
 
        m_freem(m);
@@ -2977,14 +2977,14 @@
         * worry about contiguity and alignment later.
         */
        m_copydata(m, offset, sizeof(struct wg_msg), &wgm);
-       WG_DLOG("type=%d\n", wgm.wgm_type);
+       WG_DLOG("type=%d\n", le32toh(wgm.wgm_type));
 
        /*
         * Handle DATA packets promptly as they arrive.  Other packets
         * may require expensive public-key crypto and are not as
         * sensitive to latency, so defer them to the worker thread.
         */
-       switch (wgm.wgm_type) {
+       switch (le32toh(wgm.wgm_type)) {
        case WG_MSG_TYPE_DATA:
                /* handle immediately */
                m_adj(m, offset);
@@ -3616,12 +3616,12 @@
 {
 
        memset(wgmd, 0, sizeof(*wgmd));
-       wgmd->wgmd_type = WG_MSG_TYPE_DATA;
+       wgmd->wgmd_type = htole32(WG_MSG_TYPE_DATA);
        wgmd->wgmd_receiver = wgs->wgs_receiver_index;
        /* [W] 5.4.6: msg.counter := Nm^send */
        /* [W] 5.4.6: Nm^send := Nm^send + 1 */
-       wgmd->wgmd_counter = wg_session_inc_send_counter(wgs);
-       WG_DLOG("counter=%"PRIu64"\n", wgmd->wgmd_counter);
+       wgmd->wgmd_counter = htole64(wg_session_inc_send_counter(wgs));
+       WG_DLOG("counter=%"PRIu64"\n", le64toh(wgmd->wgmd_counter));
 }
 
 static int
@@ -3792,7 +3792,8 @@
        wg_fill_msg_data(wg, wgp, wgs, wgmd);
        /* [W] 5.4.6: AEAD(Tm^send, Nm^send, P, e) */
        wg_algo_aead_enc((char *)wgmd + sizeof(*wgmd), encrypted_len,
-           wgs->wgs_tkey_send, wgmd->wgmd_counter, padded_buf, padded_len,
+           wgs->wgs_tkey_send, le64toh(wgmd->wgmd_counter),
+           padded_buf, padded_len,
            NULL, 0);
 
        error = wg->wg_ops->send_data_msg(wgp, n);



Home | Main Index | Thread Index | Old Index