Received: by 2002:a25:e74b:0:0:0:0:0 with SMTP id e72csp1970445ybh; Tue, 14 Jul 2020 11:58:01 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyzSO8rsQneQ02EiWK5P6+pKSbJP4Q6p/ku9Ev8cXyI12q3/fSgZvTBAlPGibQyCguEZFws X-Received: by 2002:a17:906:e2ca:: with SMTP id gr10mr5700733ejb.81.1594753081668; Tue, 14 Jul 2020 11:58:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1594753081; cv=none; d=google.com; s=arc-20160816; b=eO3Q5jjXLM3cXVG8jui/PaPJZr1n0e72rXqOfJDkIm/cHzwjeKObq6pkrT/+9UoU3G L0CMvDdl03jmlcF9LhPhnzRENl97iUjPstC4fMQJhPYJcDSXs5jaklYS5BJDzFYs263H nrFmeWAmqThs42OIdnzAd1gD75vPyBKubJZoySQu54DbHfnPQnwaddGlB5Dv0q4rnqAK JRnd1d433cS/8QyLiMhbhWbm+bhE6/f4AecRu7R76tJV7siCJBgPzHuJ71JXCNQ3ALol LEJQUM5iykjyLsggOy1rG/6qC3xN+OxyhLRwNuE9vLad4SeuOMCp25kV7iZ51CjeewXY wA3A== 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=qeSv3rp3+XKxSUzCwW9hHhLyG2oQDwkksvSWVMT6wsM=; b=JVk76ESjbFvOI/xFPpLUPCwZ1/JwqnM9I2K46/fjmqUVkauQq3y2YaF0QU708n4ePa +6239+hMIxtCL8e6J1AZHMWkVOgVaTIVt77Beh8DZz0t+u19wYMVc2evNxAi/85gHTB2 6iornP69FZETDUdBF6IMDpbw4rhxOl6dtwYurp2QAcbNOtmufwKBaU9g2S0yojCMuu5j bR5p5Yrcm3zZudsb1BfZ3c4nUy3THO0k7Zn7IB2cpLwYraxHfzc5JDG2q2XoxeDNPtF5 JztfNFU1C0qU8x6iYdPqO5ZGrcGV3+BA9H7CtNPsw8TdvIR7zAfbZEQYTpYpiKbOP7HF 62JA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=nvuRXS1s; 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 y19si7437522ejw.454.2020.07.14.11.57.38; Tue, 14 Jul 2020 11:58:01 -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=nvuRXS1s; 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 S1730732AbgGNSyT (ORCPT + 99 others); Tue, 14 Jul 2020 14:54:19 -0400 Received: from mail.kernel.org ([198.145.29.99]:51692 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730740AbgGNSyR (ORCPT ); Tue, 14 Jul 2020 14:54:17 -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 B0C3722BEB; Tue, 14 Jul 2020 18:54:16 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1594752857; bh=G+uS8SYJDr3PJrz8oRLSBFYFdFUlrst1MS89HE8KMjQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=nvuRXS1sPIm6/7/cRsvwiy2HnSODQH6wopVv/vMAgozqXBii6l5/EflH9JTMqUUio u0wQsEBpIDveaqXa4wxiF1xQlVDQv6PmLEhf4oML+fbkmEaYgGQuK4I/xB0UM3oLFt +RcpdqzvXnFuX2LpuBRdrPcQCrMVa+IPLrSw8Qp0= 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.7 012/166] gpu: host1x: Detach driver on unregister Date: Tue, 14 Jul 2020 20:42:57 +0200 Message-Id: <20200714184116.483510926@linuxfoundation.org> X-Mailer: git-send-email 2.27.0 In-Reply-To: <20200714184115.844176932@linuxfoundation.org> References: <20200714184115.844176932@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 6a995db51d6d8..e201f62d62c0c 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