Received: by 2002:a05:7412:d8a:b0:e2:908c:2ebd with SMTP id b10csp147650rdg; Tue, 10 Oct 2023 06:44:39 -0700 (PDT) X-Google-Smtp-Source: AGHT+IEEbhn/AkrK5ZSAwOYHcgTrPEbXSRj98sfdB9nekoHjXADgSPHXmP4Ds/oe/DmF3p65TaV0 X-Received: by 2002:a05:6808:4442:b0:3af:c259:71e6 with SMTP id ep2-20020a056808444200b003afc25971e6mr15689526oib.5.1696945479484; Tue, 10 Oct 2023 06:44:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1696945479; cv=none; d=google.com; s=arc-20160816; b=1FHCgh8PN1i2eFOeiinHgHiRufcqWMjwpiPIMp0Fxe8FRb0yJYr+AfjzDg/lGE88wl wtOOcnlsqeyDJr58rz4ieEqr3TBAdaLomivuahPZ7PmJvP3GGAoDkZkSntRGAbe/gAC2 PwfXuRQTMNaz6zR0xbIBQG3sBDDtR4ISifuZzl/qmrtGXhpAbg09tPA94Jg8Kc6wyEtP syFNEgt3pGOJWjsM87TrHOVI4g8B4uqfvVkxBXucD27OAuprG/t1PgASNPYEec+RadtW lHfWooqY7IxxnzxJm/84n262Pz5rmM1vrzAAmRFt5gaWt+58MCPK+hwNhsmdQ5hlRL1l sq4w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=VPq482qd0uFnYCTndvvcH3roYJ83oyZMr/h7yZTA8GE=; fh=2jR+qv2rV7odPRmGsomrFlvHs+wcDmAWz818RwY8I6o=; b=L2NQ9fcHdvdkM3gjYKWRPP/7iljXwHy4xO/tNR6did5UEGosN0XJdrbC6hrj0rVRWX GAZW5gYDPuD4jhbwAjU/OZunR9cc6GuMI90j0M5mmss1jID3ny6h8hnFm46FygeW0qyN sFafCro58kKuSZRRiYzFH1TL89ubZRq/rhAfokTKhKemKdbYQJ7rE2NJYpo/hC+zEB0V meiZSAi0wHnohd+x4zqWcDNiirZ0aUlEsdyR6x/79CgmftLLMt8yZ0hGg/+AnDMyCdCV 2AArO/pf2NzZTON9Lym4Jx3dsTq+PnQKWVg4PSYOlXslLhVVIBxYeurxbRIXAdMTJkqu ZJlg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=BaJC1Lss; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 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 howler.vger.email (howler.vger.email. [23.128.96.34]) by mx.google.com with ESMTPS id c6-20020a633506000000b00584a4a5be67si12263705pga.520.2023.10.10.06.44.39 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 10 Oct 2023 06:44:39 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 as permitted sender) client-ip=23.128.96.34; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=BaJC1Lss; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by howler.vger.email (Postfix) with ESMTP id E597F8028204; Tue, 10 Oct 2023 06:44:20 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at howler.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232752AbjJJNmm (ORCPT + 99 others); Tue, 10 Oct 2023 09:42:42 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:37470 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232733AbjJJNlv (ORCPT ); Tue, 10 Oct 2023 09:41:51 -0400 Received: from mail-lj1-x233.google.com (mail-lj1-x233.google.com [IPv6:2a00:1450:4864:20::233]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7FB311731 for ; Tue, 10 Oct 2023 06:40:01 -0700 (PDT) Received: by mail-lj1-x233.google.com with SMTP id 38308e7fff4ca-2c2907ff9fcso70376411fa.1 for ; Tue, 10 Oct 2023 06:40:01 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; t=1696945200; x=1697550000; darn=vger.kernel.org; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:date:message-id :from:to:cc:subject:date:message-id:reply-to; bh=VPq482qd0uFnYCTndvvcH3roYJ83oyZMr/h7yZTA8GE=; b=BaJC1LssAglvkYG9wr0GE0RnmTYiGrcAWIq/3NFH0qtaoJ8Ko8qE9RvmdsNfI7+BTx BJ3Z8hsUw1KAgnzgDYmhP1l7h+op1QXg0ymy0/4lrht++TsiE2gFPxScEq2Q2sRg2OJu rZbH6W+sB7nRy7iF4A5g0Uwd9XY3O9MrXb/mcqP1WCdHR2Hr0igbWBF1QXJDUHZTEgNl bjPBiFA/P/yn8U638jrLCa1sGgsiz2OzR6YDh8hlE0JWVa/Un7UeNPiMHVNmfn95bRzJ 3jcSd3yxQlruRYRPHs1P/IW4ib4QvUN22HCmvBK3njhyyy7ldNC4U2Xw6+CB5rUrSppF ocMA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1696945200; x=1697550000; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:date:message-id :x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=VPq482qd0uFnYCTndvvcH3roYJ83oyZMr/h7yZTA8GE=; b=O93UE+0Rt1+mY203zeVeuq+OS5vSV71U9C5Ql4rD9fmaoALVsCpGSOa8Ht0YTr7lpr 0XERm7GzKCpx2EpKNBoKM+ynKMUfq4chjtmzDCAe7muaG9Yef+2ngoKSxid6ZtmtJFRQ vAuKWXceD4GrJShr+iRFnoR9IFrrvUUluEO+CUGFkfqdfD/575Zj442b4zVVDqD0J9qi e/D6OalATMHcEJ66Mp3SSBG4glyN8XI3/9kcTzaEy5noqUaF1ZJbIsLjUQ51Jy70WckQ 5low6Tjcincrvp84NGIa272PReEreYyae1edIep7uYy04LeWsYUfuRk1vLSTrTG01rFl 9Liw== X-Gm-Message-State: AOJu0YxTEq7amSlsbd95bwutFSQCJWo18IU1lZDZ+34KElwpYE+O9msJ Gd4P53Zb5nrQ8gzDOKuGvE87Ew== X-Received: by 2002:a2e:9805:0:b0:2c0:2b44:6eb7 with SMTP id a5-20020a2e9805000000b002c02b446eb7mr15831807ljj.35.1696945199692; Tue, 10 Oct 2023 06:39:59 -0700 (PDT) Received: from [172.30.204.192] (UNUSED.212-182-62-129.lubman.net.pl. [212.182.62.129]) by smtp.gmail.com with ESMTPSA id y9-20020a2e3209000000b002b9b9fd0f92sm2348720ljy.105.2023.10.10.06.39.56 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Tue, 10 Oct 2023 06:39:58 -0700 (PDT) Message-ID: <5b57e0e0-490e-464d-bdc8-5823ad8da2d8@linaro.org> Date: Tue, 10 Oct 2023 15:39:54 +0200 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH v5 3/4] cpufreq: qcom-nvmem: add support for IPQ8064 Content-Language: en-US To: Robert Marko , ilia.lin@kernel.org, vireshk@kernel.org, nm@ti.com, sboyd@kernel.org, robh+dt@kernel.org, krzysztof.kozlowski+dt@linaro.org, conor+dt@kernel.org, agross@kernel.org, andersson@kernel.org, rafael@kernel.org, linux-pm@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-msm@vger.kernel.org Cc: Christian Marangi References: <20230930102218.229613-1-robimarko@gmail.com> <20230930102218.229613-3-robimarko@gmail.com> From: Konrad Dybcio In-Reply-To: <20230930102218.229613-3-robimarko@gmail.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=2.7 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, RCVD_IN_SBL_CSS,SPF_HELO_NONE,SPF_PASS autolearn=no autolearn_force=no version=3.4.6 X-Spam-Level: ** X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on howler.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 (howler.vger.email [0.0.0.0]); Tue, 10 Oct 2023 06:44:21 -0700 (PDT) On 9/30/23 12:21, Robert Marko wrote: > From: Christian Marangi > > IPQ8064 comes in 3 families: > * IPQ8062 up to 1.0GHz > * IPQ8064/IPQ8066/IPQ8068 up to 1.4GHz > * IPQ8065/IPQ8069 up to 1.7Ghz > > So, in order to be able to support one OPP table, add support for > IPQ8064 family based of SMEM SoC ID-s and correctly set the version so > opp-supported-hw can be correctly used. > > Bit are set with the following logic: > * IPQ8062 BIT 0 > * IPQ8064/IPQ8066/IPQ8068 BIT 1 > * IPQ8065/IPQ8069 BIT 2 > > speed is never fused, only pvs values are fused. > > IPQ806x SoC doesn't have pvs_version so we drop and we use the new > pattern: > opp-microvolt-speed0-pvs > > Example: > - for ipq8062 psv2 > opp-microvolt-speed0-pvs2 = < 925000 878750 971250> > > Signed-off-by: Christian Marangi > Signed-off-by: Robert Marko > --- [...] > +{ > + int speed = 0, pvs = 0, pvs_ver = 0; > + int msm_id, ret = 0; > + u8 *speedbin; > + size_t len; > + > + speedbin = nvmem_cell_read(speedbin_nvmem, &len); > + > + if (IS_ERR(speedbin)) The stray newline above this line triggers my OCD :D > + return PTR_ERR(speedbin); > + > + if (len != 4) { > + dev_err(cpu_dev, "Unable to read nvmem data. Defaulting to 0!\n"); > + kfree(speedbin); > + return -ENODEV; > + } > + > + get_krait_bin_format_a(cpu_dev, &speed, &pvs, &pvs_ver, speedbin); > + > + ret = qcom_smem_get_soc_id(&msm_id); > + if (ret) > + return ret; speedbin leaks here you can free it right after the get_krait.. call > + > + switch (msm_id) { > + case QCOM_ID_IPQ8062: > + drv->versions = BIT(IPQ8062_VERSION); > + break; > + case QCOM_ID_IPQ8064: > + case QCOM_ID_IPQ8066: > + case QCOM_ID_IPQ8068: > + drv->versions = BIT(IPQ8064_VERSION); > + break; > + case QCOM_ID_IPQ8065: > + case QCOM_ID_IPQ8069: > + drv->versions = BIT(IPQ8065_VERSION); > + break; > + default: > + dev_err(cpu_dev, > + "SoC ID %u is not part of IPQ8064 family, limiting to 1.0GHz!\n", > + msm_id); > + drv->versions = BIT(IPQ8062_VERSION); > + break; > + } > + > + /* IPQ8064 speed is never fused. Only pvs values are fused. */ > + snprintf(*pvs_name, sizeof("speedXX-pvsXX"), "speed%d-pvs%d", > + speed, pvs); Then drop the format for `speed` and just throw in a zero! [...] > - { .compatible = "qcom,ipq8064", .data = &match_data_krait }, > + { .compatible = "qcom,ipq8064", .data = &match_data_ipq8064 }, This change demands a Fixes tag, because you're essentially saying "the support for this SoC was supposedly there, but it could have never worked and was broken all along". Konrad