Received: by 2002:a05:6358:45e:b0:b5:b6eb:e1f9 with SMTP id 30csp3409158rwe; Mon, 29 Aug 2022 11:05:39 -0700 (PDT) X-Google-Smtp-Source: AA6agR4oLA4zoT5HkiINtmvOR/6L2lxna60+M5+2nV3QrNA9mnYBURDnqnjgd++3iCQYuZKl87uN X-Received: by 2002:aa7:cfcb:0:b0:447:b4e5:22fb with SMTP id r11-20020aa7cfcb000000b00447b4e522fbmr16597915edy.190.1661796339368; Mon, 29 Aug 2022 11:05:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1661796339; cv=none; d=google.com; s=arc-20160816; b=oFG4pq8J29kWub6Bum6Tf4xS7mX7Od+n7INcGGJGz8HpNNJIeM7mrLLSNRXUiUg+wH uqxIcRNCfT73Xsa5oKYIHa/uKEHKufv7O38n1yXATeZYmqGm55L0OaFHkwi9Dka+JXAk e2JC+yfeiS4sld4d8wMLU0cXfFzziXR4caStm5jaLZYjKbBEIm/U5JU1cfqBh3Dh1lkS 5M+5bYxYY+e6iKNI5N03UcjMsiODreWQy4IXkrgNgj06B3J3SfKu8NIFgM2fq7y6gBMx V6fuInGnMvOmMaa103PKDPIOWcKs3mrSsYgkI+ERQg98sOeVPXsga8JxeY2oEVlLoFiN /oKg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=W9xLOeQ1DMWnZYzrDwRC4aH4WmIQ6ob1xqAQ9e7Axg0=; b=CLXM0CyMVdeaUlxEiFDUHqG6zcZMw2j1oRAgA3t3uh2bXTjQDlGNOSqqqWqokfVgSs PrEJO+TeEXsvuCibWvj3+9kY/E7dJNYuEb4y7b3H5V+pXavHkN7MF0ENBKfcluMOiZpt LI3dtgd8wwFR6F2HNn37exR3/Ux35DavKT45tQkpZX0pYCXEzopCgyr4RItRuvzb/aZo /tN8LMdmF3IhzAqWpy6MHl0zijEFUflLI46Q0Q7uPLTOKa+uZ2qq7rB7tWvwNekQWYfn WA367R1OWvTSvn9EpCLIhahI/Iuda5waZ+qZppL+9uly50X6AzRoxpHDAQ60h8zoEe0Y AHvQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@arista.com header.s=google header.b=bcN1eiKR; spf=pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-crypto-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=arista.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id sg33-20020a170907a42100b00741728e3521si3601776ejc.347.2022.08.29.11.04.47; Mon, 29 Aug 2022 11:05:39 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@arista.com header.s=google header.b=bcN1eiKR; spf=pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-crypto-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=arista.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229690AbiH2RzX (ORCPT + 99 others); Mon, 29 Aug 2022 13:55:23 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60488 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230122AbiH2RzV (ORCPT ); Mon, 29 Aug 2022 13:55:21 -0400 Received: from mail-wm1-x331.google.com (mail-wm1-x331.google.com [IPv6:2a00:1450:4864:20::331]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 98AF728E1D for ; Mon, 29 Aug 2022 10:55:17 -0700 (PDT) Received: by mail-wm1-x331.google.com with SMTP id s23so4613443wmj.4 for ; Mon, 29 Aug 2022 10:55:17 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arista.com; s=google; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:date:message-id :from:to:cc; bh=W9xLOeQ1DMWnZYzrDwRC4aH4WmIQ6ob1xqAQ9e7Axg0=; b=bcN1eiKRGwEvBCEr06wPOJLtNaLCmJqwTHiUX52Dsl4qFuL+YGXnQldOsR34jA55wa W/1jLpt2jaOEwvckra6O9rD7seIilIWa0LSc4T5oLIWwb6bAa1v8GVXykItPYzE4ySqR vJjhGJZ2vCXE6ZEPXkT7bGLQ30Nm/159nmMWIdm3jox4cPIHDHy3Pi6c4jYnGeJAwlzH dgNnWYW2lpqdo64nZPFlwLAlH+mVq0xnd4iBq/Uvwnxy3vjMLgKYEElqZ/RgvnKXJm6X NhjbnAwWlAZybe8NeDZ4dOIJxiSo6uxh8FHEvgzNwDv63pvJsxKpe2CTM89vL7VM1D+I Z1XQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:date:message-id :x-gm-message-state:from:to:cc; bh=W9xLOeQ1DMWnZYzrDwRC4aH4WmIQ6ob1xqAQ9e7Axg0=; b=ghPwud44+zvb1V6R7jOgm3C9l6NH0vTUU1IMrKu5buTeAP8m3HsBje/DII87lHneK/ /viUUYpLKcF88NrTfFy+TnEuBGY6S2zsUzcOcpxkHD2jc+XlQEOkoJdfrBN47yktNmf9 p6TlbJYSLN10s3Ws2r7t4oAt1XMwffe3s3dZG3rGNGkbwX/gSrsrya+JGJdIkmiQn9US 0imhTIR7kRdWUuuZLqIjcoj+ihjFST5V1NbHQ+l7ip93LZEtVeUFyMKaP2OgR+9gcqcx fILtJz+Rit2ncGBYaRphxtPCoSMYHEedfcMhCqA3XcsW8eX3QmyBf2XmNbIJB/vWbmnR HeQw== X-Gm-Message-State: ACgBeo3G+qhB/re3DQRnSqVQLA40t/B9M3RncYznJrmIHmCJn6uVTpnw q+mwf1yug6nJ0Dln5xuCwh8A0g== X-Received: by 2002:a05:600c:4f48:b0:3a5:e707:bb8c with SMTP id m8-20020a05600c4f4800b003a5e707bb8cmr7681257wmq.198.1661795715955; Mon, 29 Aug 2022 10:55:15 -0700 (PDT) Received: from [10.83.37.24] ([217.173.96.166]) by smtp.gmail.com with ESMTPSA id p9-20020a05600c23c900b003a6125562e1sm9444142wmb.46.2022.08.29.10.55.14 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Mon, 29 Aug 2022 10:55:15 -0700 (PDT) Message-ID: Date: Mon, 29 Aug 2022 18:55:03 +0100 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.12.0 Subject: Re: [kbuild] Re: [PATCH 11/31] net/tcp: Add TCP-AO sign to outgoing packets Content-Language: en-US To: Dan Carpenter , kbuild@lists.01.org, Eric Dumazet , "David S. Miller" , linux-kernel@vger.kernel.org Cc: lkp@intel.com, kbuild-all@lists.01.org, netdev@vger.kernel.org, Andy Lutomirski , Ard Biesheuvel , Bob Gilligan , David Ahern , Eric Biggers , Francesco Ruggeri , Herbert Xu , Hideaki YOSHIFUJI , Ivan Delalande , Jakub Kicinski , Leonard Crestez , Paolo Abeni , Salam Noureddine , Shuah Khan , linux-crypto@vger.kernel.org References: <202208221901.Fs6wW5Jd-lkp@intel.com> From: Dmitry Safonov In-Reply-To: <202208221901.Fs6wW5Jd-lkp@intel.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A, RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_NONE,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-crypto@vger.kernel.org Hi Dan, On 8/22/22 13:03, Dan Carpenter wrote: > Hi Dmitry, [..] > ea66758c1795cef Paolo Abeni 2022-05-04 608 static void tcp_options_write(struct tcphdr *th, struct tcp_sock *tp, [..] > 85df6b860d509a9 Dmitry Safonov 2022-08-18 622 #ifdef CONFIG_TCP_AO > 85df6b860d509a9 Dmitry Safonov 2022-08-18 623 if (unlikely(OPTION_AO & options)) { > 85df6b860d509a9 Dmitry Safonov 2022-08-18 624 u8 maclen; > 33ad798c924b4a1 Adam Langley 2008-07-19 625 > 85df6b860d509a9 Dmitry Safonov 2022-08-18 @626 if (tp) { > > Can "tp" really be NULL? Everything else assumes it can't. It actually can be NULL, see tcp_make_synack(). At this moment code assumes that *either* (tp == NULL) or (tcprsk == NULL). > 85df6b860d509a9 Dmitry Safonov 2022-08-18 627 struct tcp_ao_info *ao_info; > 85df6b860d509a9 Dmitry Safonov 2022-08-18 628 > 85df6b860d509a9 Dmitry Safonov 2022-08-18 629 ao_info = rcu_dereference_check(tp->ao_info, > 85df6b860d509a9 Dmitry Safonov 2022-08-18 630 lockdep_sock_is_held(&tp->inet_conn.icsk_inet.sk)); > 85df6b860d509a9 Dmitry Safonov 2022-08-18 631 if (WARN_ON_ONCE(!ao_key || !ao_info || !ao_info->rnext_key)) > 85df6b860d509a9 Dmitry Safonov 2022-08-18 632 goto out_ao; > 85df6b860d509a9 Dmitry Safonov 2022-08-18 633 maclen = tcp_ao_maclen(ao_key); > 85df6b860d509a9 Dmitry Safonov 2022-08-18 634 *ptr++ = htonl((TCPOPT_AO << 24) | > 85df6b860d509a9 Dmitry Safonov 2022-08-18 635 (tcp_ao_len(ao_key) << 16) | > 85df6b860d509a9 Dmitry Safonov 2022-08-18 636 (ao_key->sndid << 8) | > 85df6b860d509a9 Dmitry Safonov 2022-08-18 637 (ao_info->rnext_key->rcvid)); > 85df6b860d509a9 Dmitry Safonov 2022-08-18 638 } > > "maclen" not initialized on else path. Patch 15 ("net/tcp: Wire TCP-AO to request sockets") adds + if (tcprsk) { + u8 aolen = tcprsk->maclen + sizeof(struct tcp_ao_hdr); + + maclen = tcprsk->maclen; + *ptr++ = htonl((TCPOPT_AO << 24) | (aolen << 16) | + (tcprsk->ao_keyid << 8) | + (tcprsk->ao_rcv_next)); + } Assuming that tp != NULL OR tcprsk != NULL, maclen is always initialized _after both patches_. For version 2, I'll make it (break patches) in more bisect-able way for static analyzers and do WARN_ON(tp == NULL && tcprsk == NULL) with break off TCP-AO signing to make sure the assumption will be valid with the code changing later on. [..] > ea66758c1795cef Paolo Abeni 2022-05-04 731 mptcp_options_write(th, ptr, tp, opts); > ^^ > Not checked here either. The function has checks inside. Thanks, Dmitry