Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp10637847pxu; Wed, 30 Dec 2020 07:40:05 -0800 (PST) X-Google-Smtp-Source: ABdhPJxibgM8i2eF7tJpcqSU1AHarICoo2BUIrssGw3aHS5RphQQP17FCb+lFtvU5y+fDfnAVVaQ X-Received: by 2002:a05:6402:1d0f:: with SMTP id dg15mr43747541edb.1.1609342805678; Wed, 30 Dec 2020 07:40:05 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1609342805; cv=none; d=google.com; s=arc-20160816; b=II+uOFOfcPRrkw/JkdJAh198XhnXA1CWGXPw3Go7dFQt4/1dQRjMlhDAXHPSrLICil jY3+/adY6jPVQTzf4zohSdio4LdptpR3sg701nBSeoiLpj1EtpYuN7vVmaAZXvw4AzNe K6T/WHjCwr7l27RCSsJDUPLBKGWeVx/ra4yR0yvDvLov9drhJyhVhmDUL3NCFsil8IsD A8xOeOm4QAS4NHdJPiC+2oijhZ37I7j7qG9eTuQ61+lPItjFCZewEFYedLYe8SF4D7sf PiuWBW0mG6h/O/3v0X3vRss1qvUfu+q5nj/yzBbAixPt2YQmLgSBQmAvDq4KbsYs6cvJ YJ5A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from:dkim-signature; bh=t5qU0u0BbjyAf7ASokX3PDKEGwUdQpw6OEstGnrNo58=; b=mjTszd9KNsw4bzayJ9JYDyhiKCKfdhVKlCpxN/PE7SZwXibZE6MzDoY1Deej02ZBqt nj6fqJgpq0hAaZo12JEje09pSJ9zQjWUdjJpg+WnchMAsWqogelyoyySyr//SjW41sHd 0PqB7oJjB/Yt+fpBE0z+KF34of1dDfMlE8mdgKqxd8ZdHeEEHOMSuNGZ4jkZ0NezhgpG Jbs27h0Nc93gO5jTARq7HfG/PymsV/vSq7lAXM+FP4+xcCMwTICe8sqfUJdPMhDDXRn6 Oug6bpdWyflT3Fsk5ljz4cE+JPiQ0q1FCZts7hmx2gTvBzoRwX7rfK+rYoQ9FxrqXrpQ wrPw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=CN437dPV; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id di28si20635824edb.383.2020.12.30.07.39.43; Wed, 30 Dec 2020 07:40:05 -0800 (PST) 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=@linaro.org header.s=google header.b=CN437dPV; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726549AbgL3Pi5 (ORCPT + 99 others); Wed, 30 Dec 2020 10:38:57 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35772 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726500AbgL3Pi5 (ORCPT ); Wed, 30 Dec 2020 10:38:57 -0500 Received: from mail-wm1-x329.google.com (mail-wm1-x329.google.com [IPv6:2a00:1450:4864:20::329]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C8F16C06179C for ; Wed, 30 Dec 2020 07:38:16 -0800 (PST) Received: by mail-wm1-x329.google.com with SMTP id 3so5016176wmg.4 for ; Wed, 30 Dec 2020 07:38:16 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=t5qU0u0BbjyAf7ASokX3PDKEGwUdQpw6OEstGnrNo58=; b=CN437dPVzQo0tvO2u2a4Jee8cmUZkWsILIxPzYq/EoNcgHYmX8y3d7PWXku/qVwxRy Zbih/MHCKJ0s5zdvYyotn+sgkUAbn783RjApS1XoiEBHja3W0TkLhDNloVKFYYkBmZPu bVcCOIdNJMbJDfBeXs3wHJX3reDJ/A3syjLGnD4ylznyFGeKC+MoVy8YK4APmzXAjBuS 0bhWQJ3ohVhocsH0n4miWboYQILyBW2+Q/1yPdUqZRoLnu7Oxv4w/V8HvP9eJUXrlEoS SZml0TkX7+8HKCCONeQ51dWaKMKvDIxnFUWfQV7WtXsmlJz8yBd7fMn2d2wxfoRVGLPr 821g== 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:in-reply-to :references; bh=t5qU0u0BbjyAf7ASokX3PDKEGwUdQpw6OEstGnrNo58=; b=sfD7IRXXxo/EW6RF/vqrt3/GmTpbiteQgMwzC+1i7O3ay5Vd3NngwWsTda/y8hw8t+ N+Wtf76gikTpT8cuP8paQVGyHpE7oaUHosCeef90JQckSQ7Jyv0DpWTVM21gB9OMu53O VdnHPOuoC0tmF5IbEhh/NDFCLSAc+tRLPr2oofJ8mVoizgGJPyfI058HGqClC5Ry6moq YYWD4X1B7/3MmyygtQ8tua97meHScia4hVFS/UIe3T4NG13bKP4vZpmKrYVzGRp8nXic J59iUDB8WNJUzKpD4Iuz0hPzNojd1tBAXgPM9bSWqledzE7gkgGdZwZ3snsHnFO+OiWS 7pwg== X-Gm-Message-State: AOAM531yO92+AKUypQwfVQc33N+5m3ZhTjiXMzyrhzhGSqV6XiKj/5XQ F9qDkd+fIAWhmA8Zrv43rXvuIA== X-Received: by 2002:a05:600c:d8:: with SMTP id u24mr8094776wmm.103.1609342694387; Wed, 30 Dec 2020 07:38:14 -0800 (PST) Received: from localhost.localdomain (lns-bzn-59-82-252-148-164.adsl.proxad.net. [82.252.148.164]) by smtp.gmail.com with ESMTPSA id g191sm8634484wmg.39.2020.12.30.07.38.12 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 30 Dec 2020 07:38:13 -0800 (PST) From: Daniel Lezcano To: rafael@kernel.org Cc: linux-pm@vger.kernel.org, linux-acpi@vger.kernel.org, kernel test robot , "Rafael J. Wysocki" , linux-kernel@vger.kernel.org (open list) Subject: [PATCH] powercap/drivers/dtpm: Fix __udivdi3 and __aeabi_uldivmod unresolved symbols Date: Wed, 30 Dec 2020 16:37:44 +0100 Message-Id: <20201230153744.15612-1-daniel.lezcano@linaro.org> X-Mailer: git-send-email 2.17.1 In-Reply-To: References: Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 32 bits architectures do not support u64 division, so the macro DIV_ROUND_CLOSEST is not adequate as the compiler will replace the call to an unexisting function for the platform, leading to an unresolved symbols. Fix this by using the compatible macros: DIV64_U64_ROUND_CLOSEST and DIV_ROUND_CLOSEST_ULL. Reported-by: kernel test robot Signed-off-by: Daniel Lezcano --- drivers/powercap/dtpm.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/drivers/powercap/dtpm.c b/drivers/powercap/dtpm.c index 5b6857e9b064..0abcc439d728 100644 --- a/drivers/powercap/dtpm.c +++ b/drivers/powercap/dtpm.c @@ -99,8 +99,8 @@ static void __dtpm_rebalance_weight(struct dtpm *dtpm) pr_debug("Setting weight '%d' for '%s'\n", child->weight, child->zone.name); - child->weight = DIV_ROUND_CLOSEST(child->power_max * 1024, - dtpm->power_max); + child->weight = DIV64_U64_ROUND_CLOSEST( + child->power_max * 1024, dtpm->power_max); __dtpm_rebalance_weight(child); } @@ -272,7 +272,7 @@ static int __set_power_limit_uw(struct dtpm *dtpm, int cid, u64 power_limit) } else if (power_limit == dtpm->power_min) { power = child->power_min; } else { - power = DIV_ROUND_CLOSEST( + power = DIV_ROUND_CLOSEST_ULL( power_limit * child->weight, 1024); } -- 2.17.1