Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp4926461ybi; Tue, 28 May 2019 04:58:01 -0700 (PDT) X-Google-Smtp-Source: APXvYqyOWIBpFJdcImkyeadDaQyXJWG2WVFlIHsL5qXUFtFOXRuANLbmyXCJHrex50VgaWmCKr2G X-Received: by 2002:a17:902:c7:: with SMTP id a65mr28758239pla.182.1559044681613; Tue, 28 May 2019 04:58:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1559044681; cv=none; d=google.com; s=arc-20160816; b=DTo+3dTHM5Zbx1BSGfRaHIOpZsRqk+9hgdpvR4fCpMZbt9UrKgbT/h2J90MGU/rH57 qDg6DCFqZpNRIIlntUIGpVPtsbSsS1AK/CygB4leBr2lc6/cchUueTkJXrHAzZ6LDUnA Vvu4phPmWRy5Ma3zEMt1MPWIygpO2tizc0x+2UEH1L+bdFtdahZxKHYyjzSX+FkzjYL6 8Scz71Xx2QDn1qtBmTZqcW7p6P59v+vYAixjrMS/qp/Tn0HrkaPrWzoWasUAV9MoW79n bYHaZGZDB8yoNyfa9s6Edo2XBdqBaCbKfH7UPfY2dnvxaM8wF0LETRXBTJhKzVIkbTnG sECg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:date:message-id:user-agent:cc:to :references:in-reply-to:from:subject:content-transfer-encoding :mime-version:dmarc-filter:dkim-signature:dkim-signature; bh=LjGr2u5W2cq/JfFaA01sza/FJOiRP3xa2aT6zVoCGyU=; b=jJqGYSCwSrxMSCgOxuZyXOVBu79sTtAXOq7cDvOA5B6qNLjL12c8TBELbYnwHjZbHw BzA/8s7X4SVZlHHuY/UQTHw9LByK0yAC2uUAdLtv+F8g6IGgo31g+OuikYdc/VmCxXfb OWGJoa9QSknOPkAm+xFnvP7SsGFlZHXQ8Stl9zdkr7k09hJHdvCUlT4FQJ/NC1nHXdQP T6k7EJHedQlA5B8pmQS4Lb+BOrOdishzFyffvYTTUjcBwy8hIqgZLxQVPM/7p8dyBt8U WOKrwR3P1YpIMeSUjo4jXWTATRLbOmo6LMfmd55Z66L1R5wMMMZVOvHGXaKTTpbdf3DC o2AA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=JUZBtdgJ; dkim=pass header.i=@codeaurora.org header.s=default header.b=WOvlO9Oi; spf=pass (google.com: best guess record for domain of linux-wireless-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id g8si3374871pjp.50.2019.05.28.04.57.45; Tue, 28 May 2019 04:58:01 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-wireless-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=JUZBtdgJ; dkim=pass header.i=@codeaurora.org header.s=default header.b=WOvlO9Oi; spf=pass (google.com: best guess record for domain of linux-wireless-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727058AbfE1Lz4 (ORCPT + 99 others); Tue, 28 May 2019 07:55:56 -0400 Received: from smtp.codeaurora.org ([198.145.29.96]:42538 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726809AbfE1Lz4 (ORCPT ); Tue, 28 May 2019 07:55:56 -0400 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id 301E760F3C; Tue, 28 May 2019 11:55:50 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1559044555; bh=k813bqE5/UfBXGr5ARK+Gx4QKOpZv/nuAkDg3b3jzBQ=; h=Subject:From:In-Reply-To:References:To:Cc:Date:From; b=JUZBtdgJYCs5pblKIc0RuQHtvm6TnBNEVhH8aoqE71dcShKITPGDsMnvnPPmPvHla LSWMrEhVGZdChMYtAZcoNU6PYY9OwM6UpZoqLKHS85MtGrrctE2H+Vl6d13GWSLfRK N1hVofqV4A4eBNF1OisaJKWSkL41tfN4nb7JjlSk= X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on pdx-caf-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-0.8 required=2.0 tests=ALL_TRUSTED,BAYES_00, DKIM_INVALID,DKIM_SIGNED,MISSING_DATE,MISSING_MID,SPF_NONE autolearn=no autolearn_force=no version=3.4.0 Received: from potku.adurom.net (88-114-240-156.elisa-laajakaista.fi [88.114.240.156]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) (Authenticated sender: kvalo@smtp.codeaurora.org) by smtp.codeaurora.org (Postfix) with ESMTPSA id 5FD3560EA5; Tue, 28 May 2019 11:55:48 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1559044550; bh=k813bqE5/UfBXGr5ARK+Gx4QKOpZv/nuAkDg3b3jzBQ=; h=Subject:From:In-Reply-To:References:To:Cc:From; b=WOvlO9OiVt/8dVWyeJQBAOLYO+j8JM2gLCQRAgk5U9cO7vYYd2hVBhSBDn8Yic4mP gLeREwi2xjWCnce+jNnmZU1EpjP7pLVFJ65dljaJ1re9TosnZampAEcLgvdHn4Tsc/ 0HF4c0DbiFI5ds0Qa6wLLVuGDWmuxq+Hh1ntp+Hk= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 5FD3560EA5 Authentication-Results: pdx-caf-mail.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: pdx-caf-mail.web.codeaurora.org; spf=none smtp.mailfrom=kvalo@codeaurora.org Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Subject: Re: [PATCH] rtlwifi: Fix null-pointer dereferences in error handling code of rtl_pci_probe() From: Kalle Valo In-Reply-To: <20190514123439.10524-1-baijiaju1990@gmail.com> References: <20190514123439.10524-1-baijiaju1990@gmail.com> To: Jia-Ju Bai Cc: pkshih@realtek.com, davem@davemloft.net, linux-wireless@vger.kernel.org, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, Jia-Ju Bai User-Agent: pwcli/0.0.0-git (https://github.com/kvalo/pwcli/) Python/2.7.12 Message-Id: <20190528115555.301E760F3C@smtp.codeaurora.org> Date: Tue, 28 May 2019 11:55:50 +0000 (UTC) Sender: linux-wireless-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org Jia-Ju Bai wrote: > *BUG 1: > In rtl_pci_probe(), when rtlpriv->cfg->ops->init_sw_vars() fails, > rtl_deinit_core() in the error handling code is executed. > rtl_deinit_core() calls rtl_free_entries_from_scan_list(), which uses > rtlpriv->scan_list.list in list_for_each_entry_safe(), but it has been > initialized. Thus a null-pointer dereference occurs. > The reason is that rtlpriv->scan_list.list is initialized by > INIT_LIST_HEAD() in rtl_init_core(), which has not been called. > > To fix this bug, rtl_deinit_core() should not be called when > rtlpriv->cfg->ops->init_sw_vars() fails. > > *BUG 2: > In rtl_pci_probe(), rtl_init_core() can fail when rtl_regd_init() in > this function fails, and rtlpriv->scan_list.list has not been > initialized by INIT_LIST_HEAD(). Then, rtl_deinit_core() in the error > handling code of rtl_pci_probe() is executed. Finally, a null-pointer > dereference occurs due to the same reason of the above bug. > > To fix this bug, the initialization of lists in rtl_init_core() are > performed before the call to rtl_regd_init(). > > These bugs are found by a runtime fuzzing tool named FIZZER written by > us. > > Signed-off-by: Jia-Ju Bai Ping & Larry, is this ok to take? -- https://patchwork.kernel.org/patch/10942971/ https://wireless.wiki.kernel.org/en/developers/documentation/submittingpatches