Received: by 10.223.176.5 with SMTP id f5csp679442wra; Tue, 30 Jan 2018 17:42:13 -0800 (PST) X-Google-Smtp-Source: AH8x224LY4Or8iPtgG5dEk9iUIXA3LudYVjMyX74GcXF24xV+a+brbii2qp7AqbVQ6gh+pB+Hr6K X-Received: by 2002:a17:902:2c83:: with SMTP id n3-v6mr2830921plb.227.1517362933866; Tue, 30 Jan 2018 17:42:13 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1517362933; cv=none; d=google.com; s=arc-20160816; b=Gw9+/eP2xg2ikDziqeS/Knk7WDFb/zOavJryUkHI8Hv9CrktlLP1LtrjfcrTjkK6O+ +loi6Iif9/ZCJt77SRF/BVq1ExP43QqL/o/t32e1nQk3z1EO0IZToSiHlqmfdgRhLAbS O5b+1EDEDQ3IjlEXsZHEc2sZDGkgidUPieA6ndvmUxZabnJUBNeTflyXgFtjqs5BnOiu UEXdN7mcQXqXhNsRdPATfyUq8Xp/IgMupg0cVYJAeEdzYWKJxO6HFxIwJRSe7gSDsHz1 0aLoVbJmIKtTsKJG8LGIl5wuT2kGHqgyq3YeCan4fe08pufvbszeUGwT2tw9VRY5iUse m2nA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :arc-authentication-results; bh=zLlXh4tCeThqtK4NIUVyo31m5Ns3u/fC8kF8f5TbCm4=; b=ZPvujK17lo5iBF9mXos/y/bPPzP9OywbpZZCav+XLESWiJ5m41iVNltVejS7uF75sG Qwng4aspPq+v5ukhry2AtFEZ6nkAAynI+SmpxTb5+nQaTqkEP67FtMJ5udraNWw02sBY lJz7l1xkmOuIO/w8S9Psejz+Jui2z5Tu7tGg09avkNut4X5DSW924fucVZsTdXyIl+d0 2GOkcP8OhxEwURaXP7XfgtjfnDAmOz8Xwu64AyALM27iarC+7f2zvXCgn/oDt97U7fkj 9xRJkdFoXDL5Wf5njnNPlmX9pVdBc6rIVS8+8AcrHxirM/FbBrnpbJ2UOcj42oOUs1Qp EfvQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-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 j26si757066pga.407.2018.01.30.17.41.59; Tue, 30 Jan 2018 17:42:13 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932097AbeA3X0g (ORCPT + 99 others); Tue, 30 Jan 2018 18:26:36 -0500 Received: from home.keithp.com ([63.227.221.253]:56006 "EHLO elaine.keithp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753338AbeA3X0f (ORCPT ); Tue, 30 Jan 2018 18:26:35 -0500 Received: from localhost (localhost [127.0.0.1]) by elaine.keithp.com (Postfix) with ESMTP id 15BC03F205E0; Tue, 30 Jan 2018 15:26:35 -0800 (PST) X-Virus-Scanned: Debian amavisd-new at keithp.com Received: from elaine.keithp.com ([127.0.0.1]) by localhost (elaine.keithp.com [127.0.0.1]) (amavisd-new, port 10024) with LMTP id f5ZZFR236frt; Tue, 30 Jan 2018 15:26:34 -0800 (PST) Received: from keithp.com (koto.keithp.com [10.0.0.2]) by elaine.keithp.com (Postfix) with ESMTPSA id 8D4A53F20299; Tue, 30 Jan 2018 15:26:34 -0800 (PST) Received: by keithp.com (Postfix, from userid 1000) id 600F51582869; Tue, 30 Jan 2018 15:26:34 -0800 (PST) From: Keith Packard To: linux-kernel@vger.kernel.org Cc: Keith Packard , Matt Mackall , Herbert Xu Subject: [PATCH] hwrng: Explicitly drop current_rng when unregistering rng device Date: Tue, 30 Jan 2018 15:26:27 -0800 Message-Id: <20180130232627.3014-1-keithp@keithp.com> X-Mailer: git-send-email 2.15.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org When the currently in-use hw rng is being removed from the system, explicitly drop it before using enable_best_rng as enable_best_rng will not do anything if the list of avaialble RNGs is empty. Without this, the last RNG removed from the system will never get cleaned up and hwrng_unregister will hang. Signed-off-by: Keith Packard --- drivers/char/hw_random/core.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/drivers/char/hw_random/core.c b/drivers/char/hw_random/core.c index 657b8770b6b9..8df3f9f147e2 100644 --- a/drivers/char/hw_random/core.c +++ b/drivers/char/hw_random/core.c @@ -515,8 +515,10 @@ void hwrng_unregister(struct hwrng *rng) mutex_lock(&rng_mutex); list_del(&rng->list); - if (current_rng == rng) + if (current_rng == rng) { + drop_current_rng(); enable_best_rng(); + } if (list_empty(&rng_list)) { mutex_unlock(&rng_mutex); -- 2.15.1