Received: by 2002:a05:6a11:4021:0:0:0:0 with SMTP id ky33csp412572pxb; Wed, 15 Sep 2021 05:07:39 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy5GmU7P/GpZIIJnIRjwRFV+LY7aDCSDO5hFfFP9/LldtWVddR/AcEMeZofT5owHFdporHz X-Received: by 2002:a05:651c:1103:: with SMTP id d3mr19368854ljo.445.1631707659152; Wed, 15 Sep 2021 05:07:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1631707659; cv=none; d=google.com; s=arc-20160816; b=SZDkLwr/JSPRjQpN841KWjArGfXsG+fK7h3lj6CoLWRifjCQrnE7Eq8+CVZ27KYYH0 KaL//sgaPLH3AtDiKYY3Ws7PrW3Czz7j7v+AxhC8oQzvMBj7PaWJ0okWEereT/CbBxgr GH0NoOyxZ4CdOBQwJvS4fjTALoqWwkm/g7tGxlJEAD/2+DUiPvcYzxjx4/VOPJdMJ8bD +zwa9WUtq6AJNtxMncDzMRkk0btTZlCWvP4F/rw0k4j33t9IYldIWKwqWWY/9e3Evleb uEBbquUpXnSz2yRkJiMboLiqJ+jt2r7K8yQqlLG5gyy/OTYiaBQ2u6Bq4S5rbgNqhyS1 4iJw== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=zJ/G+uhDKnKmBBBqmYU+RVWsZ4psvl76j+mA50Q1hn4=; b=cu3KD8Kmo1htvVNEhtFqfHx2vBWtSUigcDXdGZkADUipjgAXZwkrD85JdcyGm10WKI mU3cMPXGoRlyVrxq+CeZmZG/J8jhy87TvJdeR0Gnb9R9SkN2Kf2ZIlAyCvh/pf6FeVTP SKP1/I9IJ30MW2ZZVTnytJqaCb6j/FXmbWxt3vPe/hbk4Hn5ATXX5QFzAB4I+Q9km55q cY35LyMLZCNn2EIgKj9SrvWVjPX26uZzBONK6vW0qWLx+oN/PIG8J4+3pu1NOfzfrQxg U3qn/BFaU3sUvxtRRyuxXhvbwn9Puzev4s9t5sGFIpqdHfxc/fscAWSzQfS5BQt18otC aRjQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=SfRBDjtL; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id l8si18335093ljb.239.2021.09.15.05.07.03; Wed, 15 Sep 2021 05:07:39 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=SfRBDjtL; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237678AbhIOMET (ORCPT + 99 others); Wed, 15 Sep 2021 08:04:19 -0400 Received: from fllv0016.ext.ti.com ([198.47.19.142]:55142 "EHLO fllv0016.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237623AbhIOMEO (ORCPT ); Wed, 15 Sep 2021 08:04:14 -0400 Received: from lelv0265.itg.ti.com ([10.180.67.224]) by fllv0016.ext.ti.com (8.15.2/8.15.2) with ESMTP id 18FC2ofe085397; Wed, 15 Sep 2021 07:02:50 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ti.com; s=ti-com-17Q1; t=1631707370; bh=zJ/G+uhDKnKmBBBqmYU+RVWsZ4psvl76j+mA50Q1hn4=; h=From:To:CC:Subject:Date:In-Reply-To:References; b=SfRBDjtL47GoCRgRMD1wy/5we2Fz4K6DaNrxpcXDS439lW5vqg1Yddz5/t8jliRW8 OuVgbSD93+KhAJjGj5Dv5kR5CauztAYSgV+Rd08XkNBsDBNON5yizVHhPejJwW1bdJ g+hJfANMSZW7MdjXjN/NEkIrobLLY3IK2Yl1bHlI= Received: from DLEE112.ent.ti.com (dlee112.ent.ti.com [157.170.170.23]) by lelv0265.itg.ti.com (8.15.2/8.15.2) with ESMTPS id 18FC2ovX068123 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=FAIL); Wed, 15 Sep 2021 07:02:50 -0500 Received: from DLEE107.ent.ti.com (157.170.170.37) by DLEE112.ent.ti.com (157.170.170.23) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.2308.14; Wed, 15 Sep 2021 07:02:49 -0500 Received: from lelv0326.itg.ti.com (10.180.67.84) by DLEE107.ent.ti.com (157.170.170.37) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.2308.14 via Frontend Transport; Wed, 15 Sep 2021 07:02:49 -0500 Received: from pratyush-OptiPlex-790.dhcp.ti.com (ileax41-snat.itg.ti.com [10.172.224.153]) by lelv0326.itg.ti.com (8.15.2/8.15.2) with ESMTP id 18FC2fD2019246; Wed, 15 Sep 2021 07:02:46 -0500 From: Pratyush Yadav To: Mauro Carvalho Chehab CC: Pratyush Yadav , Laurent Pinchart , Nikhil Devshatwar , Tomi Valkeinen , Vignesh Raghavendra , Benoit Parrot , Maxime Ripard , Rob Herring , Sakari Ailus , =?UTF-8?q?Niklas=20S=C3=B6derlund?= , , , Subject: [PATCH v4 01/11] media: cadence: csi2rx: Unregister v4l2 async notifier Date: Wed, 15 Sep 2021 17:32:30 +0530 Message-ID: <20210915120240.21572-2-p.yadav@ti.com> X-Mailer: git-send-email 2.33.0 In-Reply-To: <20210915120240.21572-1-p.yadav@ti.com> References: <20210915120240.21572-1-p.yadav@ti.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain X-EXCLAIMER-MD-CONFIG: e1e8a2fd-e40a-4ac6-ac9b-f7e9cc9ee180 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The notifier is added to the global notifier list when registered. When the module is removed, the struct csi2rx_priv in which the notifier is embedded, is destroyed. As a result the notifier list has a reference to a notifier that no longer exists. This causes invalid memory accesses when the list is iterated over. Similar for when the probe fails. Unregister and clean up the notifier to avoid this. Fixes: 1fc3b37f34f6 ("media: v4l: cadence: Add Cadence MIPI-CSI2 RX driver") Signed-off-by: Pratyush Yadav --- (no changes since v3) Changes in v3: - New in v3. drivers/media/platform/cadence/cdns-csi2rx.c | 3 +++ 1 file changed, 3 insertions(+) diff --git a/drivers/media/platform/cadence/cdns-csi2rx.c b/drivers/media/platform/cadence/cdns-csi2rx.c index 7b44ab2b8c9a..d60975f905d6 100644 --- a/drivers/media/platform/cadence/cdns-csi2rx.c +++ b/drivers/media/platform/cadence/cdns-csi2rx.c @@ -469,6 +469,7 @@ static int csi2rx_probe(struct platform_device *pdev) return 0; err_cleanup: + v4l2_async_nf_unregister(&csi2rx->notifier); v4l2_async_nf_cleanup(&csi2rx->notifier); err_free_priv: kfree(csi2rx); @@ -479,6 +480,8 @@ static int csi2rx_remove(struct platform_device *pdev) { struct csi2rx_priv *csi2rx = platform_get_drvdata(pdev); + v4l2_async_nf_unregister(&csi2rx->notifier); + v4l2_async_nf_cleanup(&csi2rx->notifier); v4l2_async_unregister_subdev(&csi2rx->subdev); kfree(csi2rx); -- 2.33.0