Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp2096875yba; Fri, 19 Apr 2019 12:04:08 -0700 (PDT) X-Google-Smtp-Source: APXvYqzr7dtZSXBQZK67UtpOMRxbfG9sM2ED9XkBNo1A1PFzUh9v9SAjzHBcGd99cSv4HMlQ5nSD X-Received: by 2002:a63:9246:: with SMTP id s6mr5483718pgn.316.1555700648391; Fri, 19 Apr 2019 12:04:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1555700648; cv=none; d=google.com; s=arc-20160816; b=rwp1BjOWodzGRuDXzX/eDHQXS5QTe7NmO6Fj7+2BA1AcUBIX8x5pU/kyQkOqRUEuxx YdPyuuETQVFKUSbwpibTee+YRsmAe3RVvq2qM+gH6bEEYEF7sCjXemJoGeM1CLMoU4d4 +g10fdLiU2NBSDTKyeSV170IUbNPhJGmyENON2C/zZaTl/oKP4ZYL6YrlrAGbUp4QwnS VcGjz8mmsbLbTCdSimS8YcuQwRbl/N9Q+Fl9m6/D/SN9M4kZImCZZMHCgM5qzvHOqj24 rEkAP2jt5BQbx6tgbk3dFd97nR3CEw/uvFB5T9gLEbuc3WJqrMhk/wDeK75RzfQRC1/l xadw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:to:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:references:cc:from:subject:dkim-signature; bh=e43rnkErijS0HX8VnoEMm69iTL9eHGIel9JB6xut5yQ=; b=yMPXSNDSz5pd0FOpFP+zglJh3pSIwgC9nBEeTsGuI10evY8iBDorq4uyr/YBoapB0R N/vs8CjGC+AuZrgFW9pYvzGhrXJQmTY7pGZfknBW5Czchj2ihZRrXoLb+kLIrS1fefRX EQYvUYYLG7LTlEWYgN5k6AVpyqLk9AyFnNhLRdAY44JM27zN2RefmrYsuT//vJ99cyl7 1kYBfoLGdZa5qHpnYoCNoGZUzZtCg0tybLhYLIaPrYhBDUNyU7LIMO2Yt9w1WUjB4IWi W5ODznmYt0+QYI2UmmtxxAQYi22oE4smXIXMrNJ1vE/PnmlM3mOahV5vf1OHJwtc2vlb kjKA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b="V/KTcZ4v"; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d24si5765389pls.271.2019.04.19.12.03.51; Fri, 19 Apr 2019 12:04:08 -0700 (PDT) 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; dkim=pass header.i=@gmail.com header.s=20161025 header.b="V/KTcZ4v"; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728901AbfDSTBz (ORCPT + 99 others); Fri, 19 Apr 2019 15:01:55 -0400 Received: from mail-wm1-f66.google.com ([209.85.128.66]:34043 "EHLO mail-wm1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726417AbfDSTBy (ORCPT ); Fri, 19 Apr 2019 15:01:54 -0400 Received: by mail-wm1-f66.google.com with SMTP id r186so9503643wmf.1; Fri, 19 Apr 2019 12:01:53 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:from:cc:references:message-id:date:user-agent:mime-version :in-reply-to:content-language:content-transfer-encoding; bh=e43rnkErijS0HX8VnoEMm69iTL9eHGIel9JB6xut5yQ=; b=V/KTcZ4vKIXT5VQdeglg+jbSYX3ZxI9SIuHRgsZYIQ9t4divxvjoMLyx5BHaR1t6q8 qEa56Jb0vXNydN//t2eQKRs/W1OSr07YKl4U04Jz0MOhlZV3W9bb4MdWIi9dKsdknJkY c1HLsBlRTYi7jB2ZbZLdnIPbWUdyFSCahB2zzoY1lxzAOscTsUiN9WyX/bihx/Kl3zyg uHlDNe3uU+6XO5Ytc3W5jfygr2mDLOYr1Tw0iiSJhq3BqtAqPyRISN6xD9NC2JsNPB5e Vjt49BAFzdHuiCe/SqNmL3wwBy5WX++YbBGxBE2gVJGHP0KqIDJy8O54HwuOkXNARfqb DUHQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:from:cc:references:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=e43rnkErijS0HX8VnoEMm69iTL9eHGIel9JB6xut5yQ=; b=C5Br/n1HII5G6sHowqtwnsjkysxEQdPXlIEPjL3EGanUKJomDsqBkoqgsDEj8AbYlv LAB2vldxuNJQwKPvFmJpjONOSliE5D5rqvltpffkE4Bv/58HEChUF7uZHEdaqPTt6DVt XhIsy1nSkFQQePo1dNY4NGdco2PcA7f5pixf4dvs+xaLNpcLn1n6tAQvyTFOvKnWlyXr jU98gKf7Xqmjf9sFw0R1+zUwQG+fBjf/Ll5epaUfGlvDEg6xIt+nO29CuMUHRnsVkQBF rB0oVo0/d/JoGkwrAEUxFJ40tdGmAdLrxDustjIP7Lfz5tk9ST8JqBBxiLI4Pr0VoPsq ohFg== X-Gm-Message-State: APjAAAUbmiOnbh9cQAyK0ugNQnevAH6asRO5twZax71DUjM08w9bcEoM hRG7WfXuVsMTZNQXfcRRQ3flbMma8l8= X-Received: by 2002:a05:600c:2293:: with SMTP id 19mr2011184wmf.77.1555668041719; Fri, 19 Apr 2019 03:00:41 -0700 (PDT) Received: from [192.168.20.141] ([194.99.104.18]) by smtp.gmail.com with ESMTPSA id r18sm7259631wme.18.2019.04.19.03.00.39 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Fri, 19 Apr 2019 03:00:41 -0700 (PDT) Subject: [PATCH v3 01/11] platform/x86: asus-wmi: Fix hwmon device cleanup From: Yurii Pavlovskyi Cc: Corentin Chary , Darren Hart , Andy Shevchenko , Daniel Drake , acpi4asus-user@lists.sourceforge.net, platform-driver-x86@vger.kernel.org, linux-kernel@vger.kernel.org References: <7acd57fe-604a-a96a-4ca2-a25bc88d6405@gmail.com> Message-ID: Date: Fri, 19 Apr 2019 12:00:39 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.6.1 MIME-Version: 1.0 In-Reply-To: <7acd57fe-604a-a96a-4ca2-a25bc88d6405@gmail.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit To: unlisted-recipients:; (no To-header on input) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The driver does not clean up the hwmon device on exit or error. To reproduce the bug, repeat rmmod, insmod to verify that device number /sys/devices/platform/asus-nb-wmi/hwmon/hwmon?? grows every time. Replace call for registering device with devm_* version that unregisters it automatically. Signed-off-by: Yurii Pavlovskyi --- drivers/platform/x86/asus-wmi.c | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/drivers/platform/x86/asus-wmi.c b/drivers/platform/x86/asus-wmi.c index ee1fa93708ec..d865eb95054c 100644 --- a/drivers/platform/x86/asus-wmi.c +++ b/drivers/platform/x86/asus-wmi.c @@ -1425,9 +1425,10 @@ static int asus_wmi_hwmon_init(struct asus_wmi *asus) { struct device *hwmon; - hwmon = hwmon_device_register_with_groups(&asus->platform_device->dev, - "asus", asus, - hwmon_attribute_groups); + hwmon = devm_hwmon_device_register_with_groups( + &asus->platform_device->dev, "asus", asus, + hwmon_attribute_groups); + if (IS_ERR(hwmon)) { pr_err("Could not register asus hwmon device\n"); return PTR_ERR(hwmon); -- 2.17.1