Received: by 2002:a05:6358:11c7:b0:104:8066:f915 with SMTP id i7csp2255702rwl; Sat, 1 Apr 2023 04:56:02 -0700 (PDT) X-Google-Smtp-Source: AKy350aLcHRKxSWoKQdKynNmZY2+4ViY1HO8w3VKmEfoig0aSawEbuyart/pl59HHpxdbcJwMf0C X-Received: by 2002:a17:906:553:b0:8af:5403:992d with SMTP id k19-20020a170906055300b008af5403992dmr28184137eja.28.1680350162276; Sat, 01 Apr 2023 04:56:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1680350162; cv=none; d=google.com; s=arc-20160816; b=kdjS38OayteRSTyvGzHRKecWj2+qmJ3zpEQVx2LUL55ubtSpgNhwycyjNhdSkQ0FE8 d05G2OPKFehiKvOgETeJC/al4eoGDzHoA+NuYtl6TD86zvNRuGI9FJTjonpbadckIsuR eSAdvLve6JS3V8H7ME5d8bAVAasBXB2IigKSfOg5+PwkLaVH6WAIZ2FnEeVc9rfX4a7a PlstIDqODIF2YMj5/wUzkVonGxgKDMk0Wf94IvXtx+izTDlIbANUVClwFTPyEJbUUyZc ZDT0PRrcis+stOzGaXdvPi0zAk62iYJIW4ic7ACLa+pWO/9hvnxDzboEcRMWMt3z21NJ 2qUQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:content-transfer-encoding:mime-version :message-id:date:subject:from:dkim-signature; bh=5QslPU0bn72iS1LMcL81r7OJHaoEq7yFVP8NXGm8ywA=; b=nKMkDFFw2phDdhL52FpeZ4hL1hkTMzQ2pnoO5tolb4XxcC0Q/qGHFN74XMQwDDvlze mrB0Iei/NE0/Wcjuyd2at1u8l1Oqb+bHUWSzujd3KfICwJaSsc8sTFhz3P3+dgltz48p RtqxEYcyO/I9i46QxFPPNu/zcxX1eq/UYC8nguPD0hk61hio9l0qfbn9SmJfGVVobw80 mYpqxp31byLmoqlluUfvNC5P0wQ4GVr0EkJhu6xJxvihgVu0Xg0Dk7nu3bCGKimJX5a1 +88XRQkVFlhbOFyQ7D0a4Lc+negnoiIdMF8zRuMfQejUhfuxDLTqnJtekGF13sIUPFH3 07Bg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=S0XMAxNB; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id t7-20020a170906178700b0093ea690f938si748295eje.417.2023.04.01.04.55.37; Sat, 01 Apr 2023 04:56:02 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=S0XMAxNB; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 S229773AbjDALyy (ORCPT + 99 others); Sat, 1 Apr 2023 07:54:54 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51276 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229753AbjDALyw (ORCPT ); Sat, 1 Apr 2023 07:54:52 -0400 Received: from mail-lf1-x12a.google.com (mail-lf1-x12a.google.com [IPv6:2a00:1450:4864:20::12a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id F30381C1C6 for ; Sat, 1 Apr 2023 04:54:49 -0700 (PDT) Received: by mail-lf1-x12a.google.com with SMTP id bi9so32196280lfb.12 for ; Sat, 01 Apr 2023 04:54:49 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; t=1680350088; h=cc:to:content-transfer-encoding:mime-version:message-id:date :subject:from:from:to:cc:subject:date:message-id:reply-to; bh=5QslPU0bn72iS1LMcL81r7OJHaoEq7yFVP8NXGm8ywA=; b=S0XMAxNBg2ZKsMOFeqYFGWeuDdC52ExqfS+sp2a03/8aK9vIZo6Fm67EJeghewN1d6 bBgOa+DAxgcIn4xpNf6vGfAl6MmHLCTvxpDVSKovf1D8452oFWm7PkkoVOvE8i2BTET5 nBCShoPJndr+qIYdQKY8XCEy01YQFEYZi9u71k3eb006rBjKmcxI08NHsudSycwzvSNo MzAk1Szq6qK/U3aO9sQ2u+zWFM4DEPoPkclFsyo6+ssN7vh8WyrOebHB5x9DB75DPQQW V2CW5Jgqb3gE2RUivdoOTHMVNAvzaRl5BcXqUIoofGhB8pjw2p9UKGpToIkma6gUFsNA Vgvg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; t=1680350088; h=cc:to:content-transfer-encoding:mime-version:message-id:date :subject:from:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=5QslPU0bn72iS1LMcL81r7OJHaoEq7yFVP8NXGm8ywA=; b=8Oi1ZqcwSAY9g0dqfDiIKpNU4SHz8eFZxSQxhbLHV9PCQ01IigwG2Hnl7jfwSYd++d qq5mi4ASnwQuoWAqIN9LRiSnmjv7wa6O9cjRJBylphcqRYSXZYrRTTrTVeIro+QgCUKW lgyUqa923lFv4MYUQ+1Eq2UvBltVshvd/Gtq3+YwJfuZnnH/REGqJtK5LGTxaXHnorJM n/x/KDaogzkrQuaXklemzhPllTWPSH3YdYF0lWs6mdT5ZD+XJIe3qVzf9no3D7wUUly8 8Q2cF2Pc3r9e9XbcS7DOBIRBIoTL8MnA4MhTXS1VJCLxyxOkhMUXS4dfhvncnYjPfwTw yqAg== X-Gm-Message-State: AAQBX9di7Xpw56JSrc7cGxf4eV8p/8Xi3jU0dm+qNKDZHhNsukgA+bj6 dzNrOA+xDiWWhxuCIkQ8W+B6jw== X-Received: by 2002:ac2:4ac2:0:b0:4ea:f5dd:8aa1 with SMTP id m2-20020ac24ac2000000b004eaf5dd8aa1mr7660217lfp.18.1680350088198; Sat, 01 Apr 2023 04:54:48 -0700 (PDT) Received: from [192.168.1.101] (abxj225.neoplus.adsl.tpnet.pl. [83.9.3.225]) by smtp.gmail.com with ESMTPSA id w8-20020ac254a8000000b004e83f386878sm786737lfk.153.2023.04.01.04.54.44 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 01 Apr 2023 04:54:47 -0700 (PDT) From: Konrad Dybcio Subject: [PATCH v6 00/15] GMU-less A6xx support (A610, A619_holi) Date: Sat, 01 Apr 2023 13:54:37 +0200 Message-Id: <20230223-topic-gmuwrapper-v6-0-2034115bb60c@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit X-B4-Tracking: v=1; b=H4sIAH0bKGQC/4XNQQ7CIBQE0Ks0rMUglFJceQ/jAtpPS1KBfGrVm N5ddGdMdDmTzJsHyYAeMtlXD4Kw+OxjKKHZVKQbTRiA+r5kwhkXjHNB55h8R4fz5YomJUBqa+e cdL1SrSZlZk0GatGEbizDcJmmUiYE52/vn+Op5NHnOeL9fbuIV/vjYRGUUWlBSiNE0+70YfLBY NxGHMhLW+p/Ql0E0K0Cq3TPhPsS5D9BFsE6pWqrjWbcfAjruj4BPG6lFkoBAAA= To: Rob Clark , Abhinav Kumar , Dmitry Baryshkov , Sean Paul , David Airlie , Daniel Vetter , Rob Herring , Krzysztof Kozlowski , Bjorn Andersson , Konrad Dybcio , Akhil P Oommen Cc: linux-arm-msm@vger.kernel.org, dri-devel@lists.freedesktop.org, freedreno@lists.freedesktop.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, Rob Clark , Marijn Suijten , Konrad Dybcio , Krzysztof Kozlowski X-Mailer: b4 0.12.2 X-Developer-Signature: v=1; a=ed25519-sha256; t=1680350084; l=8581; i=konrad.dybcio@linaro.org; s=20230215; h=from:subject:message-id; bh=+hG0oi13LNaN2RrmVir69vepeiToqQZ8Le99hRwIZ/0=; b=3Y975/Uo7qMu4CmdCyip67L+tlBihX7EeklGEdeLLkXvHCVKgscW1NGMQS2EC2lVWmvd1uLPZzn9 dhNOXRm5C6ExgVR4MH7VS8gT55lA2j9sTntM1UrdEN5vFjSleiMU X-Developer-Key: i=konrad.dybcio@linaro.org; a=ed25519; pk=iclgkYvtl2w05SSXO5EjjSYlhFKsJ+5OSZBjOkQuEms= X-Spam-Status: No, score=-0.2 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org v5 -> v6: - Rebase on 8ead96783163 ("drm/msm/gpu: Move BO allocation out of hw_init") (Add .ucode_load to funcs_gmuwrapper) - Drop A6[45]0 speedbin deps, merged into msm-next Dependencies: - https://lore.kernel.org/linux-arm-msm/20230330231517.2747024-1-konrad.dybcio@linaro.org/ (to work properly) v5: https://lore.kernel.org/linux-arm-msm/20230223-topic-gmuwrapper-v5-0-bf774b9a902a@linaro.org/ v4 -> v5: - Add a newline before the new allOf:if: [3/15] - Enforce 6 clocks on A619_holi/A610 [2/15] - Pick up tags - Improve error handling in a6xx_pm_resume [6/15] - Add patch [1/15] (fix an existing issue) which can be picked separately and account for it in [6/15] - Rebase atop Akhil's CX shutdown patches and incorporate analogous logic - Fix a regression introduced in v3 that made the fw loader expect GMU fw on GMU wrapper GPUs Dependencies: - https://lore.kernel.org/linux-arm-msm/20230120172233.1905761-1-konrad.dybcio@linaro.org/ (to apply) - https://lore.kernel.org/linux-arm-msm/20230330231517.2747024-1-konrad.dybcio@linaro.org/ (to work properly) v4: https://lore.kernel.org/r/20230223-topic-gmuwrapper-v4-0-e987eb79d03f@linaro.org v3 -> v4: - Drop the mistakengly-included and wrong A3xx-A5xx bindings changes - Improve bindings commit messages to better explain what GMU Wrapper is - Drop the A680 highest bank bit value adjustment patch - Sort UBWC config variables in a reverse-Christmass-tree fashion [4/14] - Don't alter any UBWC config values in [4/14] - Do so for a619_holi in [8/14] - Rebase on next-20230314 (shouldn't matter at all) v3: https://lore.kernel.org/r/20230223-topic-gmuwrapper-v3-0-5be55a336819@linaro.org v2 -> v3: New dependencies: - https://lore.kernel.org/linux-arm-msm/20230223-topic-opp-v3-0-5f22163cd1df@linaro.org/T/#t - https://lore.kernel.org/linux-arm-msm/20230120172233.1905761-1-konrad.dybcio@linaro.org/ Sidenote: A speedbin rework is in progress, the of_machine_is_compatible calls in A619_holi are ugly (but well, necessary..) but they'll be replaced with socid matching in this or the next kernel cycle. Due to the new way of identifying GMU wrapper GPUs, configuring 6350 to use wrapper would cause the wrong fuse values to be checked, but that will be solved by the conversion + the ultimate goal is to use the GMU whenever possible with the wrapper left for GMU-less Adrenos and early bringup debugging of GMU-equipped ones. - Ship dt-bindings in this series as we're referencing the compatible now - "De-staticize" -> "remove static keyword" [3/15] - Track down all the values in [4/15] - Add many comments and explanations in [4/15] - Fix possible return-before-mutex-unlock [5/15] - Explain the GMU wrapper a bit more in the commit msg [5/15] - Separate out pm_resume/suspend for GMU-wrapper GPUs to make things cleaner [5/15] - Don't check if `info` exists, it has to at this point [5/15] - Assign gpu->info early and clean up following if statements in a6xx_gpu_init [5/15] - Determine whether we use GMU wrapper based on the GMU compatible instead of a quirk [5/15] - Use a struct field to annotate whether we're using gmu wrapper so that it can be assigned at runtime (turns out a619 holi-ness cannot be determined by patchid + that will make it easier to test out GMU GPUs without actually turning on the GMU if anybody wants to do so) [5/15] - Unconditionally hook up gx to the gmu wrapper (otherwise our gpu will not get power) [5/15] - Don't check for gx domain presence in gmu_wrapper paths, it's guaranteed [5/15] - Use opp set rate in the gmuwrapper suspend path [5/15] - Call opp functions on the GPU device and not on the DRM device of mdp4/5/DPU1 half the time (WHOOOOPS!) [5/15] - Disable the memory clock in a6xx_pm_suspend instead of enabling it (moderate oops) [5/15] - Call the forgotten clk_bulk_disable_unprepare in a6xx_pm_suspend [5/15] - Set rate to FMIN (a6xx really doesn't like rate=0 + that's what msm-5.x does anyway) before disabling core clock [5/15] - pm_runtime_get_sync -> pm_runtime_resume_and_get [5/15] - Don't annotate no cached BO support with a quirk, as A619_holi is merged into the A619 entry in the big const struct - this means that all GPUs operating in gmu wrapper configuration will be implicitly treated as if they didn't have this feature [7/15] - Drop OPP rate & icc related patches, they're a part of a separate series now; rebase on it - Clean up extra parentheses [8/15] - Identify A619_holi by checking the compatible of its GMU instead of patchlevel [8/15] - Drop "Fix up A6XX protected registers" - unnecessary, Rob will add a comment explaining why - Fix existing UBWC values for A680, new patch [10/15] - Use adreno_is_aXYZ macros in speedbin matching [13/15] - new patch v2: https://lore.kernel.org/linux-arm-msm/20230214173145.2482651-1-konrad.dybcio@linaro.org/ v1 -> v2: - Fix A630 values in [2/14] - Fix [6/14] for GMU-equipped GPUs Link to v1: https://lore.kernel.org/linux-arm-msm/20230126151618.225127-1-konrad.dybcio@linaro.org/ This series concludes my couple-weeks-long suffering of figuring out the ins and outs of the "non-standard" A6xx GPUs which feature no GMU. The GMU functionality is essentially emulated by parting out a "GMU wrapper" region, which is essentially just a register space within the GPU. It's modeled to be as similar to the actual GMU as possible while staying as unnecessary as we can make it - there's no IRQs, communicating with a microcontroller, no RPMh communication etc. etc. I tried to reuse as much code as possible without making a mess where every even line is used for GMU and every odd line is used for GMU wrapper.. This series contains: - plumbing for non-GMU operation, if-ing out GMU calls based on GMU presence - GMU wrapper support - A610 support (w/ speedbin) - A619 support (w/ speedbin) - couple of minor fixes and improvements - VDDCX/VDDGX scaling fix for non-GMU GPUs (concerns more than just A6xx) - Enablement of opp interconnect properties A619_holi works perfectly fine using the already-present A619 support in mesa. A610 needs more work on that front, but can already replay command traces captures on downstream. NOTE: the "drm/msm/a6xx: Add support for A619_holi" patch contains two occurences of 0x18 used in place of a register #define, as it's supposed to be RBBM_GPR0_CNTL, but that will only be present after mesa-side changes are merged and headers are synced from there. Speedbin patches depend on: https://lore.kernel.org/linux-arm-msm/20230120172233.1905761-1-konrad.dybcio@linaro.org/ Signed-off-by: Konrad Dybcio --- Konrad Dybcio (15): drm/msm/adreno: adreno_gpu: Don't set OPP scaling clock w/ GMU dt-bindings: display/msm: gpu: Document GMU wrapper-equipped A6xx dt-bindings: display/msm/gmu: Add GMU wrapper drm/msm/a6xx: Remove static keyword from sptprac en/disable functions drm/msm/a6xx: Extend and explain UBWC config drm/msm/a6xx: Introduce GMU wrapper support drm/msm/a6xx: Remove both GBIF and RBBM GBIF halt on hw init drm/msm/adreno: Disable has_cached_coherent in GMU wrapper configurations drm/msm/a6xx: Add support for A619_holi drm/msm/a6xx: Add A610 support drm/msm/a6xx: Fix some A619 tunables drm/msm/a6xx: Use "else if" in GPU speedbin rev matching drm/msm/a6xx: Use adreno_is_aXYZ macros in speedbin matching drm/msm/a6xx: Add A619_holi speedbin support drm/msm/a6xx: Add A610 speedbin support .../devicetree/bindings/display/msm/gmu.yaml | 50 +- .../devicetree/bindings/display/msm/gpu.yaml | 61 ++- drivers/gpu/drm/msm/adreno/a6xx_gmu.c | 76 ++- drivers/gpu/drm/msm/adreno/a6xx_gmu.h | 2 + drivers/gpu/drm/msm/adreno/a6xx_gpu.c | 508 ++++++++++++++++++--- drivers/gpu/drm/msm/adreno/a6xx_gpu.h | 1 + drivers/gpu/drm/msm/adreno/a6xx_gpu_state.c | 14 +- drivers/gpu/drm/msm/adreno/adreno_device.c | 17 +- drivers/gpu/drm/msm/adreno/adreno_gpu.c | 28 +- drivers/gpu/drm/msm/adreno/adreno_gpu.h | 33 +- 10 files changed, 688 insertions(+), 102 deletions(-) --- base-commit: b5595a717f5b26d99ec94d038cb1cfaae319bd6e change-id: 20230223-topic-gmuwrapper-b4fff5fd7789 Best regards, -- Konrad Dybcio