Received: by 2002:a25:6193:0:0:0:0:0 with SMTP id v141csp2090384ybb; Sat, 21 Mar 2020 12:32:56 -0700 (PDT) X-Google-Smtp-Source: ADFU+vvkIEJF98WpAix3htiXJ/r4gCJqe6cxT4uYuySundOtqDQxMB68Z9IteJfoeIYb0bV9sjzb X-Received: by 2002:a05:6830:110c:: with SMTP id w12mr11206901otq.175.1584819176611; Sat, 21 Mar 2020 12:32:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1584819176; cv=none; d=google.com; s=arc-20160816; b=boOJ7RZEjwxBBDE0szjF0gMm7x+1cimW2n4tG1yRdLMfwt6GthNfjKoaIroeuhtOW2 J9tLF9ell+79Y9EP31pHJaAWI5xZ4kggyKdtTEx/U153fQf6ahdmrfbvxw+kRWm6NB6h Ab1SCGKQUoGAv0SIDB8cLq2qd1M2RIJqjiyG736EY/Awi7Hl4Ik7ipvc8vbN/xjCtS5r aiS3rAlGHcEeZiQzTBDntTYL6xaWVTOuTrudUSDcYYI0uDaZAI7AaCfft3mBDX9jFCQx W0rg9tum2DuhZAcMPtwlCP17jrYMAU8lhAAmIPm3Hijy8Nb60NWG5S4Vsl9BdPcqDbbB EcjA== 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 :dkim-signature; bh=tAhMZYvG/G7C+UxGyPYY7dK/Sq4D4s4ohO0yGJZTXxY=; b=Mx7h7iFr7sKTZJs4mcjCWKrMWYyPKkg8/NPqs3DIwATfHsjFY5uV+ohNxF7P8pfNsl EoPxKdX3bhbVqtHfNj9O9DTaHgkgOosSK/5jTglxghK2by64pcjTBJm29VOUT36420Ea 7wOyPIIVAvU8+hG8LPPdEHkWZpB8AnfeyAUkz7fRa6IijMcaaI2mzCepT2BT4P2C0wXP 100787W6qJMKWJSlMljpfjdaHHUaUyEF4AHMYcVZRqnk20BCmPtIR1FRyCYfJ74/gOq7 yT7WJGHiXwem3bZKWf6htibr7C0lRDrgDRb4eNRCrqgbzym3ckn6ophVG6kxBS1iy58f 6+fQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=SFSkxNik; 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=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id a19si6342345otk.60.2020.03.21.12.32.44; Sat, 21 Mar 2020 12:32:56 -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=@linaro.org header.s=google header.b=SFSkxNik; 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=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727859AbgCUTbz (ORCPT + 99 others); Sat, 21 Mar 2020 15:31:55 -0400 Received: from mail-wr1-f66.google.com ([209.85.221.66]:37710 "EHLO mail-wr1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727296AbgCUTbz (ORCPT ); Sat, 21 Mar 2020 15:31:55 -0400 Received: by mail-wr1-f66.google.com with SMTP id w10so11654929wrm.4 for ; Sat, 21 Mar 2020 12:31:53 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id; bh=tAhMZYvG/G7C+UxGyPYY7dK/Sq4D4s4ohO0yGJZTXxY=; b=SFSkxNikzlUEPoZZkz9LGgx8W0ZYrakIf9SQ2cED+xBRql8xEffMwXkqluyb7PYY2D MrPKftWf9bd/BJV6ZAdi573Gp+F7dSKXAswYTRvUTubdzO6nIuYDgE4rVLNvsdMmbBn3 fGVuGxYINpcwDlYoZ9OBMMFny6gPsg9dqoFbqXwtQk8zTn7esFWJE6l2FGikN/AluTwT HjZLD27u0oiAwJlawipPVhVgrhaIQyVOoZOhawyJ2jGaqC1VoeeUiEWbc0DZWjtuR+N5 vPZwwKc6+7O9JFOZJUt010k8EM+Dj/BZqtkwhICSdbd8czvcrvktfcjMNQXz2gA/Rlbw 6gPA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=tAhMZYvG/G7C+UxGyPYY7dK/Sq4D4s4ohO0yGJZTXxY=; b=dhJlYXgsMU6hEwALbrigiyCbJ7C0aySudAbKCtq6OfYyihj12FQ1gXOdc5Exqd+7ue Yb8p9rdp4pnHlSdX/nLBrgq0/iAzMVxGcpJkQCP8aSiEoSCLMQWpBN3pkRaOWtdbyQf5 OlKxxcKTj0/7VeWn9DCsoGxGku9rNLzSm4I3YGiVdhBBHqhIdBh87r8HNLLTc81qMNfI PtGDOE7G5qYP5ycv18IuIn63c9U4BRnO5P/SWSmxNbqBelWQ2qe09rgKkHhz6wojuY0E YoT6l/tneN3zmN7f7M59xb3g09mq2+GoT/DH9ByJhMv+38g4CqpGdzOS9igK8H3dLjyK 3s3A== X-Gm-Message-State: ANhLgQ2dytXumqzQH8AKn+oZuF54QqpkVHem5sQtT7svQqDCi1CTPYaA 9THKfW0ISC3X/N5oktMxeLavGA== X-Received: by 2002:adf:f88b:: with SMTP id u11mr16031186wrp.84.1584819112216; Sat, 21 Mar 2020 12:31:52 -0700 (PDT) Received: from mai.imgcgcw.net ([2a01:e34:ed2f:f020:ca2:a5ed:e238:a0c0]) by smtp.gmail.com with ESMTPSA id n124sm8990714wma.11.2020.03.21.12.31.51 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 21 Mar 2020 12:31:51 -0700 (PDT) From: Daniel Lezcano To: daniel.lezcano@linaro.org Cc: Amit Daniel Kachhap , Viresh Kumar , Javi Merino , Zhang Rui , Amit Kucheria , linux-pm@vger.kernel.org (open list:THERMAL/CPU_COOLING), linux-kernel@vger.kernel.org (open list) Subject: [PATCH] thermal/drivers/cpufreq_cooling: Remove abusing WARN_ON Date: Sat, 21 Mar 2020 20:31:07 +0100 Message-Id: <20200321193107.21590-1-daniel.lezcano@linaro.org> X-Mailer: git-send-email 2.17.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The WARN_ON macros are used at the entry functions state2power() and set_cur_state(). state2power() is called with the max_state retrieved from get_max_state which returns cpufreq_cdev->max_level, then it check if max_state is > cpufreq_cdev->max_level. The test does not really makes sense but let's assume we want to make sure to catch an error if the code evolves. However the WARN_ON is overkill. set_cur_state() is also called from userspace if we write to the sysfs. It is easy to see a stack dumped by just writing to sysfs /sys/class/thermal/cooling_device0/cur_state a value greater than "max_level". A bit scary. Returing -EINVAL is enough. Remove these WARN_ON. Signed-off-by: Daniel Lezcano --- drivers/thermal/cpufreq_cooling.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/drivers/thermal/cpufreq_cooling.c b/drivers/thermal/cpufreq_cooling.c index af55ac08e1bd..d66791a71320 100644 --- a/drivers/thermal/cpufreq_cooling.c +++ b/drivers/thermal/cpufreq_cooling.c @@ -273,7 +273,7 @@ static int cpufreq_state2power(struct thermal_cooling_device *cdev, struct cpufreq_cooling_device *cpufreq_cdev = cdev->devdata; /* Request state should be less than max_level */ - if (WARN_ON(state > cpufreq_cdev->max_level)) + if (state > cpufreq_cdev->max_level) return -EINVAL; num_cpus = cpumask_weight(cpufreq_cdev->policy->cpus); @@ -434,7 +434,7 @@ static int cpufreq_set_cur_state(struct thermal_cooling_device *cdev, int ret; /* Request state should be less than max_level */ - if (WARN_ON(state > cpufreq_cdev->max_level)) + if (state > cpufreq_cdev->max_level) return -EINVAL; /* Check if the old cooling action is same as new cooling action */ -- 2.17.1