Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp2058056ybv; Fri, 14 Feb 2020 10:37:41 -0800 (PST) X-Google-Smtp-Source: APXvYqxPoH09H8g4a4OKn69RcCYVTjWYjzmNinSOEwVRqMHE0ghqhJW6jn1//GkjFH04eNWHToRl X-Received: by 2002:a05:6830:22ca:: with SMTP id q10mr3629321otc.280.1581705461318; Fri, 14 Feb 2020 10:37:41 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1581705461; cv=none; d=google.com; s=arc-20160816; b=KoanXJ5dk6fF7amK6bDuZikBgnxLRbGfX1kq5AJbTI9m+wseIO4Bar/gUWAfa2D18N ISqNipau/yew3vlOWPi7fm4+nvvcG9vv+cjbmqyJ7i4lRrKs+MdDWPk5F85NdXC3kdG6 FjLct5O5R243eri3BkW8b2U8lLQxOELc0M4dUIUKg5lfpg6u4+aZJb9XDS2DpXkeRiS/ cbbfWN10sHImZBWWQVGbyPYNhMbqH6XRPqNocjLoLlfA4m0wHL/3VJi7x0pJBWNUaRCl uKpMNHyYJyoeo1CuQA1dci+obFLn77FgviSzwlrkSCgKXwOAeFMbfTtqrN7hLtMpvBCW 61Bw== 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 :dmarc-filter:dkim-signature; bh=Lve/8NkQ1+pW/USqTTKmFAidSUSOjj1HUCuP/rW4dNg=; b=WhCYKpfUVvIntXw0dRvDgSaWhQUyXq4LOBAm4y6BKTZE9ZRhnbJNhY8ND97tTUnv5M Oi6+rIJRSJq8rMC24oQQ20IAep4uCLC55PXKixrvrOw/B28T7Gox7kbtOTfh/pGKYx2u euG8ieMx7DkioXKt6paMEM33ZK5/GqY6ZzxOaf/xPXnBB1dGeESjU3WDShsC14VjT/NQ 6sg2cEtBZsGHfT/LCdOBJmy2izbPnU6oS8DVdRxe7GwjSeF+Uwdz2LGu1qZAmA+5dVS/ dahicB9MzoNHhT6NaTeKZwgdRPtfMYf00dpCFS4Kw6j4lUzFIwo+4RscgKh657H1Vayv F/vQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@mg.codeaurora.org header.s=smtp header.b=u7UoSFam; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id p19si1684811otq.296.2020.02.14.10.37.29; Fri, 14 Feb 2020 10:37:41 -0800 (PST) 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=fail header.i=@mg.codeaurora.org header.s=smtp header.b=u7UoSFam; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2389255AbgBNShF (ORCPT + 99 others); Fri, 14 Feb 2020 13:37:05 -0500 Received: from mail26.static.mailgun.info ([104.130.122.26]:38857 "EHLO mail26.static.mailgun.info" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388824AbgBNShD (ORCPT ); Fri, 14 Feb 2020 13:37:03 -0500 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1581705423; h=Message-Id: Date: Subject: Cc: To: From: Sender; bh=Lve/8NkQ1+pW/USqTTKmFAidSUSOjj1HUCuP/rW4dNg=; b=u7UoSFamGdbF5svGcEW+llI7xSPdrS9+asj9Iol5gFqdVv9nRfBQZgy0KxDGxacpYd9NUSNA ZHUGwg0CTFzF6tw3AagwaPW6a450AEDNGVXn0qoTjlUx9+52+yWDd6EISYySqcegbIzqrPmE SkAAeRbjzw/J3SkbhcnuNPyglPA= X-Mailgun-Sending-Ip: 104.130.122.26 X-Mailgun-Sid: WyI0MWYwYSIsICJsaW51eC1rZXJuZWxAdmdlci5rZXJuZWwub3JnIiwgImJlOWU0YSJd Received: from smtp.codeaurora.org (ec2-35-166-182-171.us-west-2.compute.amazonaws.com [35.166.182.171]) by mxa.mailgun.org with ESMTP id 5e46e8c6.7faad7e4a490-smtp-out-n01; Fri, 14 Feb 2020 18:36:54 -0000 (UTC) Received: by smtp.codeaurora.org (Postfix, from userid 1001) id 00FA9C4479F; Fri, 14 Feb 2020 18:36:53 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-caf-mail-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-1.0 required=2.0 tests=ALL_TRUSTED,SPF_NONE, URIBL_BLOCKED autolearn=unavailable autolearn_force=no version=3.4.0 Received: from jcrouse1-lnx.qualcomm.com (i-global254.qualcomm.com [199.106.103.254]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: jcrouse) by smtp.codeaurora.org (Postfix) with ESMTPSA id D597FC4479C; Fri, 14 Feb 2020 18:36:50 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org D597FC4479C Authentication-Results: aws-us-west-2-caf-mail-1.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: aws-us-west-2-caf-mail-1.web.codeaurora.org; spf=none smtp.mailfrom=jcrouse@codeaurora.org From: Jordan Crouse To: linux-arm-msm@vger.kernel.org Cc: Eric Anholt , David Airlie , Sean Paul , Wen Yang , AngeloGioacchino Del Regno , linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, Rob Clark , Thomas Gleixner , freedreno@lists.freedesktop.org, Jeffrey Hugo , Ben Dooks , Daniel Vetter Subject: [PATCH] drm/msm/a5xx: Always set an OPP supported hardware value Date: Fri, 14 Feb 2020 11:36:44 -0700 Message-Id: <1581705404-5124-1-git-send-email-jcrouse@codeaurora.org> X-Mailer: git-send-email 2.7.4 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org If the opp table specifies opp-supported-hw as a property but the driver has not set a supported hardware value the OPP subsystem will reject all the table entries. Set a "default" value that will match the default table entries but not conflict with any possible real bin values. Also fix a small memory leak and free the buffer allocated by nvmem_cell_read(). Signed-off-by: Jordan Crouse --- drivers/gpu/drm/msm/adreno/a5xx_gpu.c | 27 ++++++++++++++++++++------- 1 file changed, 20 insertions(+), 7 deletions(-) diff --git a/drivers/gpu/drm/msm/adreno/a5xx_gpu.c b/drivers/gpu/drm/msm/adreno/a5xx_gpu.c index 7d9e63e..724024a 100644 --- a/drivers/gpu/drm/msm/adreno/a5xx_gpu.c +++ b/drivers/gpu/drm/msm/adreno/a5xx_gpu.c @@ -1446,18 +1446,31 @@ static const struct adreno_gpu_funcs funcs = { static void check_speed_bin(struct device *dev) { struct nvmem_cell *cell; - u32 bin, val; + u32 val; + + /* + * If the OPP table specifies a opp-supported-hw property then we have + * to set something with dev_pm_opp_set_supported_hw() or the table + * doesn't get populated so pick an arbitrary value that should + * ensure the default frequencies are selected but not conflict with any + * actual bins + */ + val = 0x80; cell = nvmem_cell_get(dev, "speed_bin"); - /* If a nvmem cell isn't defined, nothing to do */ - if (IS_ERR(cell)) - return; + if (!IS_ERR(cell)) { + void *buf = nvmem_cell_read(cell, NULL); + + if (!IS_ERR(buf)) { + u8 bin = *((u8 *) buf); - bin = *((u32 *) nvmem_cell_read(cell, NULL)); - nvmem_cell_put(cell); + val = (1 << bin); + kfree(buf); + } - val = (1 << bin); + nvmem_cell_put(cell); + } dev_pm_opp_set_supported_hw(dev, &val, 1); } -- 2.7.4