Received: by 2002:a05:6a10:6d10:0:0:0:0 with SMTP id gq16csp4794070pxb; Wed, 20 Apr 2022 10:08:12 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwx+zhT9W054U4UOa9JnVBNQS1MRqMP1LOX3LUCuqacP6B4qhAzhactnQlzFkfQOMKmbVo3 X-Received: by 2002:a05:6402:35c5:b0:423:e603:999b with SMTP id z5-20020a05640235c500b00423e603999bmr17310592edc.255.1650474492577; Wed, 20 Apr 2022 10:08:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1650474492; cv=none; d=google.com; s=arc-20160816; b=ruatLnuiue+PfsoNexrtxBpp6u5VKc5LkJHMhPV2FHoAV7en9rGjO27TgSISLB3KLA FPraU0va90F8h1qazdLS2VcbCKQj+wtZsY2FSOhxmPD4TJhoeDDYRPi0btuzdhQj0BIZ PsKeEk3SDAD80moDzNTFQlnRyaoewwePPuOg62+fKLlLRITTOVrU/zdp+fSdAghvIj6S ZzOeIFRkKUdesx6cdoWCMovNkfwNpWte9KL+7LwGHrwPd2wEvWEIxvGF2YN8b0ivnPX0 StVg7GHNpL+pOSr0QCvlDuASrgQRevAQ4EQwSC9/4mEhmYMNLLS0glvSraDR9c2yP4WN Ixng== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=gV7UtmajIQUducVZbRr5/Bay12YbRA1rsedm6F/j0xI=; b=xtIoiuOtFfgSlSgKm06tbkEFQCUZVNSjrwy0GbhEdVDlVubXEmx3udfD0O0AmQ3HNH HsF2LA8+0vOSZjK1sUJEHmuZyc7qK0dJfGsdqrhNcQ/IKQi7c+HmXNhv+L6XpObczIw2 vylyJ3NQ6c0gaUClcddKzVPorId/yojgS7444xGHQhA9fEfskZOUqe4VmM5jWLp3on5r hEUnfrpdPXROieXINphVBmMrMTNEC+fC8Zl/Vcgf36Q9n52nY7FzKKIdY6xrXf0KP/k4 qi1AxM5nOg1g/TKJna5v2/Jlj22MGM3pBvCCvThUAvF2cZgG5YLyzD1CdsouLvv+b/2s wLHg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=M0q72AcD; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id i19-20020a1709061e5300b006ee81f1754csi2325882ejj.882.2022.04.20.10.07.43; Wed, 20 Apr 2022 10:08:12 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-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=@chromium.org header.s=google header.b=M0q72AcD; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234533AbiDRXUk (ORCPT + 99 others); Mon, 18 Apr 2022 19:20:40 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39352 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234591AbiDRXUi (ORCPT ); Mon, 18 Apr 2022 19:20:38 -0400 Received: from mail-qt1-x831.google.com (mail-qt1-x831.google.com [IPv6:2607:f8b0:4864:20::831]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 63BB423BC8 for ; Mon, 18 Apr 2022 16:17:57 -0700 (PDT) Received: by mail-qt1-x831.google.com with SMTP id t2so11101141qtw.9 for ; Mon, 18 Apr 2022 16:17:57 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=gV7UtmajIQUducVZbRr5/Bay12YbRA1rsedm6F/j0xI=; b=M0q72AcD9jfg+dANbrjyHrlpiw+otlCPC3XzOhu55g0oelda3LhwCOxsI7RPsfE08t 3qog70rS3rB1uw2/b749YJpqemXtQmY72xz+nPXSqczpIr4rs/yRwh2WfcSXUpHqxzzo s/HLNq4ZtgOuiSICTaKPyOUcwceY7Lt7dvYh0= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=gV7UtmajIQUducVZbRr5/Bay12YbRA1rsedm6F/j0xI=; b=al1D5gQEsysF0+8vLqwWWbs1dBRMA17lv/1B29vzzqyvTqT7vt3dphoo6kKJDOk5+t ciAyA1UzRn5m9U9V9drW/XapijobrtFt231CDCbFaYFBFnJKhlB4WIFX4nEdsyvDi4DY wSQol/TXQxsQ17Htx9WqktHt5FuZ6eh12S4ahm8KqW8LQPazLapozbr9yXpopMdfBndv NFcgCD7RRVoSG41YtPvqdybQCO45kc2R9dimwNOPuBdcD5dwV0dsVcSD9KXk851DwcBD eQhsEYvU3IzY8/0jcE3dZ8MAnP/nHR5cMPgQK+zWZTu0fAnCQmOzVMhOR1HF27ZYn2OV xRuQ== X-Gm-Message-State: AOAM532p8X5jsuLBNaYQ+705vFWWpkpBpZJg4TYiI/wIV1wcJxfYq1gm 8XfnYu2ZsK06mbTF7IcLuJKK1g== X-Received: by 2002:ac8:5dca:0:b0:2f1:fcc6:d85a with SMTP id e10-20020ac85dca000000b002f1fcc6d85amr5238941qtx.72.1650323876585; Mon, 18 Apr 2022 16:17:56 -0700 (PDT) Received: from grundler-glapstation.lan ([70.134.62.80]) by smtp.gmail.com with ESMTPSA id a1-20020a05622a02c100b002f17cba4930sm8214048qtx.85.2022.04.18.16.17.54 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 18 Apr 2022 16:17:55 -0700 (PDT) From: Grant Grundler To: Igor Russkikh Cc: Jakub Kicinski , Paolo Abeni , netdev , "David S . Miller" , LKML , Aashay Shringarpure , Yi Chou , Shervin Oloumi , Grant Grundler Subject: [PATCH 0/5] net: atlantic: more fuzzing fixes Date: Mon, 18 Apr 2022 16:17:41 -0700 Message-Id: <20220418231746.2464800-1-grundler@chromium.org> X-Mailer: git-send-email 2.36.0.rc0.470.gd361397f0d-goog MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.7 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable 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-kernel@vger.kernel.org The Chrome OS fuzzing team posted a "Fuzzing" report for atlantic driver in Q4 2021 using Chrome OS v5.4 kernel and "Cable Matters Thunderbolt 3 to 10 Gb Ethernet" (b0 version): https://docs.google.com/document/d/e/2PACX-1vT4oCGNhhy_AuUqpu6NGnW0N9HF_jxf2kS7raOpOlNRqJNiTHAtjiHRthXYSeXIRTgfeVvsEt0qK9qK/pub It essentially describes four problems: 1) validate rxd_wb->next_desc_ptr before populating buff->next 2) "frag[0] not initialized" case in aq_ring_rx_clean() 3) limit iterations handling fragments in aq_ring_rx_clean() 4) validate hw_head_ in hw_atl_b0_hw_ring_tx_head_update() I've added one "clean up" contribution: "net: atlantic: reduce scope of is_rsc_complete" I tested the "original" patches using chromeos-v5.4 kernel branch: https://chromium-review.googlesource.com/q/hashtag:pcinet-atlantic-2022q1+(status:open%20OR%20status:merged) The fuzzing team will retest using the chromeos-v5.4 patches and the b0 HW. I've forward ported those patches to 5.18-rc2 and compiled them but am currently unable to test them on 5.18-rc2 kernel (logistics problems). I'm confident in all but the last patch: "net: atlantic: verify hw_head_ is reasonable" Please verify I'm not confusing how ring->sw_head and ring->sw_tail are used in hw_atl_b0_hw_ring_tx_head_update(). Credit largely goes to Chrome OS Fuzzing team members: Aashay Shringarpure, Yi Chou, Shervin Oloumi cheers, grant