Received: by 2002:a05:7412:b10a:b0:f3:1519:9f41 with SMTP id az10csp592389rdb; Thu, 30 Nov 2023 12:44:26 -0800 (PST) X-Google-Smtp-Source: AGHT+IH54Oz5bPJb16mclY6iO7oT+mc3/1Hl8yLKGpD00Dnv93V7iAyZPn+kOC7o3GVUasziroxd X-Received: by 2002:a17:902:ea84:b0:1cc:482c:bc54 with SMTP id x4-20020a170902ea8400b001cc482cbc54mr22528785plb.48.1701377066084; Thu, 30 Nov 2023 12:44:26 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1701377066; cv=none; d=google.com; s=arc-20160816; b=pO4ypyslbChfXxqSWk1DaCcx4xI2MS94dlcATklbf85RPBoLpzbAPJazD3d5lwr8bX Tq2mKx1qfGxWvhtM1WGv0wr1qu8WJVb0DAqDVC2p2YC0U7IhhL37lBtRSLvhUMm88NOr TZX+cO/Xh6YWsfgjnEW/2OTdu9XqewVDUUJYs8nuCjLimLoNWSibuitInLWN493ztQHi FADWy8+JgcgnB8YOWRJ9VMn1eeRqWs4ZGSMUvTMuUZMPasrGW+KJGEm6pYgJDe2UxxQ3 UDpOKA8PLZd7vJe8XS7mYVV2GU2wPUcIt+wjSebmzHeat4hj+3sM/Uu6qPTuIKBNdFf0 BG8g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=/0jU5xqycc0INc7xfvu25TUCTmwcIVLu+lTI0MHpfJc=; fh=g3kSv4WvKlMaeFENGH9vsQAEMHCdLvlnRC6We8RThxY=; b=Xc7gnOL4JlFBhKc+Mc4yvHUGkfQygifdxiEvyLGFhPV2BJY9gJnmp9Rop7n6gRLTeE H/JTFZO1u6gmbdj6rA6SmzkVAgyB+gHRpqghrVA8ab4g+37vEzY/thKOVlgGAZ6I1QVt rFFRRc3xCjrEa/7IKcDfA0ArszY6GHMmLLbxZLQ2P293cu3yRD0f52Qz/K2HewsfaBVQ +ojSzE6jUbuH0luVqTCXUtusReq42dJtjiZFMV9H23CtAJHqyh5bORMGBBusqKL0rRgB cyy7IV2pxaveNh6g4Y9OMYquJWcfepB7ztJ9MD6BtjFG5BnWYa22dF9An9xp1YKYwWhE WDfg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.33 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from lipwig.vger.email (lipwig.vger.email. [23.128.96.33]) by mx.google.com with ESMTPS id d14-20020a170902cece00b001d002bce0f8si2025826plg.0.2023.11.30.12.44.25 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 30 Nov 2023 12:44:26 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.33 as permitted sender) client-ip=23.128.96.33; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.33 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by lipwig.vger.email (Postfix) with ESMTP id 4F06C801C615; Thu, 30 Nov 2023 12:44:23 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at lipwig.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235287AbjK3UoD (ORCPT + 99 others); Thu, 30 Nov 2023 15:44:03 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47762 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1376770AbjK3Un7 (ORCPT ); Thu, 30 Nov 2023 15:43:59 -0500 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 15D711731; Thu, 30 Nov 2023 12:43:57 -0800 (PST) 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 5ED9F1042; Thu, 30 Nov 2023 12:44:43 -0800 (PST) Received: from usa.arm.com (e103737-lin.cambridge.arm.com [10.1.197.49]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id 617BF3F73F; Thu, 30 Nov 2023 12:43:55 -0800 (PST) From: Sudeep Holla To: linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org Cc: Sudeep Holla , quic_mdtipton@quicinc.com, quic_asartor@quicinc.com, quic_lingutla@quicinc.com, Sibi Sankar , linux-arm-msm@vger.kernel.org, Cristian Marussi Subject: [PATCH 1/2] firmware: arm_scmi: Fix frequency truncation by promoting multiplier to u64 Date: Thu, 30 Nov 2023 20:43:42 +0000 Message-ID: <20231130204343.503076-1-sudeep.holla@arm.com> X-Mailer: git-send-email 2.43.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-0.8 required=5.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lipwig.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (lipwig.vger.email [0.0.0.0]); Thu, 30 Nov 2023 12:44:23 -0800 (PST) Fix the frequency truncation for all values equal to or greater 4GHz by updating the multiplier 'mult_factor' to u64 type. It is also possible that the multiplier itself can be greater than or equal to 2^32. So we need to also fix the equation computing the value of the multiplier. Fixes: a9e3fbfaa0ff ("firmware: arm_scmi: add initial support for performance protocol") Reported-by: Sibi Sankar Closes: https://lore.kernel.org/all/20231129065748.19871-3-quic_sibis@quicinc.com/ Cc: Cristian Marussi Signed-off-by: Sudeep Holla --- drivers/firmware/arm_scmi/perf.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/drivers/firmware/arm_scmi/perf.c b/drivers/firmware/arm_scmi/perf.c index 81dd5c5e5533..8ce449922e55 100644 --- a/drivers/firmware/arm_scmi/perf.c +++ b/drivers/firmware/arm_scmi/perf.c @@ -152,7 +152,7 @@ struct perf_dom_info { u32 opp_count; u32 sustained_freq_khz; u32 sustained_perf_level; - u32 mult_factor; + u64 mult_factor; struct scmi_perf_domain_info info; struct scmi_opp opp[MAX_OPPS]; struct scmi_fc_info *fc_info; @@ -273,8 +273,8 @@ scmi_perf_domain_attributes_get(const struct scmi_protocol_handle *ph, dom_info->mult_factor = 1000; else dom_info->mult_factor = - (dom_info->sustained_freq_khz * 1000) / - dom_info->sustained_perf_level; + (dom_info->sustained_freq_khz * 1000UL) + / dom_info->sustained_perf_level; strscpy(dom_info->info.name, attr->name, SCMI_SHORT_NAME_MAX_SIZE); } -- 2.43.0