Received: by 2002:a05:7412:a9a8:b0:f9:92ae:e617 with SMTP id o40csp38320rdh; Wed, 20 Dec 2023 15:17:35 -0800 (PST) X-Google-Smtp-Source: AGHT+IGAeBebPJaFHtmBM3xda7H6lADYI2OD+VBu1maCzn1E0LZVTdH4RpE/e5CLgzSRk78z7vcR X-Received: by 2002:a05:622a:1b8b:b0:423:93d7:8078 with SMTP id bp11-20020a05622a1b8b00b0042393d78078mr21857746qtb.47.1703114255365; Wed, 20 Dec 2023 15:17:35 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1703114255; cv=none; d=google.com; s=arc-20160816; b=nrtdIaLKbR8A4MpRKJYooYvqX8aVF+Q2C0cvKt8j7w66v+5n8hKBYlZlRARiGRIG81 dKUEZniGPoOxUJpaQqX2/5z9DXE0BwZXuZPSyo1dyQTna+D+Wx2fKOqmSoLCsl+bYuQ2 O+l0RNnR5vPhuP89nIMIScwY6pNpmUs73v+pb2dzMQfF+/TNs/oRkqIQilOlIB0ofp3c JS9QebhsXZmUSApb6Qd/3N/6uKcISpfn8ykLR26BDm0e91eHvfJXQ5/KfBNCxdxq57gk ABTsnBbkArmk4TG9+n3LRHwmWbm+a/Ls3gYUCQXKRFsjFJd7+HssKF4hj002goc/JV8j rTPQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:in-reply-to:message-id :date:subject:cc:to:from; bh=vuRRxVe9sVJjVCKH96ozoj5wyhgpvD/0DQ+YXa9RHfI=; fh=BLXDRFxX5XTO46cEytehPgkEKhEpfPIIZAXbZsHkuJk=; b=mNuWz+kjTaYtyYg+Q5GGcAgpzIlAZzAI3zB3kKeUAjI6ZGEu+iADrGX0cVJq17c45P /8rINspnS4Q5gSMkD0F+dimLoDNQ9oBYgJWCmVT0mJ9bza2jJUE2uQYRzifVzcAJTeLQ qkzC8jibsYc5jAloI4JFZ517zQvHmKJzu2OXRNNFQU6JraKfHW+NphY8WB5mVqGiaBEf fwb3lCHJhPpiFuzUBFTs+dR2iRE7y+EFJPHvYsNAotz0ueRuzRa0cO/3BbC/gcpSY9gr /+pe82FDLWIISFCRRApqUJVcR6qS2dYCpwnlrYvz7OKqAhbBU1Qplr8t2WJtrxKMNM9F rbvg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel+bounces-7624-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-7624-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [2604:1380:45d1:ec00::1]) by mx.google.com with ESMTPS id d17-20020a05622a05d100b0042780bde4b2si711628qtb.666.2023.12.20.15.17.35 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 20 Dec 2023 15:17:35 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-7624-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) client-ip=2604:1380:45d1:ec00::1; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel+bounces-7624-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-7624-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ny.mirrors.kernel.org (Postfix) with ESMTPS id 26A061C24844 for ; Wed, 20 Dec 2023 23:17:35 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 583E24BA88; Wed, 20 Dec 2023 23:16:59 +0000 (UTC) X-Original-To: linux-kernel@vger.kernel.org Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 4AE674AF63; Wed, 20 Dec 2023 23:16:57 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=arm.com Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id A2CFC1515; Wed, 20 Dec 2023 15:17:41 -0800 (PST) Received: from e129166.arm.com (unknown [10.57.82.217]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id 737A03F64C; Wed, 20 Dec 2023 15:16:55 -0800 (PST) From: Lukasz Luba To: linux-kernel@vger.kernel.org, rafael@kernel.org Cc: linux-pm@vger.kernel.org, daniel.lezcano@linaro.org, rui.zhang@intel.com, lukasz.luba@arm.com Subject: [PATCH v3 2/9] thermal: gov_power_allocator: Refactor check_power_actors() Date: Wed, 20 Dec 2023 23:17:46 +0000 Message-Id: <20231220231753.1824364-3-lukasz.luba@arm.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20231220231753.1824364-1-lukasz.luba@arm.com> References: <20231220231753.1824364-1-lukasz.luba@arm.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit In preparation for a subsequent change, rearrange check_power_actors(). No intentional functional impact. Signed-off-by: Lukasz Luba --- drivers/thermal/gov_power_allocator.c | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/drivers/thermal/gov_power_allocator.c b/drivers/thermal/gov_power_allocator.c index 785fff14223d..d9175d9f5e3f 100644 --- a/drivers/thermal/gov_power_allocator.c +++ b/drivers/thermal/gov_power_allocator.c @@ -581,8 +581,9 @@ static void allow_maximum_power(struct thermal_zone_device *tz, bool update) * power actor API. The warning should help to investigate the issue, which * could be e.g. lack of Energy Model for a given device. * - * Return: 0 on success, -EINVAL if any cooling device does not implement - * the power actor API. + * If all of the cooling devices currently attached to @tz implement the power + * actor API, return the number of them (which may be 0, because some cooling + * devices may be attached later). Otherwise, return -EINVAL. */ static int check_power_actors(struct thermal_zone_device *tz, struct power_allocator_params *params) @@ -597,8 +598,9 @@ static int check_power_actors(struct thermal_zone_device *tz, if (!cdev_is_power_actor(instance->cdev)) { dev_warn(&tz->device, "power_allocator: %s is not a power actor\n", instance->cdev->type); - ret = -EINVAL; + return -EINVAL; } + ret++; } return ret; @@ -631,7 +633,7 @@ static int power_allocator_bind(struct thermal_zone_device *tz) } ret = check_power_actors(tz, params); - if (ret) { + if (ret < 0) { dev_warn(&tz->device, "power_allocator: binding failed\n"); kfree(params); return ret; -- 2.25.1