Received: by 2002:a25:e74b:0:0:0:0:0 with SMTP id e72csp1966307ybh; Tue, 14 Jul 2020 11:52:42 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz1g56yQcroFlAGRJ2Hf0YkxNCfDm1XLSkocYZn9xmvc6B0XOZ6q5rB3DGUZVWe0KytJ44o X-Received: by 2002:a17:906:ce51:: with SMTP id se17mr5667054ejb.503.1594752762190; Tue, 14 Jul 2020 11:52:42 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1594752762; cv=none; d=google.com; s=arc-20160816; b=Twz9Rg6wBLjDkgnH/PA+a3Min10OP+9hTzRa7LvDmQQ+no+nUN1QUFHLZeeGg0Sskp P1XFaqqMxxprbzRLdrZ/WAeNWi3E4k5AiZ7CimeMC1XmvHsKFCnChOS3fjiA5737ifDu hC2t3ZQqXcuANdDLEaXsz0wuFsFI/hy4MkAASQWJi48jgbdWsyAzP7Z8YEKmAVQwrVU0 ZtksIw6VHOURMZTWNWUTrRcePc87KG7lQokasHMAb8Xzg0SKHEWQg9+rheT/JHySvDFI YXolCXb8rn/GfaOIysmo8DV0wSGeeam14I+0TYFNV41kh53O5v0AQd4vKMSR7r8569d5 1Lzw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=LYZsODW+V4gnKflhyhRMpATsAr1lKilwzGTHZ54KFaY=; b=X36rJ3VPmSUh+pL8c9EKPgufmNg+EF6Xy/yRKJiA6X5/Z5lhNI9RQzmbZqbXUaisKd mEbpK9tSIMFVLqNsy0i3+NpY40menGAmMcnb9f4qWDNeWgs6spqwNPQRMasvk1SgRHVR bflHwUNfe/LHlfRp8RbRMQV9ny2t1xjgE9KVBuuNuRZ/ow2RWZN9JSb4aawhJM45CjJs MKVYK880ip/EZIBPPUoS8nsdtchM6B6DqU5IukeZXthv+rd8t4K5OanILGQmjyDCDa0F Wk0n/9z2TYpk4YYMb28RBnGS00z7UJ+b4JXsy8EHDFvT/GYfJnuEUjXQS1YfG+jxoHq+ ZAsw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=Jzjvsb0Z; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id qq26si11137765ejb.675.2020.07.14.11.52.19; Tue, 14 Jul 2020 11:52:42 -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=@kernel.org header.s=default header.b=Jzjvsb0Z; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729525AbgGNStH (ORCPT + 99 others); Tue, 14 Jul 2020 14:49:07 -0400 Received: from mail.kernel.org ([198.145.29.99]:44798 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730050AbgGNStF (ORCPT ); Tue, 14 Jul 2020 14:49:05 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id ECCCB22B2C; Tue, 14 Jul 2020 18:49:03 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1594752544; bh=bP4Svco64tcbNZ0VKLuxdblCqIX6tIwtPXqy85bho7I=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Jzjvsb0ZpVX4zzz3EQ8cx4EO9I4wjcEViTxWPz8z4+xJe7c94otudtWlyIoPK0HRw m4+FaM0YvNyh0OToFxPofNVDabCQMC62ltDtjzXft56Bl8wlts6eSyk+IZ8IZMfTvA 7lH2b6LAOm7ho4biYWt9a74kQYchWXSucSMXhKfI= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Sowjanya Komatineni , Thierry Reding , Sasha Levin Subject: [PATCH 5.4 010/109] gpu: host1x: Detach driver on unregister Date: Tue, 14 Jul 2020 20:43:13 +0200 Message-Id: <20200714184106.019140730@linuxfoundation.org> X-Mailer: git-send-email 2.27.0 In-Reply-To: <20200714184105.507384017@linuxfoundation.org> References: <20200714184105.507384017@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Thierry Reding [ Upstream commit d9a0a05bf8c76e6dc79230669a8b5d685b168c30 ] Currently when a host1x device driver is unregistered, it is not detached from the host1x controller, which means that the device will stay around and when the driver is registered again, it may bind to the old, stale device rather than the new one that was created from scratch upon driver registration. This in turn can cause various weird crashes within the driver core because it is confronted with a device that was already deleted. Fix this by detaching the driver from the host1x controller when it is unregistered. This ensures that the deleted device also is no longer present in the device list that drivers will bind to. Reported-by: Sowjanya Komatineni Signed-off-by: Thierry Reding Tested-by: Sowjanya Komatineni Signed-off-by: Thierry Reding Signed-off-by: Sasha Levin --- drivers/gpu/host1x/bus.c | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/drivers/gpu/host1x/bus.c b/drivers/gpu/host1x/bus.c index 742aa9ff21b87..fcda8621ae6f9 100644 --- a/drivers/gpu/host1x/bus.c +++ b/drivers/gpu/host1x/bus.c @@ -686,8 +686,17 @@ EXPORT_SYMBOL(host1x_driver_register_full); */ void host1x_driver_unregister(struct host1x_driver *driver) { + struct host1x *host1x; + driver_unregister(&driver->driver); + mutex_lock(&devices_lock); + + list_for_each_entry(host1x, &devices, list) + host1x_detach_driver(host1x, driver); + + mutex_unlock(&devices_lock); + mutex_lock(&drivers_lock); list_del_init(&driver->list); mutex_unlock(&drivers_lock); -- 2.25.1