Commit 38f88732 authored by Dave Airlie's avatar Dave Airlie

Merge tag 'drm-msm-next-2023-08-20' of https://gitlab.freedesktop.org/drm/msm into drm-next

Updates for v6.6, which includes a backmerge of msm-fixes to avoid conficts.

Core:
- SM6125 MDSS support

DPU:
- SM6125 DPU support
- Added subblocks to display snapshot
- Use UBWC data from MDSS driver rather than duplicating it
- dpu_core_perf cleanup

DSI:
- Enabled burst mode to fix CMD mode panels
- Runtime PM support
- refgen regulator support

DSI PHY:
- SM6125 support in 14nm DSI PHY driver

GPU:
- Rework GPU identification to prepare for a7xx, and other a7xx prep
- Cleanups and fixes
- Disallow legacy relocs on a6xx and newer
- a690: switch to using a660_gmu.bin fw as this is what we have in
  linux-firmware and we see no evidence that it should be different
  from other a660 family (a6xx subgen 4) devices
- Submit overhead opts, 1.6x faster for NO_IMPLICIT_SYNC commits with
  100 BOs to 2.5x faster for 1000 BOs
Signed-off-by: default avatarDave Airlie <airlied@redhat.com>
From: Rob Clark <robdclark@gmail.com>
Link: https://patchwork.freedesktop.org/patch/msgid/CAF6AEGv_01g-edjdfKLWWcb-rO5aSyLsv5FpbKrTkXVL9+ngTQ@mail.gmail.com
parents fdebffeb 34b149ec
...@@ -29,6 +29,7 @@ properties: ...@@ -29,6 +29,7 @@ properties:
- description: Link clock from DP PHY - description: Link clock from DP PHY
- description: VCO DIV clock from DP PHY - description: VCO DIV clock from DP PHY
- description: AHB config clock from GCC - description: AHB config clock from GCC
- description: GPLL0 div source from GCC
clock-names: clock-names:
items: items:
...@@ -39,6 +40,7 @@ properties: ...@@ -39,6 +40,7 @@ properties:
- const: dp_phy_pll_link_clk - const: dp_phy_pll_link_clk
- const: dp_phy_pll_vco_div_clk - const: dp_phy_pll_vco_div_clk
- const: cfg_ahb_clk - const: cfg_ahb_clk
- const: gcc_disp_gpll0_div_clk_src
'#clock-cells': '#clock-cells':
const: 1 const: 1
...@@ -46,6 +48,16 @@ properties: ...@@ -46,6 +48,16 @@ properties:
'#power-domain-cells': '#power-domain-cells':
const: 1 const: 1
power-domains:
description:
A phandle and PM domain specifier for the CX power domain.
maxItems: 1
required-opps:
description:
A phandle to an OPP node describing the power domain's performance point.
maxItems: 1
reg: reg:
maxItems: 1 maxItems: 1
...@@ -63,23 +75,31 @@ examples: ...@@ -63,23 +75,31 @@ examples:
- | - |
#include <dt-bindings/clock/qcom,rpmcc.h> #include <dt-bindings/clock/qcom,rpmcc.h>
#include <dt-bindings/clock/qcom,gcc-sm6125.h> #include <dt-bindings/clock/qcom,gcc-sm6125.h>
#include <dt-bindings/power/qcom-rpmpd.h>
clock-controller@5f00000 { clock-controller@5f00000 {
compatible = "qcom,sm6125-dispcc"; compatible = "qcom,sm6125-dispcc";
reg = <0x5f00000 0x20000>; reg = <0x5f00000 0x20000>;
clocks = <&rpmcc RPM_SMD_XO_CLK_SRC>, clocks = <&rpmcc RPM_SMD_XO_CLK_SRC>,
<&dsi0_phy 0>, <&dsi0_phy 0>,
<&dsi0_phy 1>, <&dsi0_phy 1>,
<&dsi1_phy 1>, <&dsi1_phy 1>,
<&dp_phy 0>, <&dp_phy 0>,
<&dp_phy 1>, <&dp_phy 1>,
<&gcc GCC_DISP_AHB_CLK>; <&gcc GCC_DISP_AHB_CLK>,
<&gcc GCC_DISP_GPLL0_DIV_CLK_SRC>;
clock-names = "bi_tcxo", clock-names = "bi_tcxo",
"dsi0_phy_pll_out_byteclk", "dsi0_phy_pll_out_byteclk",
"dsi0_phy_pll_out_dsiclk", "dsi0_phy_pll_out_dsiclk",
"dsi1_phy_pll_out_dsiclk", "dsi1_phy_pll_out_dsiclk",
"dp_phy_pll_link_clk", "dp_phy_pll_link_clk",
"dp_phy_pll_vco_div_clk", "dp_phy_pll_vco_div_clk",
"cfg_ahb_clk"; "cfg_ahb_clk",
"gcc_disp_gpll0_div_clk_src";
required-opps = <&rpmhpd_opp_ret>;
power-domains = <&rpmpd SM6125_VDDCX>;
#clock-cells = <1>; #clock-cells = <1>;
#power-domain-cells = <1>; #power-domain-cells = <1>;
}; };
......
...@@ -28,6 +28,7 @@ properties: ...@@ -28,6 +28,7 @@ properties:
- qcom,sm8350-dp - qcom,sm8350-dp
- items: - items:
- enum: - enum:
- qcom,sm8250-dp
- qcom,sm8450-dp - qcom,sm8450-dp
- qcom,sm8550-dp - qcom,sm8550-dp
- const: qcom,sm8350-dp - const: qcom,sm8350-dp
......
...@@ -27,6 +27,7 @@ properties: ...@@ -27,6 +27,7 @@ properties:
- qcom,sdm660-dsi-ctrl - qcom,sdm660-dsi-ctrl
- qcom,sdm845-dsi-ctrl - qcom,sdm845-dsi-ctrl
- qcom,sm6115-dsi-ctrl - qcom,sm6115-dsi-ctrl
- qcom,sm6125-dsi-ctrl
- qcom,sm6350-dsi-ctrl - qcom,sm6350-dsi-ctrl
- qcom,sm6375-dsi-ctrl - qcom,sm6375-dsi-ctrl
- qcom,sm8150-dsi-ctrl - qcom,sm8150-dsi-ctrl
...@@ -166,6 +167,10 @@ properties: ...@@ -166,6 +167,10 @@ properties:
description: description:
Phandle to vdd regulator device node Phandle to vdd regulator device node
refgen-supply:
description:
Phandle to REFGEN regulator device node
vcca-supply: vcca-supply:
description: description:
Phandle to vdd regulator device node Phandle to vdd regulator device node
...@@ -301,6 +306,7 @@ allOf: ...@@ -301,6 +306,7 @@ allOf:
contains: contains:
enum: enum:
- qcom,msm8998-dsi-ctrl - qcom,msm8998-dsi-ctrl
- qcom,sm6125-dsi-ctrl
- qcom,sm6350-dsi-ctrl - qcom,sm6350-dsi-ctrl
then: then:
properties: properties:
......
...@@ -19,6 +19,7 @@ properties: ...@@ -19,6 +19,7 @@ properties:
- qcom,dsi-phy-14nm-2290 - qcom,dsi-phy-14nm-2290
- qcom,dsi-phy-14nm-660 - qcom,dsi-phy-14nm-660
- qcom,dsi-phy-14nm-8953 - qcom,dsi-phy-14nm-8953
- qcom,sm6125-dsi-phy-14nm
reg: reg:
items: items:
...@@ -35,6 +36,16 @@ properties: ...@@ -35,6 +36,16 @@ properties:
vcca-supply: vcca-supply:
description: Phandle to vcca regulator device node. description: Phandle to vcca regulator device node.
power-domains:
description:
A phandle and PM domain specifier for an optional power domain.
maxItems: 1
required-opps:
description:
A phandle to an OPP node describing the power domain's performance point.
maxItems: 1
required: required:
- compatible - compatible
- reg - reg
......
...@@ -13,6 +13,12 @@ maintainers: ...@@ -13,6 +13,12 @@ maintainers:
properties: properties:
compatible: compatible:
oneOf: oneOf:
- description: |
The driver is parsing the compat string for Adreno to
figure out the chip-id.
items:
- pattern: '^qcom,adreno-[0-9a-f][0-9a-f][0-9a-f][0-9a-f][0-9a-f][0-9a-f][0-9a-f][0-9a-f]$'
- const: qcom,adreno
- description: | - description: |
The driver is parsing the compat string for Adreno to The driver is parsing the compat string for Adreno to
figure out the gpu-id and patch level. figure out the gpu-id and patch level.
......
...@@ -77,6 +77,12 @@ properties: ...@@ -77,6 +77,12 @@ properties:
items: items:
- description: MDSS_CORE reset - description: MDSS_CORE reset
memory-region:
maxItems: 1
description:
Phandle to a node describing a reserved framebuffer memory region.
For example, the splash memory region set up by the bootloader.
required: required:
- reg - reg
- reg-names - reg-names
......
...@@ -15,6 +15,7 @@ properties: ...@@ -15,6 +15,7 @@ properties:
compatible: compatible:
enum: enum:
- qcom,sc7180-dpu - qcom,sc7180-dpu
- qcom,sm6125-dpu
- qcom,sm6350-dpu - qcom,sm6350-dpu
- qcom,sm6375-dpu - qcom,sm6375-dpu
...@@ -63,7 +64,9 @@ allOf: ...@@ -63,7 +64,9 @@ allOf:
- if: - if:
properties: properties:
compatible: compatible:
const: qcom,sm6375-dpu enum:
- qcom,sm6375-dpu
- qcom,sm6125-dpu
then: then:
properties: properties:
......
# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause
%YAML 1.2
---
$id: http://devicetree.org/schemas/display/msm/qcom,sm6125-mdss.yaml#
$schema: http://devicetree.org/meta-schemas/core.yaml#
title: Qualcomm SM6125 Display MDSS
maintainers:
- Marijn Suijten <marijn.suijten@somainline.org>
description:
SM6125 MSM Mobile Display Subsystem (MDSS), which encapsulates sub-blocks
like DPU display controller, DSI and DP interfaces etc.
$ref: /schemas/display/msm/mdss-common.yaml#
properties:
compatible:
const: qcom,sm6125-mdss
clocks:
items:
- description: Display AHB clock from gcc
- description: Display AHB clock
- description: Display core clock
clock-names:
items:
- const: iface
- const: ahb
- const: core
iommus:
maxItems: 1
interconnects:
maxItems: 2
interconnect-names:
maxItems: 2
patternProperties:
"^display-controller@[0-9a-f]+$":
type: object
properties:
compatible:
const: qcom,sm6125-dpu
"^dsi@[0-9a-f]+$":
type: object
properties:
compatible:
items:
- const: qcom,sm6125-dsi-ctrl
- const: qcom,mdss-dsi-ctrl
"^phy@[0-9a-f]+$":
type: object
properties:
compatible:
const: qcom,sm6125-dsi-phy-14nm
unevaluatedProperties: false
examples:
- |
#include <dt-bindings/clock/qcom,dispcc-sm6125.h>
#include <dt-bindings/clock/qcom,gcc-sm6125.h>
#include <dt-bindings/clock/qcom,rpmcc.h>
#include <dt-bindings/interrupt-controller/arm-gic.h>
#include <dt-bindings/power/qcom-rpmpd.h>
display-subsystem@5e00000 {
compatible = "qcom,sm6125-mdss";
reg = <0x05e00000 0x1000>;
reg-names = "mdss";
interrupts = <GIC_SPI 186 IRQ_TYPE_LEVEL_HIGH>;
interrupt-controller;
#interrupt-cells = <1>;
clocks = <&gcc GCC_DISP_AHB_CLK>,
<&dispcc DISP_CC_MDSS_AHB_CLK>,
<&dispcc DISP_CC_MDSS_MDP_CLK>;
clock-names = "iface",
"ahb",
"core";
power-domains = <&dispcc MDSS_GDSC>;
iommus = <&apps_smmu 0x400 0x0>;
#address-cells = <1>;
#size-cells = <1>;
ranges;
display-controller@5e01000 {
compatible = "qcom,sm6125-dpu";
reg = <0x05e01000 0x83208>,
<0x05eb0000 0x2008>;
reg-names = "mdp", "vbif";
interrupt-parent = <&mdss>;
interrupts = <0>;
clocks = <&gcc GCC_DISP_HF_AXI_CLK>,
<&dispcc DISP_CC_MDSS_AHB_CLK>,
<&dispcc DISP_CC_MDSS_ROT_CLK>,
<&dispcc DISP_CC_MDSS_MDP_LUT_CLK>,
<&dispcc DISP_CC_MDSS_MDP_CLK>,
<&dispcc DISP_CC_MDSS_VSYNC_CLK>,
<&gcc GCC_DISP_THROTTLE_CORE_CLK>;
clock-names = "bus",
"iface",
"rot",
"lut",
"core",
"vsync",
"throttle";
assigned-clocks = <&dispcc DISP_CC_MDSS_VSYNC_CLK>;
assigned-clock-rates = <19200000>;
operating-points-v2 = <&mdp_opp_table>;
power-domains = <&rpmpd SM6125_VDDCX>;
ports {
#address-cells = <1>;
#size-cells = <0>;
port@0 {
reg = <0>;
dpu_intf1_out: endpoint {
remote-endpoint = <&mdss_dsi0_in>;
};
};
};
};
dsi@5e94000 {
compatible = "qcom,sm6125-dsi-ctrl", "qcom,mdss-dsi-ctrl";
reg = <0x05e94000 0x400>;
reg-names = "dsi_ctrl";
interrupt-parent = <&mdss>;
interrupts = <4>;
clocks = <&dispcc DISP_CC_MDSS_BYTE0_CLK>,
<&dispcc DISP_CC_MDSS_BYTE0_INTF_CLK>,
<&dispcc DISP_CC_MDSS_PCLK0_CLK>,
<&dispcc DISP_CC_MDSS_ESC0_CLK>,
<&dispcc DISP_CC_MDSS_AHB_CLK>,
<&gcc GCC_DISP_HF_AXI_CLK>;
clock-names = "byte",
"byte_intf",
"pixel",
"core",
"iface",
"bus";
assigned-clocks = <&dispcc DISP_CC_MDSS_BYTE0_CLK_SRC>,
<&dispcc DISP_CC_MDSS_PCLK0_CLK_SRC>;
assigned-clock-parents = <&mdss_dsi0_phy 0>, <&mdss_dsi0_phy 1>;
operating-points-v2 = <&dsi_opp_table>;
power-domains = <&rpmpd SM6125_VDDCX>;
phys = <&mdss_dsi0_phy>;
phy-names = "dsi";
#address-cells = <1>;
#size-cells = <0>;
ports {
#address-cells = <1>;
#size-cells = <0>;
port@0 {
reg = <0>;
mdss_dsi0_in: endpoint {
remote-endpoint = <&dpu_intf1_out>;
};
};
port@1 {
reg = <1>;
mdss_dsi0_out: endpoint {
};
};
};
};
phy@5e94400 {
compatible = "qcom,sm6125-dsi-phy-14nm";
reg = <0x05e94400 0x100>,
<0x05e94500 0x300>,
<0x05e94800 0x188>;
reg-names = "dsi_phy",
"dsi_phy_lane",
"dsi_pll";
#clock-cells = <1>;
#phy-cells = <0>;
clocks = <&dispcc DISP_CC_MDSS_AHB_CLK>,
<&rpmcc RPM_SMD_XO_CLK_SRC>;
clock-names = "iface",
"ref";
required-opps = <&rpmpd_opp_nom>;
power-domains = <&rpmpd SM6125_VDDMX>;
};
};
...
...@@ -131,13 +131,6 @@ examples: ...@@ -131,13 +131,6 @@ examples:
remote-endpoint = <&dsi0_in>; remote-endpoint = <&dsi0_in>;
}; };
}; };
port@1 {
reg = <1>;
dpu_intf2_out: endpoint {
remote-endpoint = <&dsi1_in>;
};
};
}; };
}; };
......
...@@ -132,13 +132,6 @@ examples: ...@@ -132,13 +132,6 @@ examples:
remote-endpoint = <&dsi0_in>; remote-endpoint = <&dsi0_in>;
}; };
}; };
port@1 {
reg = <1>;
dpu_intf2_out: endpoint {
remote-endpoint = <&dsi1_in>;
};
};
}; };
}; };
......
...@@ -52,6 +52,12 @@ patternProperties: ...@@ -52,6 +52,12 @@ patternProperties:
compatible: compatible:
const: qcom,sm8350-dpu const: qcom,sm8350-dpu
"^displayport-controller@[0-9a-f]+$":
type: object
properties:
compatible:
const: qcom,sm8350-dp
"^dsi@[0-9a-f]+$": "^dsi@[0-9a-f]+$":
type: object type: object
properties: properties:
......
...@@ -42,6 +42,14 @@ patternProperties: ...@@ -42,6 +42,14 @@ patternProperties:
compatible: compatible:
const: qcom,sm8450-dpu const: qcom,sm8450-dpu
"^displayport-controller@[0-9a-f]+$":
type: object
properties:
compatible:
items:
- const: qcom,sm8450-dp
- const: qcom,sm8350-dp
"^dsi@[0-9a-f]+$": "^dsi@[0-9a-f]+$":
type: object type: object
properties: properties:
......
...@@ -42,6 +42,14 @@ patternProperties: ...@@ -42,6 +42,14 @@ patternProperties:
compatible: compatible:
const: qcom,sm8550-dpu const: qcom,sm8550-dpu
"^displayport-controller@[0-9a-f]+$":
type: object
properties:
compatible:
items:
- const: qcom,sm8550-dp
- const: qcom,sm8350-dp
"^dsi@[0-9a-f]+$": "^dsi@[0-9a-f]+$":
type: object type: object
properties: properties:
......
...@@ -205,7 +205,7 @@ static int a2xx_hw_init(struct msm_gpu *gpu) ...@@ -205,7 +205,7 @@ static int a2xx_hw_init(struct msm_gpu *gpu)
A2XX_MH_INTERRUPT_MASK_MMU_PAGE_FAULT); A2XX_MH_INTERRUPT_MASK_MMU_PAGE_FAULT);
for (i = 3; i <= 5; i++) for (i = 3; i <= 5; i++)
if ((SZ_16K << i) == adreno_gpu->gmem) if ((SZ_16K << i) == adreno_gpu->info->gmem)
break; break;
gpu_write(gpu, REG_A2XX_RB_EDRAM_INFO, i); gpu_write(gpu, REG_A2XX_RB_EDRAM_INFO, i);
...@@ -540,6 +540,10 @@ struct msm_gpu *a2xx_gpu_init(struct drm_device *dev) ...@@ -540,6 +540,10 @@ struct msm_gpu *a2xx_gpu_init(struct drm_device *dev)
gpu->perfcntrs = perfcntrs; gpu->perfcntrs = perfcntrs;
gpu->num_perfcntrs = ARRAY_SIZE(perfcntrs); gpu->num_perfcntrs = ARRAY_SIZE(perfcntrs);
ret = adreno_gpu_init(dev, pdev, adreno_gpu, &funcs, 1);
if (ret)
goto fail;
if (adreno_is_a20x(adreno_gpu)) if (adreno_is_a20x(adreno_gpu))
adreno_gpu->registers = a200_registers; adreno_gpu->registers = a200_registers;
else if (adreno_is_a225(adreno_gpu)) else if (adreno_is_a225(adreno_gpu))
...@@ -547,10 +551,6 @@ struct msm_gpu *a2xx_gpu_init(struct drm_device *dev) ...@@ -547,10 +551,6 @@ struct msm_gpu *a2xx_gpu_init(struct drm_device *dev)
else else
adreno_gpu->registers = a220_registers; adreno_gpu->registers = a220_registers;
ret = adreno_gpu_init(dev, pdev, adreno_gpu, &funcs, 1);
if (ret)
goto fail;
if (!gpu->aspace) { if (!gpu->aspace) {
dev_err(dev->dev, "No memory protection without MMU\n"); dev_err(dev->dev, "No memory protection without MMU\n");
if (!allow_vram_carveout) { if (!allow_vram_carveout) {
......
...@@ -145,7 +145,7 @@ static void a4xx_enable_hwcg(struct msm_gpu *gpu) ...@@ -145,7 +145,7 @@ static void a4xx_enable_hwcg(struct msm_gpu *gpu)
gpu_write(gpu, REG_A4XX_RBBM_CLOCK_DELAY_HLSQ, 0x00220000); gpu_write(gpu, REG_A4XX_RBBM_CLOCK_DELAY_HLSQ, 0x00220000);
/* Early A430's have a timing issue with SP/TP power collapse; /* Early A430's have a timing issue with SP/TP power collapse;
disabling HW clock gating prevents it. */ disabling HW clock gating prevents it. */
if (adreno_is_a430(adreno_gpu) && adreno_gpu->rev.patchid < 2) if (adreno_is_a430(adreno_gpu) && adreno_patchid(adreno_gpu) < 2)
gpu_write(gpu, REG_A4XX_RBBM_CLOCK_CTL, 0); gpu_write(gpu, REG_A4XX_RBBM_CLOCK_CTL, 0);
else else
gpu_write(gpu, REG_A4XX_RBBM_CLOCK_CTL, 0xAAAAAAAA); gpu_write(gpu, REG_A4XX_RBBM_CLOCK_CTL, 0xAAAAAAAA);
......
...@@ -66,7 +66,7 @@ void a5xx_flush(struct msm_gpu *gpu, struct msm_ringbuffer *ring, ...@@ -66,7 +66,7 @@ void a5xx_flush(struct msm_gpu *gpu, struct msm_ringbuffer *ring,
static void a5xx_submit_in_rb(struct msm_gpu *gpu, struct msm_gem_submit *submit) static void a5xx_submit_in_rb(struct msm_gpu *gpu, struct msm_gem_submit *submit)
{ {
struct msm_ringbuffer *ring = submit->ring; struct msm_ringbuffer *ring = submit->ring;
struct msm_gem_object *obj; struct drm_gem_object *obj;
uint32_t *ptr, dwords; uint32_t *ptr, dwords;
unsigned int i; unsigned int i;
...@@ -83,7 +83,7 @@ static void a5xx_submit_in_rb(struct msm_gpu *gpu, struct msm_gem_submit *submit ...@@ -83,7 +83,7 @@ static void a5xx_submit_in_rb(struct msm_gpu *gpu, struct msm_gem_submit *submit
obj = submit->bos[submit->cmd[i].idx].obj; obj = submit->bos[submit->cmd[i].idx].obj;
dwords = submit->cmd[i].size; dwords = submit->cmd[i].size;
ptr = msm_gem_get_vaddr(&obj->base); ptr = msm_gem_get_vaddr(obj);
/* _get_vaddr() shouldn't fail at this point, /* _get_vaddr() shouldn't fail at this point,
* since we've already mapped it once in * since we've already mapped it once in
...@@ -103,7 +103,7 @@ static void a5xx_submit_in_rb(struct msm_gpu *gpu, struct msm_gem_submit *submit ...@@ -103,7 +103,7 @@ static void a5xx_submit_in_rb(struct msm_gpu *gpu, struct msm_gem_submit *submit
OUT_RING(ring, ptr[i]); OUT_RING(ring, ptr[i]);
} }
msm_gem_put_vaddr(&obj->base); msm_gem_put_vaddr(obj);
break; break;
} }
...@@ -749,7 +749,7 @@ static int a5xx_hw_init(struct msm_gpu *gpu) ...@@ -749,7 +749,7 @@ static int a5xx_hw_init(struct msm_gpu *gpu)
gpu_write(gpu, REG_A5XX_UCHE_GMEM_RANGE_MIN_LO, 0x00100000); gpu_write(gpu, REG_A5XX_UCHE_GMEM_RANGE_MIN_LO, 0x00100000);
gpu_write(gpu, REG_A5XX_UCHE_GMEM_RANGE_MIN_HI, 0x00000000); gpu_write(gpu, REG_A5XX_UCHE_GMEM_RANGE_MIN_HI, 0x00000000);
gpu_write(gpu, REG_A5XX_UCHE_GMEM_RANGE_MAX_LO, gpu_write(gpu, REG_A5XX_UCHE_GMEM_RANGE_MAX_LO,
0x00100000 + adreno_gpu->gmem - 1); 0x00100000 + adreno_gpu->info->gmem - 1);
gpu_write(gpu, REG_A5XX_UCHE_GMEM_RANGE_MAX_HI, 0x00000000); gpu_write(gpu, REG_A5XX_UCHE_GMEM_RANGE_MAX_HI, 0x00000000);
if (adreno_is_a506(adreno_gpu) || adreno_is_a508(adreno_gpu) || if (adreno_is_a506(adreno_gpu) || adreno_is_a508(adreno_gpu) ||
...@@ -1770,7 +1770,7 @@ struct msm_gpu *a5xx_gpu_init(struct drm_device *dev) ...@@ -1770,7 +1770,7 @@ struct msm_gpu *a5xx_gpu_init(struct drm_device *dev)
nr_rings = 4; nr_rings = 4;
if (adreno_cmp_rev(ADRENO_REV(5, 1, 0, ANY_ID), config->rev)) if (config->info->revn == 510)
nr_rings = 1; nr_rings = 1;
ret = adreno_gpu_init(dev, pdev, adreno_gpu, &funcs, nr_rings); ret = adreno_gpu_init(dev, pdev, adreno_gpu, &funcs, nr_rings);
......
...@@ -179,7 +179,7 @@ static void a540_lm_setup(struct msm_gpu *gpu) ...@@ -179,7 +179,7 @@ static void a540_lm_setup(struct msm_gpu *gpu)
/* The battery current limiter isn't enabled for A540 */ /* The battery current limiter isn't enabled for A540 */
config = AGC_LM_CONFIG_BCL_DISABLED; config = AGC_LM_CONFIG_BCL_DISABLED;
config |= adreno_gpu->rev.patchid << AGC_LM_CONFIG_GPU_VERSION_SHIFT; config |= adreno_patchid(adreno_gpu) << AGC_LM_CONFIG_GPU_VERSION_SHIFT;
/* For now disable GPMU side throttling */ /* For now disable GPMU side throttling */
config |= AGC_LM_CONFIG_THROTTLE_DISABLE; config |= AGC_LM_CONFIG_THROTTLE_DISABLE;
......
...@@ -1166,6 +1166,9 @@ static inline uint32_t A6XX_CP_ROQ_THRESHOLDS_2_ROQ_SIZE(uint32_t val) ...@@ -1166,6 +1166,9 @@ static inline uint32_t A6XX_CP_ROQ_THRESHOLDS_2_ROQ_SIZE(uint32_t val)
#define REG_A6XX_CP_DBG_ECO_CNTL 0x00000843 #define REG_A6XX_CP_DBG_ECO_CNTL 0x00000843
#define REG_A6XX_CP_PROTECT_CNTL 0x0000084f #define REG_A6XX_CP_PROTECT_CNTL 0x0000084f
#define A6XX_CP_PROTECT_CNTL_LAST_SPAN_INF_RANGE 0x00000008
#define A6XX_CP_PROTECT_CNTL_ACCESS_FAULT_ON_VIOL_EN 0x00000002
#define A6XX_CP_PROTECT_CNTL_ACCESS_PROT_EN 0x00000001
static inline uint32_t REG_A6XX_CP_SCRATCH(uint32_t i0) { return 0x00000883 + 0x1*i0; } static inline uint32_t REG_A6XX_CP_SCRATCH(uint32_t i0) { return 0x00000883 + 0x1*i0; }
......
...@@ -792,10 +792,22 @@ static int a6xx_gmu_fw_start(struct a6xx_gmu *gmu, unsigned int state) ...@@ -792,10 +792,22 @@ static int a6xx_gmu_fw_start(struct a6xx_gmu *gmu, unsigned int state)
gmu_write(gmu, REG_A6XX_GMU_AHB_FENCE_RANGE_0, gmu_write(gmu, REG_A6XX_GMU_AHB_FENCE_RANGE_0,
(1 << 31) | (0xa << 18) | (0xa0)); (1 << 31) | (0xa << 18) | (0xa0));
chipid = adreno_gpu->rev.core << 24; /*
chipid |= adreno_gpu->rev.major << 16; * Snapshots toggle the NMI bit which will result in a jump to the NMI
chipid |= adreno_gpu->rev.minor << 12; * handler instead of __main. Set the M3 config value to avoid that.
chipid |= adreno_gpu->rev.patchid << 8; */
gmu_write(gmu, REG_A6XX_GMU_CM3_CFG, 0x4052);
/*
* Note that the GMU has a slightly different layout for
* chip_id, for whatever reason, so a bit of massaging
* is needed. The upper 16b are the same, but minor and
* patchid are packed in four bits each with the lower
* 8b unused:
*/
chipid = adreno_gpu->chip_id & 0xffff0000;
chipid |= (adreno_gpu->chip_id << 4) & 0xf000; /* minor */
chipid |= (adreno_gpu->chip_id << 8) & 0x0f00; /* patchid */
gmu_write(gmu, REG_A6XX_GMU_HFI_SFR_ADDR, chipid); gmu_write(gmu, REG_A6XX_GMU_HFI_SFR_ADDR, chipid);
...@@ -889,6 +901,13 @@ static void a6xx_gmu_force_off(struct a6xx_gmu *gmu) ...@@ -889,6 +901,13 @@ static void a6xx_gmu_force_off(struct a6xx_gmu *gmu)
/* Make sure there are no outstanding RPMh votes */ /* Make sure there are no outstanding RPMh votes */
a6xx_gmu_rpmh_off(gmu); a6xx_gmu_rpmh_off(gmu);
/* Clear the WRITEDROPPED fields and put fence into allow mode */
gmu_write(gmu, REG_A6XX_GMU_AHB_FENCE_STATUS_CLR, 0x7);
gmu_write(gmu, REG_A6XX_GMU_AO_AHB_FENCE_CTRL, 0);
/* Make sure the above writes go through */
wmb();
/* Halt the gmu cm3 core */ /* Halt the gmu cm3 core */
gmu_write(gmu, REG_A6XX_GMU_CM3_SYSRESET, 1); gmu_write(gmu, REG_A6XX_GMU_CM3_SYSRESET, 1);
...@@ -1437,8 +1456,15 @@ void a6xx_gmu_remove(struct a6xx_gpu *a6xx_gpu) ...@@ -1437,8 +1456,15 @@ void a6xx_gmu_remove(struct a6xx_gpu *a6xx_gpu)
struct a6xx_gmu *gmu = &a6xx_gpu->gmu; struct a6xx_gmu *gmu = &a6xx_gpu->gmu;
struct platform_device *pdev = to_platform_device(gmu->dev); struct platform_device *pdev = to_platform_device(gmu->dev);
if (!gmu->initialized) mutex_lock(&gmu->lock);
if (!gmu->initialized) {
mutex_unlock(&gmu->lock);
return; return;
}
gmu->initialized = false;
mutex_unlock(&gmu->lock);
pm_runtime_force_suspend(gmu->dev); pm_runtime_force_suspend(gmu->dev);
...@@ -1468,8 +1494,6 @@ void a6xx_gmu_remove(struct a6xx_gpu *a6xx_gpu) ...@@ -1468,8 +1494,6 @@ void a6xx_gmu_remove(struct a6xx_gpu *a6xx_gpu)
/* Drop reference taken in of_find_device_by_node */ /* Drop reference taken in of_find_device_by_node */
put_device(gmu->dev); put_device(gmu->dev);
gmu->initialized = false;
} }
static int cxpd_notifier_cb(struct notifier_block *nb, static int cxpd_notifier_cb(struct notifier_block *nb,
...@@ -1619,7 +1643,7 @@ int a6xx_gmu_init(struct a6xx_gpu *a6xx_gpu, struct device_node *node) ...@@ -1619,7 +1643,7 @@ int a6xx_gmu_init(struct a6xx_gpu *a6xx_gpu, struct device_node *node)
SZ_256K - SZ_16K, 0x44000, "dcache"); SZ_256K - SZ_16K, 0x44000, "dcache");
if (ret) if (ret)
goto err_memory; goto err_memory;
} else if (adreno_is_a630(adreno_gpu) || adreno_is_a615_family(adreno_gpu)) { } else if (adreno_is_a630_family(adreno_gpu)) {
/* HFI v1, has sptprac */ /* HFI v1, has sptprac */
gmu->legacy = true; gmu->legacy = true;
...@@ -1629,13 +1653,13 @@ int a6xx_gmu_init(struct a6xx_gpu *a6xx_gpu, struct device_node *node) ...@@ -1629,13 +1653,13 @@ int a6xx_gmu_init(struct a6xx_gpu *a6xx_gpu, struct device_node *node)
goto err_memory; goto err_memory;
} }
/* Allocate memory for for the HFI queues */ /* Allocate memory for the GMU log region */
ret = a6xx_gmu_memory_alloc(gmu, &gmu->hfi, SZ_16K, 0, "hfi"); ret = a6xx_gmu_memory_alloc(gmu, &gmu->log, SZ_16K, 0, "log");
if (ret) if (ret)
goto err_memory; goto err_memory;
/* Allocate memory for the GMU log region */ /* Allocate memory for for the HFI queues */
ret = a6xx_gmu_memory_alloc(gmu, &gmu->log, SZ_4K, 0, "log"); ret = a6xx_gmu_memory_alloc(gmu, &gmu->hfi, SZ_16K, 0, "hfi");
if (ret) if (ret)
goto err_memory; goto err_memory;
......
...@@ -425,6 +425,8 @@ static inline uint32_t A6XX_GMU_GPU_NAP_CTRL_SID(uint32_t val) ...@@ -425,6 +425,8 @@ static inline uint32_t A6XX_GMU_GPU_NAP_CTRL_SID(uint32_t val)
#define REG_A6XX_GMU_AHB_FENCE_STATUS 0x00009313 #define REG_A6XX_GMU_AHB_FENCE_STATUS 0x00009313
#define REG_A6XX_GMU_AHB_FENCE_STATUS_CLR 0x00009314
#define REG_A6XX_GMU_RBBM_INT_UNMASKED_STATUS 0x00009315 #define REG_A6XX_GMU_RBBM_INT_UNMASKED_STATUS 0x00009315
#define REG_A6XX_GMU_AO_SPARE_CNTL 0x00009316 #define REG_A6XX_GMU_AO_SPARE_CNTL 0x00009316
......
...@@ -930,10 +930,16 @@ static void a6xx_set_cp_protect(struct msm_gpu *gpu) ...@@ -930,10 +930,16 @@ static void a6xx_set_cp_protect(struct msm_gpu *gpu)
* protect violation and select the last span to protect from the start * protect violation and select the last span to protect from the start
* address all the way to the end of the register address space * address all the way to the end of the register address space
*/ */
gpu_write(gpu, REG_A6XX_CP_PROTECT_CNTL, BIT(0) | BIT(1) | BIT(3)); gpu_write(gpu, REG_A6XX_CP_PROTECT_CNTL,
A6XX_CP_PROTECT_CNTL_ACCESS_PROT_EN |
for (i = 0; i < count - 1; i++) A6XX_CP_PROTECT_CNTL_ACCESS_FAULT_ON_VIOL_EN |
A6XX_CP_PROTECT_CNTL_LAST_SPAN_INF_RANGE);
for (i = 0; i < count - 1; i++) {
/* Intentionally skip writing to some registers */
if (regs[i])
gpu_write(gpu, REG_A6XX_CP_PROTECT(i), regs[i]); gpu_write(gpu, REG_A6XX_CP_PROTECT(i), regs[i]);
}
/* last CP_PROTECT to have "infinite" length on the last entry */ /* last CP_PROTECT to have "infinite" length on the last entry */
gpu_write(gpu, REG_A6XX_CP_PROTECT(count_max - 1), regs[i]); gpu_write(gpu, REG_A6XX_CP_PROTECT(count_max - 1), regs[i]);
} }
...@@ -1195,7 +1201,9 @@ static int hw_init(struct msm_gpu *gpu) ...@@ -1195,7 +1201,9 @@ static int hw_init(struct msm_gpu *gpu)
if (!adreno_has_gmu_wrapper(adreno_gpu)) { if (!adreno_has_gmu_wrapper(adreno_gpu)) {
/* Make sure the GMU keeps the GPU on while we set it up */ /* Make sure the GMU keeps the GPU on while we set it up */
a6xx_gmu_set_oob(&a6xx_gpu->gmu, GMU_OOB_GPU_SET); ret = a6xx_gmu_set_oob(&a6xx_gpu->gmu, GMU_OOB_GPU_SET);
if (ret)
return ret;
} }
/* Clear GBIF halt in case GX domain was not collapsed */ /* Clear GBIF halt in case GX domain was not collapsed */
...@@ -1270,7 +1278,7 @@ static int hw_init(struct msm_gpu *gpu) ...@@ -1270,7 +1278,7 @@ static int hw_init(struct msm_gpu *gpu)
gpu_write64(gpu, REG_A6XX_UCHE_GMEM_RANGE_MIN, 0x00100000); gpu_write64(gpu, REG_A6XX_UCHE_GMEM_RANGE_MIN, 0x00100000);
gpu_write64(gpu, REG_A6XX_UCHE_GMEM_RANGE_MAX, gpu_write64(gpu, REG_A6XX_UCHE_GMEM_RANGE_MAX,
0x00100000 + adreno_gpu->gmem - 1); 0x00100000 + adreno_gpu->info->gmem - 1);
} }
gpu_write(gpu, REG_A6XX_UCHE_FILTER_CNTL, 0x804); gpu_write(gpu, REG_A6XX_UCHE_FILTER_CNTL, 0x804);
...@@ -1729,16 +1737,6 @@ static irqreturn_t a6xx_irq(struct msm_gpu *gpu) ...@@ -1729,16 +1737,6 @@ static irqreturn_t a6xx_irq(struct msm_gpu *gpu)
return IRQ_HANDLED; return IRQ_HANDLED;
} }
static void a6xx_llc_rmw(struct a6xx_gpu *a6xx_gpu, u32 reg, u32 mask, u32 or)
{
return msm_rmw(a6xx_gpu->llc_mmio + (reg << 2), mask, or);
}
static void a6xx_llc_write(struct a6xx_gpu *a6xx_gpu, u32 reg, u32 value)
{
msm_writel(value, a6xx_gpu->llc_mmio + (reg << 2));
}
static void a6xx_llc_deactivate(struct a6xx_gpu *a6xx_gpu) static void a6xx_llc_deactivate(struct a6xx_gpu *a6xx_gpu)
{ {
llcc_slice_deactivate(a6xx_gpu->llc_slice); llcc_slice_deactivate(a6xx_gpu->llc_slice);
...@@ -2091,9 +2089,7 @@ static void a6xx_destroy(struct msm_gpu *gpu) ...@@ -2091,9 +2089,7 @@ static void a6xx_destroy(struct msm_gpu *gpu)
a6xx_llc_slices_destroy(a6xx_gpu); a6xx_llc_slices_destroy(a6xx_gpu);
mutex_lock(&a6xx_gpu->gmu.lock);
a6xx_gmu_remove(a6xx_gpu); a6xx_gmu_remove(a6xx_gpu);
mutex_unlock(&a6xx_gpu->gmu.lock);
adreno_gpu_cleanup(adreno_gpu); adreno_gpu_cleanup(adreno_gpu);
...@@ -2204,159 +2200,19 @@ static bool a6xx_progress(struct msm_gpu *gpu, struct msm_ringbuffer *ring) ...@@ -2204,159 +2200,19 @@ static bool a6xx_progress(struct msm_gpu *gpu, struct msm_ringbuffer *ring)
return progress; return progress;
} }
static u32 a610_get_speed_bin(u32 fuse) static u32 fuse_to_supp_hw(const struct adreno_info *info, u32 fuse)
{
/*
* There are (at least) three SoCs implementing A610: SM6125 (trinket),
* SM6115 (bengal) and SM6225 (khaje). Trinket does not have speedbinning,
* as only a single SKU exists and we don't support khaje upstream yet.
* Hence, this matching table is only valid for bengal and can be easily
* expanded if need be.
*/
if (fuse == 0)
return 0;
else if (fuse == 206)
return 1;
else if (fuse == 200)
return 2;
else if (fuse == 157)
return 3;
else if (fuse == 127)
return 4;
return UINT_MAX;
}
static u32 a618_get_speed_bin(u32 fuse)
{ {
if (fuse == 0) if (!info->speedbins)
return 0;
else if (fuse == 169)
return 1;
else if (fuse == 174)
return 2;
return UINT_MAX; return UINT_MAX;
}
static u32 a619_holi_get_speed_bin(u32 fuse) for (int i = 0; info->speedbins[i].fuse != SHRT_MAX; i++)
{ if (info->speedbins[i].fuse == fuse)
/* return BIT(info->speedbins[i].speedbin);
* There are (at least) two SoCs implementing A619_holi: SM4350 (holi)
* and SM6375 (blair). Limit the fuse matching to the corresponding
* SoC to prevent bogus frequency setting (as improbable as it may be,
* given unexpected fuse values are.. unexpected! But still possible.)
*/
if (fuse == 0)
return 0;
if (of_machine_is_compatible("qcom,sm4350")) {
if (fuse == 138)
return 1;
else if (fuse == 92)
return 2;
} else if (of_machine_is_compatible("qcom,sm6375")) {
if (fuse == 190)
return 1;
else if (fuse == 177)
return 2;
} else
pr_warn("Unknown SoC implementing A619_holi!\n");
return UINT_MAX; return UINT_MAX;
} }
static u32 a619_get_speed_bin(u32 fuse) static int a6xx_set_supported_hw(struct device *dev, const struct adreno_info *info)
{
if (fuse == 0)
return 0;
else if (fuse == 120)
return 4;
else if (fuse == 138)
return 3;
else if (fuse == 169)
return 2;
else if (fuse == 180)
return 1;
return UINT_MAX;
}
static u32 a640_get_speed_bin(u32 fuse)
{
if (fuse == 0)
return 0;
else if (fuse == 1)
return 1;
return UINT_MAX;
}
static u32 a650_get_speed_bin(u32 fuse)
{
if (fuse == 0)
return 0;
else if (fuse == 1)
return 1;
/* Yep, 2 and 3 are swapped! :/ */
else if (fuse == 2)
return 3;
else if (fuse == 3)
return 2;
return UINT_MAX;
}
static u32 adreno_7c3_get_speed_bin(u32 fuse)
{
if (fuse == 0)
return 0;
else if (fuse == 117)
return 0;
else if (fuse == 190)
return 1;
return UINT_MAX;
}
static u32 fuse_to_supp_hw(struct device *dev, struct adreno_gpu *adreno_gpu, u32 fuse)
{
u32 val = UINT_MAX;
if (adreno_is_a610(adreno_gpu))
val = a610_get_speed_bin(fuse);
if (adreno_is_a618(adreno_gpu))
val = a618_get_speed_bin(fuse);
else if (adreno_is_a619_holi(adreno_gpu))
val = a619_holi_get_speed_bin(fuse);
else if (adreno_is_a619(adreno_gpu))
val = a619_get_speed_bin(fuse);
else if (adreno_is_7c3(adreno_gpu))
val = adreno_7c3_get_speed_bin(fuse);
else if (adreno_is_a640(adreno_gpu))
val = a640_get_speed_bin(fuse);
else if (adreno_is_a650(adreno_gpu))
val = a650_get_speed_bin(fuse);
if (val == UINT_MAX) {
DRM_DEV_ERROR(dev,
"missing support for speed-bin: %u. Some OPPs may not be supported by hardware\n",
fuse);
return UINT_MAX;
}
return (1 << val);
}
static int a6xx_set_supported_hw(struct device *dev, struct adreno_gpu *adreno_gpu)
{ {
u32 supp_hw; u32 supp_hw;
u32 speedbin; u32 speedbin;
...@@ -2375,7 +2231,14 @@ static int a6xx_set_supported_hw(struct device *dev, struct adreno_gpu *adreno_g ...@@ -2375,7 +2231,14 @@ static int a6xx_set_supported_hw(struct device *dev, struct adreno_gpu *adreno_g
return ret; return ret;
} }
supp_hw = fuse_to_supp_hw(dev, adreno_gpu, speedbin); supp_hw = fuse_to_supp_hw(info, speedbin);
if (supp_hw == UINT_MAX) {
DRM_DEV_ERROR(dev,
"missing support for speed-bin: %u. Some OPPs may not be supported by hardware\n",
speedbin);
return UINT_MAX;
}
ret = devm_pm_opp_set_supported_hw(dev, &supp_hw, 1); ret = devm_pm_opp_set_supported_hw(dev, &supp_hw, 1);
if (ret) if (ret)
...@@ -2449,7 +2312,6 @@ struct msm_gpu *a6xx_gpu_init(struct drm_device *dev) ...@@ -2449,7 +2312,6 @@ struct msm_gpu *a6xx_gpu_init(struct drm_device *dev)
struct msm_drm_private *priv = dev->dev_private; struct msm_drm_private *priv = dev->dev_private;
struct platform_device *pdev = priv->gpu_pdev; struct platform_device *pdev = priv->gpu_pdev;
struct adreno_platform_config *config = pdev->dev.platform_data; struct adreno_platform_config *config = pdev->dev.platform_data;
const struct adreno_info *info;
struct device_node *node; struct device_node *node;
struct a6xx_gpu *a6xx_gpu; struct a6xx_gpu *a6xx_gpu;
struct adreno_gpu *adreno_gpu; struct adreno_gpu *adreno_gpu;
...@@ -2474,29 +2336,12 @@ struct msm_gpu *a6xx_gpu_init(struct drm_device *dev) ...@@ -2474,29 +2336,12 @@ struct msm_gpu *a6xx_gpu_init(struct drm_device *dev)
adreno_gpu->gmu_is_wrapper = of_device_is_compatible(node, "qcom,adreno-gmu-wrapper"); adreno_gpu->gmu_is_wrapper = of_device_is_compatible(node, "qcom,adreno-gmu-wrapper");
/* adreno_gpu->base.hw_apriv =
* We need to know the platform type before calling into adreno_gpu_init !!(config->info->quirks & ADRENO_QUIRK_HAS_HW_APRIV);
* so that the hw_apriv flag can be correctly set. Snoop into the info
* and grab the revision number
*/
info = adreno_info(config->rev);
if (!info)
return ERR_PTR(-EINVAL);
/* Assign these early so that we can use the is_aXYZ helpers */
/* Numeric revision IDs (e.g. 630) */
adreno_gpu->revn = info->revn;
/* New-style ADRENO_REV()-only */
adreno_gpu->rev = info->rev;
/* Quirk data */
adreno_gpu->info = info;
if (adreno_is_a650(adreno_gpu) || adreno_is_a660_family(adreno_gpu))
adreno_gpu->base.hw_apriv = true;
a6xx_llc_slices_init(pdev, a6xx_gpu); a6xx_llc_slices_init(pdev, a6xx_gpu);
ret = a6xx_set_supported_hw(&pdev->dev, adreno_gpu); ret = a6xx_set_supported_hw(&pdev->dev, config->info);
if (ret) { if (ret) {
a6xx_destroy(&(a6xx_gpu->base.base)); a6xx_destroy(&(a6xx_gpu->base.base));
return ERR_PTR(ret); return ERR_PTR(ret);
......
...@@ -39,8 +39,8 @@ struct a6xx_gpu { ...@@ -39,8 +39,8 @@ struct a6xx_gpu {
/* /*
* Given a register and a count, return a value to program into * Given a register and a count, return a value to program into
* REG_CP_PROTECT_REG(n) - this will block both reads and writes for _len * REG_CP_PROTECT_REG(n) - this will block both reads and writes for
* registers starting at _reg. * _len + 1 registers starting at _reg.
*/ */
#define A6XX_PROTECT_NORDWR(_reg, _len) \ #define A6XX_PROTECT_NORDWR(_reg, _len) \
((1 << 31) | \ ((1 << 31) | \
...@@ -62,6 +62,21 @@ static inline bool a6xx_has_gbif(struct adreno_gpu *gpu) ...@@ -62,6 +62,21 @@ static inline bool a6xx_has_gbif(struct adreno_gpu *gpu)
return true; return true;
} }
static inline void a6xx_llc_rmw(struct a6xx_gpu *a6xx_gpu, u32 reg, u32 mask, u32 or)
{
return msm_rmw(a6xx_gpu->llc_mmio + (reg << 2), mask, or);
}
static inline u32 a6xx_llc_read(struct a6xx_gpu *a6xx_gpu, u32 reg)
{
return msm_readl(a6xx_gpu->llc_mmio + (reg << 2));
}
static inline void a6xx_llc_write(struct a6xx_gpu *a6xx_gpu, u32 reg, u32 value)
{
msm_writel(value, a6xx_gpu->llc_mmio + (reg << 2));
}
#define shadowptr(_a6xx_gpu, _ring) ((_a6xx_gpu)->shadow_iova + \ #define shadowptr(_a6xx_gpu, _ring) ((_a6xx_gpu)->shadow_iova + \
((_ring)->id * sizeof(uint32_t))) ((_ring)->id * sizeof(uint32_t)))
......
This diff is collapsed.
...@@ -320,16 +320,13 @@ int adreno_get_param(struct msm_gpu *gpu, struct msm_file_private *ctx, ...@@ -320,16 +320,13 @@ int adreno_get_param(struct msm_gpu *gpu, struct msm_file_private *ctx,
*value = adreno_gpu->info->revn; *value = adreno_gpu->info->revn;
return 0; return 0;
case MSM_PARAM_GMEM_SIZE: case MSM_PARAM_GMEM_SIZE:
*value = adreno_gpu->gmem; *value = adreno_gpu->info->gmem;
return 0; return 0;
case MSM_PARAM_GMEM_BASE: case MSM_PARAM_GMEM_BASE:
*value = !adreno_is_a650_family(adreno_gpu) ? 0x100000 : 0; *value = !adreno_is_a650_family(adreno_gpu) ? 0x100000 : 0;
return 0; return 0;
case MSM_PARAM_CHIP_ID: case MSM_PARAM_CHIP_ID:
*value = (uint64_t)adreno_gpu->rev.patchid | *value = adreno_gpu->chip_id;
((uint64_t)adreno_gpu->rev.minor << 8) |
((uint64_t)adreno_gpu->rev.major << 16) |
((uint64_t)adreno_gpu->rev.core << 24);
if (!adreno_gpu->info->revn) if (!adreno_gpu->info->revn)
*value |= ((uint64_t) adreno_gpu->speedbin) << 32; *value |= ((uint64_t) adreno_gpu->speedbin) << 32;
return 0; return 0;
...@@ -400,17 +397,9 @@ int adreno_set_param(struct msm_gpu *gpu, struct msm_file_private *ctx, ...@@ -400,17 +397,9 @@ int adreno_set_param(struct msm_gpu *gpu, struct msm_file_private *ctx,
case MSM_PARAM_CMDLINE: { case MSM_PARAM_CMDLINE: {
char *str, **paramp; char *str, **paramp;
str = kmalloc(len + 1, GFP_KERNEL); str = memdup_user_nul(u64_to_user_ptr(value), len);
if (!str) if (IS_ERR(str))
return -ENOMEM; return PTR_ERR(str);
if (copy_from_user(str, u64_to_user_ptr(value), len)) {
kfree(str);
return -EFAULT;
}
/* Ensure string is null terminated: */
str[len] = '\0';
mutex_lock(&gpu->lock); mutex_lock(&gpu->lock);
...@@ -847,10 +836,9 @@ void adreno_show(struct msm_gpu *gpu, struct msm_gpu_state *state, ...@@ -847,10 +836,9 @@ void adreno_show(struct msm_gpu *gpu, struct msm_gpu_state *state,
if (IS_ERR_OR_NULL(state)) if (IS_ERR_OR_NULL(state))
return; return;
drm_printf(p, "revision: %d (%d.%d.%d.%d)\n", drm_printf(p, "revision: %u (%"ADRENO_CHIPID_FMT")\n",
adreno_gpu->info->revn, adreno_gpu->rev.core, adreno_gpu->info->revn,
adreno_gpu->rev.major, adreno_gpu->rev.minor, ADRENO_CHIPID_ARGS(adreno_gpu->chip_id));
adreno_gpu->rev.patchid);
/* /*
* If this is state collected due to iova fault, so fault related info * If this is state collected due to iova fault, so fault related info
* *
...@@ -921,10 +909,9 @@ void adreno_dump_info(struct msm_gpu *gpu) ...@@ -921,10 +909,9 @@ void adreno_dump_info(struct msm_gpu *gpu)
struct adreno_gpu *adreno_gpu = to_adreno_gpu(gpu); struct adreno_gpu *adreno_gpu = to_adreno_gpu(gpu);
int i; int i;
printk("revision: %d (%d.%d.%d.%d)\n", printk("revision: %u (%"ADRENO_CHIPID_FMT")\n",
adreno_gpu->info->revn, adreno_gpu->rev.core, adreno_gpu->info->revn,
adreno_gpu->rev.major, adreno_gpu->rev.minor, ADRENO_CHIPID_ARGS(adreno_gpu->chip_id));
adreno_gpu->rev.patchid);
for (i = 0; i < gpu->nr_rings; i++) { for (i = 0; i < gpu->nr_rings; i++) {
struct msm_ringbuffer *ring = gpu->rb[i]; struct msm_ringbuffer *ring = gpu->rb[i];
...@@ -1041,14 +1028,16 @@ int adreno_gpu_ocmem_init(struct device *dev, struct adreno_gpu *adreno_gpu, ...@@ -1041,14 +1028,16 @@ int adreno_gpu_ocmem_init(struct device *dev, struct adreno_gpu *adreno_gpu,
return PTR_ERR(ocmem); return PTR_ERR(ocmem);
} }
ocmem_hdl = ocmem_allocate(ocmem, OCMEM_GRAPHICS, adreno_gpu->gmem); ocmem_hdl = ocmem_allocate(ocmem, OCMEM_GRAPHICS, adreno_gpu->info->gmem);
if (IS_ERR(ocmem_hdl)) if (IS_ERR(ocmem_hdl))
return PTR_ERR(ocmem_hdl); return PTR_ERR(ocmem_hdl);
adreno_ocmem->ocmem = ocmem; adreno_ocmem->ocmem = ocmem;
adreno_ocmem->base = ocmem_hdl->addr; adreno_ocmem->base = ocmem_hdl->addr;
adreno_ocmem->hdl = ocmem_hdl; adreno_ocmem->hdl = ocmem_hdl;
adreno_gpu->gmem = ocmem_hdl->len;
if (WARN_ON(ocmem_hdl->len != adreno_gpu->info->gmem))
return -ENOMEM;
return 0; return 0;
} }
...@@ -1073,13 +1062,19 @@ int adreno_gpu_init(struct drm_device *drm, struct platform_device *pdev, ...@@ -1073,13 +1062,19 @@ int adreno_gpu_init(struct drm_device *drm, struct platform_device *pdev,
struct adreno_platform_config *config = dev->platform_data; struct adreno_platform_config *config = dev->platform_data;
struct msm_gpu_config adreno_gpu_config = { 0 }; struct msm_gpu_config adreno_gpu_config = { 0 };
struct msm_gpu *gpu = &adreno_gpu->base; struct msm_gpu *gpu = &adreno_gpu->base;
struct adreno_rev *rev = &config->rev;
const char *gpu_name; const char *gpu_name;
u32 speedbin; u32 speedbin;
int ret; int ret;
adreno_gpu->funcs = funcs;
adreno_gpu->info = config->info;
adreno_gpu->chip_id = config->chip_id;
gpu->allow_relocs = config->info->family < ADRENO_6XX_GEN1;
/* Only handle the core clock when GMU is not in use (or is absent). */ /* Only handle the core clock when GMU is not in use (or is absent). */
if (adreno_has_gmu_wrapper(adreno_gpu) || config->rev.core < 6) { if (adreno_has_gmu_wrapper(adreno_gpu) ||
adreno_gpu->info->family < ADRENO_6XX_GEN1) {
/* /*
* This can only be done before devm_pm_opp_of_add_table(), or * This can only be done before devm_pm_opp_of_add_table(), or
* dev_pm_opp_set_config() will WARN_ON() * dev_pm_opp_set_config() will WARN_ON()
...@@ -1095,24 +1090,14 @@ int adreno_gpu_init(struct drm_device *drm, struct platform_device *pdev, ...@@ -1095,24 +1090,14 @@ int adreno_gpu_init(struct drm_device *drm, struct platform_device *pdev,
devm_pm_opp_set_clkname(dev, "core"); devm_pm_opp_set_clkname(dev, "core");
} }
adreno_gpu->funcs = funcs;
adreno_gpu->info = adreno_info(config->rev);
adreno_gpu->gmem = adreno_gpu->info->gmem;
adreno_gpu->revn = adreno_gpu->info->revn;
adreno_gpu->rev = *rev;
if (adreno_read_speedbin(dev, &speedbin) || !speedbin) if (adreno_read_speedbin(dev, &speedbin) || !speedbin)
speedbin = 0xffff; speedbin = 0xffff;
adreno_gpu->speedbin = (uint16_t) (0xffff & speedbin); adreno_gpu->speedbin = (uint16_t) (0xffff & speedbin);
gpu_name = adreno_gpu->info->name; gpu_name = devm_kasprintf(dev, GFP_KERNEL, "%"ADRENO_CHIPID_FMT,
if (!gpu_name) { ADRENO_CHIPID_ARGS(config->chip_id));
gpu_name = devm_kasprintf(dev, GFP_KERNEL, "%d.%d.%d.%d",
rev->core, rev->major, rev->minor,
rev->patchid);
if (!gpu_name) if (!gpu_name)
return -ENOMEM; return -ENOMEM;
}
adreno_gpu_config.ioname = "kgsl_3d0_reg_memory"; adreno_gpu_config.ioname = "kgsl_3d0_reg_memory";
......
...@@ -29,21 +29,40 @@ enum { ...@@ -29,21 +29,40 @@ enum {
ADRENO_FW_MAX, ADRENO_FW_MAX,
}; };
/**
* @enum adreno_family: identify generation and possibly sub-generation
*
* In some cases there are distinct sub-generations within a major revision
* so it helps to be able to group the GPU devices by generation and if
* necessary sub-generation.
*/
enum adreno_family {
ADRENO_2XX_GEN1, /* a20x */
ADRENO_2XX_GEN2, /* a22x */
ADRENO_3XX,
ADRENO_4XX,
ADRENO_5XX,
ADRENO_6XX_GEN1, /* a630 family */
ADRENO_6XX_GEN2, /* a640 family */
ADRENO_6XX_GEN3, /* a650 family */
ADRENO_6XX_GEN4, /* a660 family */
};
#define ADRENO_QUIRK_TWO_PASS_USE_WFI BIT(0) #define ADRENO_QUIRK_TWO_PASS_USE_WFI BIT(0)
#define ADRENO_QUIRK_FAULT_DETECT_MASK BIT(1) #define ADRENO_QUIRK_FAULT_DETECT_MASK BIT(1)
#define ADRENO_QUIRK_LMLOADKILL_DISABLE BIT(2) #define ADRENO_QUIRK_LMLOADKILL_DISABLE BIT(2)
#define ADRENO_QUIRK_HAS_HW_APRIV BIT(3)
#define ADRENO_QUIRK_HAS_CACHED_COHERENT BIT(4)
struct adreno_rev { /* Helper for formating the chip_id in the way that userspace tools like
uint8_t core; * crashdec expect.
uint8_t major; */
uint8_t minor; #define ADRENO_CHIPID_FMT "u.%u.%u.%u"
uint8_t patchid; #define ADRENO_CHIPID_ARGS(_c) \
}; (((_c) >> 24) & 0xff), \
(((_c) >> 16) & 0xff), \
#define ANY_ID 0xff (((_c) >> 8) & 0xff), \
((_c) & 0xff)
#define ADRENO_REV(core, major, minor, patchid) \
((struct adreno_rev){ core, major, minor, patchid })
struct adreno_gpu_funcs { struct adreno_gpu_funcs {
struct msm_gpu_funcs base; struct msm_gpu_funcs base;
...@@ -58,10 +77,21 @@ struct adreno_reglist { ...@@ -58,10 +77,21 @@ struct adreno_reglist {
extern const struct adreno_reglist a612_hwcg[], a615_hwcg[], a630_hwcg[], a640_hwcg[], a650_hwcg[]; extern const struct adreno_reglist a612_hwcg[], a615_hwcg[], a630_hwcg[], a640_hwcg[], a650_hwcg[];
extern const struct adreno_reglist a660_hwcg[], a690_hwcg[]; extern const struct adreno_reglist a660_hwcg[], a690_hwcg[];
struct adreno_speedbin {
uint16_t fuse;
uint16_t speedbin;
};
struct adreno_info { struct adreno_info {
struct adreno_rev rev; const char *machine;
/**
* @chipids: Table of matching chip-ids
*
* Terminated with 0 sentinal
*/
uint32_t *chip_ids;
enum adreno_family family;
uint32_t revn; uint32_t revn;
const char *name;
const char *fw[ADRENO_FW_MAX]; const char *fw[ADRENO_FW_MAX];
uint32_t gmem; uint32_t gmem;
u64 quirks; u64 quirks;
...@@ -70,16 +100,39 @@ struct adreno_info { ...@@ -70,16 +100,39 @@ struct adreno_info {
u32 inactive_period; u32 inactive_period;
const struct adreno_reglist *hwcg; const struct adreno_reglist *hwcg;
u64 address_space_size; u64 address_space_size;
/**
* @speedbins: Optional table of fuse to speedbin mappings
*
* Consists of pairs of fuse, index mappings, terminated with
* {SHRT_MAX, 0} sentinal.
*/
struct adreno_speedbin *speedbins;
}; };
const struct adreno_info *adreno_info(struct adreno_rev rev); #define ADRENO_CHIP_IDS(tbl...) (uint32_t[]) { tbl, 0 }
/*
* Helper to build a speedbin table, ie. the table:
* fuse | speedbin
* -----+---------
* 0 | 0
* 169 | 1
* 174 | 2
*
* would be declared as:
*
* .speedbins = ADRENO_SPEEDBINS(
* { 0, 0 },
* { 169, 1 },
* { 174, 2 },
* ),
*/
#define ADRENO_SPEEDBINS(tbl...) (struct adreno_speedbin[]) { tbl {SHRT_MAX, 0} }
struct adreno_gpu { struct adreno_gpu {
struct msm_gpu base; struct msm_gpu base;
struct adreno_rev rev;
const struct adreno_info *info; const struct adreno_info *info;
uint32_t gmem; /* actual gmem size */ uint32_t chip_id;
uint32_t revn; /* numeric revision name */
uint16_t speedbin; uint16_t speedbin;
const struct adreno_gpu_funcs *funcs; const struct adreno_gpu_funcs *funcs;
...@@ -128,7 +181,8 @@ struct adreno_ocmem { ...@@ -128,7 +181,8 @@ struct adreno_ocmem {
/* platform config data (ie. from DT, or pdata) */ /* platform config data (ie. from DT, or pdata) */
struct adreno_platform_config { struct adreno_platform_config {
struct adreno_rev rev; uint32_t chip_id;
const struct adreno_info *info;
}; };
#define ADRENO_IDLE_TIMEOUT msecs_to_jiffies(1000) #define ADRENO_IDLE_TIMEOUT msecs_to_jiffies(1000)
...@@ -145,14 +199,21 @@ struct adreno_platform_config { ...@@ -145,14 +199,21 @@ struct adreno_platform_config {
__ret; \ __ret; \
}) })
bool adreno_cmp_rev(struct adreno_rev rev1, struct adreno_rev rev2); static inline uint8_t adreno_patchid(const struct adreno_gpu *gpu)
{
/* It is probably ok to assume legacy "adreno_rev" format
* for all a6xx devices, but probably best to limit this
* to older things.
*/
WARN_ON_ONCE(gpu->info->family >= ADRENO_6XX_GEN1);
return gpu->chip_id & 0xff;
}
static inline bool adreno_is_revn(const struct adreno_gpu *gpu, uint32_t revn) static inline bool adreno_is_revn(const struct adreno_gpu *gpu, uint32_t revn)
{ {
/* revn can be zero, but if not is set at same time as info */ if (WARN_ON_ONCE(!gpu->info))
WARN_ON_ONCE(!gpu->info); return false;
return gpu->info->revn == revn;
return gpu->revn == revn;
} }
static inline bool adreno_has_gmu_wrapper(const struct adreno_gpu *gpu) static inline bool adreno_has_gmu_wrapper(const struct adreno_gpu *gpu)
...@@ -162,18 +223,16 @@ static inline bool adreno_has_gmu_wrapper(const struct adreno_gpu *gpu) ...@@ -162,18 +223,16 @@ static inline bool adreno_has_gmu_wrapper(const struct adreno_gpu *gpu)
static inline bool adreno_is_a2xx(const struct adreno_gpu *gpu) static inline bool adreno_is_a2xx(const struct adreno_gpu *gpu)
{ {
/* revn can be zero, but if not is set at same time as info */ if (WARN_ON_ONCE(!gpu->info))
WARN_ON_ONCE(!gpu->info); return false;
return gpu->info->family <= ADRENO_2XX_GEN2;
return (gpu->revn < 300);
} }
static inline bool adreno_is_a20x(const struct adreno_gpu *gpu) static inline bool adreno_is_a20x(const struct adreno_gpu *gpu)
{ {
/* revn can be zero, but if not is set at same time as info */ if (WARN_ON_ONCE(!gpu->info))
WARN_ON_ONCE(!gpu->info); return false;
return gpu->info->family == ADRENO_2XX_GEN1;
return (gpu->revn < 210);
} }
static inline bool adreno_is_a225(const struct adreno_gpu *gpu) static inline bool adreno_is_a225(const struct adreno_gpu *gpu)
...@@ -204,7 +263,7 @@ static inline bool adreno_is_a330(const struct adreno_gpu *gpu) ...@@ -204,7 +263,7 @@ static inline bool adreno_is_a330(const struct adreno_gpu *gpu)
static inline bool adreno_is_a330v2(const struct adreno_gpu *gpu) static inline bool adreno_is_a330v2(const struct adreno_gpu *gpu)
{ {
return adreno_is_a330(gpu) && (gpu->rev.patchid > 0); return adreno_is_a330(gpu) && (adreno_patchid(gpu) > 0);
} }
static inline int adreno_is_a405(const struct adreno_gpu *gpu) static inline int adreno_is_a405(const struct adreno_gpu *gpu)
...@@ -294,8 +353,7 @@ static inline int adreno_is_a650(const struct adreno_gpu *gpu) ...@@ -294,8 +353,7 @@ static inline int adreno_is_a650(const struct adreno_gpu *gpu)
static inline int adreno_is_7c3(const struct adreno_gpu *gpu) static inline int adreno_is_7c3(const struct adreno_gpu *gpu)
{ {
/* The order of args is important here to handle ANY_ID correctly */ return gpu->info->chip_ids[0] == 0x06030500;
return adreno_cmp_rev(ADRENO_REV(6, 3, 5, ANY_ID), gpu->rev);
} }
static inline int adreno_is_a660(const struct adreno_gpu *gpu) static inline int adreno_is_a660(const struct adreno_gpu *gpu)
...@@ -310,35 +368,37 @@ static inline int adreno_is_a680(const struct adreno_gpu *gpu) ...@@ -310,35 +368,37 @@ static inline int adreno_is_a680(const struct adreno_gpu *gpu)
static inline int adreno_is_a690(const struct adreno_gpu *gpu) static inline int adreno_is_a690(const struct adreno_gpu *gpu)
{ {
/* The order of args is important here to handle ANY_ID correctly */ return gpu->info->chip_ids[0] == 0x06090000;
return adreno_cmp_rev(ADRENO_REV(6, 9, 0, ANY_ID), gpu->rev); }
};
/* check for a615, a616, a618, a619 or any derivatives */ /* check for a615, a616, a618, a619 or any a630 derivatives */
static inline int adreno_is_a615_family(const struct adreno_gpu *gpu) static inline int adreno_is_a630_family(const struct adreno_gpu *gpu)
{ {
return adreno_is_revn(gpu, 615) || if (WARN_ON_ONCE(!gpu->info))
adreno_is_revn(gpu, 616) || return false;
adreno_is_revn(gpu, 618) || return gpu->info->family == ADRENO_6XX_GEN1;
adreno_is_revn(gpu, 619);
} }
static inline int adreno_is_a660_family(const struct adreno_gpu *gpu) static inline int adreno_is_a660_family(const struct adreno_gpu *gpu)
{ {
return adreno_is_a660(gpu) || adreno_is_a690(gpu) || adreno_is_7c3(gpu); if (WARN_ON_ONCE(!gpu->info))
return false;
return gpu->info->family == ADRENO_6XX_GEN4;
} }
/* check for a650, a660, or any derivatives */ /* check for a650, a660, or any derivatives */
static inline int adreno_is_a650_family(const struct adreno_gpu *gpu) static inline int adreno_is_a650_family(const struct adreno_gpu *gpu)
{ {
return adreno_is_revn(gpu, 650) || if (WARN_ON_ONCE(!gpu->info))
adreno_is_revn(gpu, 620) || return false;
adreno_is_a660_family(gpu); return gpu->info->family >= ADRENO_6XX_GEN3;
} }
static inline int adreno_is_a640_family(const struct adreno_gpu *gpu) static inline int adreno_is_a640_family(const struct adreno_gpu *gpu)
{ {
return adreno_is_a640(gpu) || adreno_is_a680(gpu); if (WARN_ON_ONCE(!gpu->info))
return false;
return gpu->info->family == ADRENO_6XX_GEN2;
} }
u64 adreno_private_address_space_size(struct msm_gpu *gpu); u64 adreno_private_address_space_size(struct msm_gpu *gpu);
......
/* SPDX-License-Identifier: GPL-2.0-only */
/*
* Copyright (c) 2023 Marijn Suijten <marijn.suijten@somainline.org>. All rights reserved.
* Copyright (c) 2022. Qualcomm Innovation Center, Inc. All rights reserved.
* Copyright (c) 2015-2018, 2020 The Linux Foundation. All rights reserved.
*/
#ifndef _DPU_5_4_SM6125_H
#define _DPU_5_4_SM6125_H
static const struct dpu_caps sm6125_dpu_caps = {
.max_mixer_width = DEFAULT_DPU_OUTPUT_LINE_WIDTH,
.max_mixer_blendstages = 0x6,
.has_dim_layer = true,
.has_idle_pc = true,
.max_linewidth = 2160,
.pixel_ram_size = DEFAULT_PIXEL_RAM_SIZE,
.max_hdeci_exp = MAX_HORZ_DECIMATION,
.max_vdeci_exp = MAX_VERT_DECIMATION,
};
static const struct dpu_mdp_cfg sm6125_mdp = {
.name = "top_0",
.base = 0x0, .len = 0x45c,
.features = 0,
.clk_ctrls = {
[DPU_CLK_CTRL_VIG0] = { .reg_off = 0x2ac, .bit_off = 0 },
[DPU_CLK_CTRL_DMA0] = { .reg_off = 0x2ac, .bit_off = 8 },
[DPU_CLK_CTRL_DMA1] = { .reg_off = 0x2b4, .bit_off = 8 },
},
};
static const struct dpu_ctl_cfg sm6125_ctl[] = {
{
.name = "ctl_0", .id = CTL_0,
.base = 0x1000, .len = 0x1e0,
.features = BIT(DPU_CTL_ACTIVE_CFG),
.intr_start = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR2, 9),
}, {
.name = "ctl_1", .id = CTL_1,
.base = 0x1200, .len = 0x1e0,
.features = BIT(DPU_CTL_ACTIVE_CFG),
.intr_start = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR2, 10),
}, {
.name = "ctl_2", .id = CTL_2,
.base = 0x1400, .len = 0x1e0,
.features = BIT(DPU_CTL_ACTIVE_CFG),
.intr_start = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR2, 11),
}, {
.name = "ctl_3", .id = CTL_3,
.base = 0x1600, .len = 0x1e0,
.features = BIT(DPU_CTL_ACTIVE_CFG),
.intr_start = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR2, 12),
}, {
.name = "ctl_4", .id = CTL_4,
.base = 0x1800, .len = 0x1e0,
.features = BIT(DPU_CTL_ACTIVE_CFG),
.intr_start = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR2, 13),
}, {
.name = "ctl_5", .id = CTL_5,
.base = 0x1a00, .len = 0x1e0,
.features = BIT(DPU_CTL_ACTIVE_CFG),
.intr_start = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR2, 23),
},
};
static const struct dpu_sspp_cfg sm6125_sspp[] = {
{
.name = "sspp_0", .id = SSPP_VIG0,
.base = 0x4000, .len = 0x1f0,
.features = VIG_SM6125_MASK,
.sblk = &sm6125_vig_sblk_0,
.xin_id = 0,
.type = SSPP_TYPE_VIG,
.clk_ctrl = DPU_CLK_CTRL_VIG0,
}, {
.name = "sspp_8", .id = SSPP_DMA0,
.base = 0x24000, .len = 0x1f0,
.features = DMA_SDM845_MASK,
.sblk = &sdm845_dma_sblk_0,
.xin_id = 1,
.type = SSPP_TYPE_DMA,
.clk_ctrl = DPU_CLK_CTRL_DMA0,
}, {
.name = "sspp_9", .id = SSPP_DMA1,
.base = 0x26000, .len = 0x1f0,
.features = DMA_SDM845_MASK,
.sblk = &sdm845_dma_sblk_1,
.xin_id = 5,
.type = SSPP_TYPE_DMA,
.clk_ctrl = DPU_CLK_CTRL_DMA1,
},
};
static const struct dpu_lm_cfg sm6125_lm[] = {
{
.name = "lm_0", .id = LM_0,
.base = 0x44000, .len = 0x320,
.features = MIXER_QCM2290_MASK,
.sblk = &sdm845_lm_sblk,
.pingpong = PINGPONG_0,
.dspp = DSPP_0,
.lm_pair = LM_1,
}, {
.name = "lm_1", .id = LM_1,
.base = 0x45000, .len = 0x320,
.features = MIXER_QCM2290_MASK,
.sblk = &sdm845_lm_sblk,
.pingpong = PINGPONG_1,
.dspp = 0,
.lm_pair = LM_0,
},
};
static const struct dpu_dspp_cfg sm6125_dspp[] = {
{
.name = "dspp_0", .id = DSPP_0,
.base = 0x54000, .len = 0x1800,
.features = DSPP_SC7180_MASK,
.sblk = &sdm845_dspp_sblk,
},
};
static const struct dpu_pingpong_cfg sm6125_pp[] = {
{
.name = "pingpong_0", .id = PINGPONG_0,
.base = 0x70000, .len = 0xd4,
.features = PINGPONG_SM8150_MASK,
.merge_3d = 0,
.sblk = &sdm845_pp_sblk,
.intr_done = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 8),
.intr_rdptr = -1,
}, {
.name = "pingpong_1", .id = PINGPONG_1,
.base = 0x70800, .len = 0xd4,
.features = PINGPONG_SM8150_MASK,
.merge_3d = 0,
.sblk = &sdm845_pp_sblk,
.intr_done = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 9),
.intr_rdptr = -1,
},
};
static const struct dpu_intf_cfg sm6125_intf[] = {
{
.name = "intf_0", .id = INTF_0,
.base = 0x6a000, .len = 0x280,
.features = INTF_SC7180_MASK,
.type = INTF_DP,
.controller_id = MSM_DP_CONTROLLER_0,
.prog_fetch_lines_worst_case = 24,
.intr_underrun = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 24),
.intr_vsync = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 25),
.intr_tear_rd_ptr = -1,
}, {
.name = "intf_1", .id = INTF_1,
.base = 0x6a800, .len = 0x2c0,
.features = INTF_SC7180_MASK,
.type = INTF_DSI,
.controller_id = 0,
.prog_fetch_lines_worst_case = 24,
.intr_underrun = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 26),
.intr_vsync = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 27),
.intr_tear_rd_ptr = DPU_IRQ_IDX(MDP_INTF1_TEAR_INTR, 2),
},
};
static const struct dpu_perf_cfg sm6125_perf_data = {
.max_bw_low = 4100000,
.max_bw_high = 4100000,
.min_core_ib = 2400000,
.min_llcc_ib = 0, /* No LLCC on this SoC */
.min_dram_ib = 800000,
.min_prefill_lines = 24,
.danger_lut_tbl = {0xf, 0xffff, 0x0},
.safe_lut_tbl = {0xfff8, 0xf000, 0xffff},
.qos_lut_tbl = {
{.nentry = ARRAY_SIZE(sm8150_qos_linear),
.entries = sm8150_qos_linear
},
{.nentry = ARRAY_SIZE(sc7180_qos_macrotile),
.entries = sc7180_qos_macrotile
},
{.nentry = ARRAY_SIZE(sc7180_qos_nrt),
.entries = sc7180_qos_nrt
},
/* TODO: macrotile-qseed is different from macrotile */
},
.cdp_cfg = {
{.rd_enable = 1, .wr_enable = 1},
{.rd_enable = 1, .wr_enable = 0}
},
.clk_inefficiency_factor = 105,
.bw_inefficiency_factor = 120,
};
static const struct dpu_mdss_version sm6125_mdss_ver = {
.core_major_ver = 5,
.core_minor_ver = 4,
};
const struct dpu_mdss_cfg dpu_sm6125_cfg = {
.mdss_ver = &sm6125_mdss_ver,
.caps = &sm6125_dpu_caps,
.mdp = &sm6125_mdp,
.ctl_count = ARRAY_SIZE(sm6125_ctl),
.ctl = sm6125_ctl,
.sspp_count = ARRAY_SIZE(sm6125_sspp),
.sspp = sm6125_sspp,
.mixer_count = ARRAY_SIZE(sm6125_lm),
.mixer = sm6125_lm,
.dspp_count = ARRAY_SIZE(sm6125_dspp),
.dspp = sm6125_dspp,
.pingpong_count = ARRAY_SIZE(sm6125_pp),
.pingpong = sm6125_pp,
.intf_count = ARRAY_SIZE(sm6125_intf),
.intf = sm6125_intf,
.vbif_count = ARRAY_SIZE(sdm845_vbif),
.vbif = sdm845_vbif,
.perf = &sm6125_perf_data,
};
#endif
...@@ -17,21 +17,15 @@ static const struct dpu_caps sc7180_dpu_caps = { ...@@ -17,21 +17,15 @@ static const struct dpu_caps sc7180_dpu_caps = {
.pixel_ram_size = DEFAULT_PIXEL_RAM_SIZE, .pixel_ram_size = DEFAULT_PIXEL_RAM_SIZE,
}; };
static const struct dpu_ubwc_cfg sc7180_ubwc_cfg = { static const struct dpu_mdp_cfg sc7180_mdp = {
.ubwc_version = DPU_HW_UBWC_VER_20, .name = "top_0",
.highest_bank_bit = 0x3,
};
static const struct dpu_mdp_cfg sc7180_mdp[] = {
{
.name = "top_0", .id = MDP_TOP,
.base = 0x0, .len = 0x494, .base = 0x0, .len = 0x494,
.features = 0, .clk_ctrls = {
.clk_ctrls[DPU_CLK_CTRL_VIG0] = { .reg_off = 0x2ac, .bit_off = 0 }, [DPU_CLK_CTRL_VIG0] = { .reg_off = 0x2ac, .bit_off = 0 },
.clk_ctrls[DPU_CLK_CTRL_DMA0] = { .reg_off = 0x2ac, .bit_off = 8 }, [DPU_CLK_CTRL_DMA0] = { .reg_off = 0x2ac, .bit_off = 8 },
.clk_ctrls[DPU_CLK_CTRL_DMA1] = { .reg_off = 0x2b4, .bit_off = 8 }, [DPU_CLK_CTRL_DMA1] = { .reg_off = 0x2b4, .bit_off = 8 },
.clk_ctrls[DPU_CLK_CTRL_DMA2] = { .reg_off = 0x2c4, .bit_off = 8 }, [DPU_CLK_CTRL_DMA2] = { .reg_off = 0x2c4, .bit_off = 8 },
.clk_ctrls[DPU_CLK_CTRL_WB2] = { .reg_off = 0x3b8, .bit_off = 24 }, [DPU_CLK_CTRL_WB2] = { .reg_off = 0x3b8, .bit_off = 24 },
}, },
}; };
...@@ -41,14 +35,12 @@ static const struct dpu_ctl_cfg sc7180_ctl[] = { ...@@ -41,14 +35,12 @@ static const struct dpu_ctl_cfg sc7180_ctl[] = {
.base = 0x1000, .len = 0x1dc, .base = 0x1000, .len = 0x1dc,
.features = BIT(DPU_CTL_ACTIVE_CFG), .features = BIT(DPU_CTL_ACTIVE_CFG),
.intr_start = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR2, 9), .intr_start = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR2, 9),
}, }, {
{
.name = "ctl_1", .id = CTL_1, .name = "ctl_1", .id = CTL_1,
.base = 0x1200, .len = 0x1dc, .base = 0x1200, .len = 0x1dc,
.features = BIT(DPU_CTL_ACTIVE_CFG), .features = BIT(DPU_CTL_ACTIVE_CFG),
.intr_start = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR2, 10), .intr_start = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR2, 10),
}, }, {
{
.name = "ctl_2", .id = CTL_2, .name = "ctl_2", .id = CTL_2,
.base = 0x1400, .len = 0x1dc, .base = 0x1400, .len = 0x1dc,
.features = BIT(DPU_CTL_ACTIVE_CFG), .features = BIT(DPU_CTL_ACTIVE_CFG),
...@@ -57,50 +49,126 @@ static const struct dpu_ctl_cfg sc7180_ctl[] = { ...@@ -57,50 +49,126 @@ static const struct dpu_ctl_cfg sc7180_ctl[] = {
}; };
static const struct dpu_sspp_cfg sc7180_sspp[] = { static const struct dpu_sspp_cfg sc7180_sspp[] = {
SSPP_BLK("sspp_0", SSPP_VIG0, 0x4000, 0x1f8, VIG_SC7180_MASK, {
sc7180_vig_sblk_0, 0, SSPP_TYPE_VIG, DPU_CLK_CTRL_VIG0), .name = "sspp_0", .id = SSPP_VIG0,
SSPP_BLK("sspp_8", SSPP_DMA0, 0x24000, 0x1f8, DMA_SDM845_MASK, .base = 0x4000, .len = 0x1f8,
sdm845_dma_sblk_0, 1, SSPP_TYPE_DMA, DPU_CLK_CTRL_DMA0), .features = VIG_SC7180_MASK,
SSPP_BLK("sspp_9", SSPP_DMA1, 0x26000, 0x1f8, DMA_CURSOR_SDM845_MASK, .sblk = &sc7180_vig_sblk_0,
sdm845_dma_sblk_1, 5, SSPP_TYPE_DMA, DPU_CLK_CTRL_DMA1), .xin_id = 0,
SSPP_BLK("sspp_10", SSPP_DMA2, 0x28000, 0x1f8, DMA_CURSOR_SDM845_MASK, .type = SSPP_TYPE_VIG,
sdm845_dma_sblk_2, 9, SSPP_TYPE_DMA, DPU_CLK_CTRL_DMA2), .clk_ctrl = DPU_CLK_CTRL_VIG0,
}, {
.name = "sspp_8", .id = SSPP_DMA0,
.base = 0x24000, .len = 0x1f8,
.features = DMA_SDM845_MASK,
.sblk = &sdm845_dma_sblk_0,
.xin_id = 1,
.type = SSPP_TYPE_DMA,
.clk_ctrl = DPU_CLK_CTRL_DMA0,
}, {
.name = "sspp_9", .id = SSPP_DMA1,
.base = 0x26000, .len = 0x1f8,
.features = DMA_CURSOR_SDM845_MASK,
.sblk = &sdm845_dma_sblk_1,
.xin_id = 5,
.type = SSPP_TYPE_DMA,
.clk_ctrl = DPU_CLK_CTRL_DMA1,
}, {
.name = "sspp_10", .id = SSPP_DMA2,
.base = 0x28000, .len = 0x1f8,
.features = DMA_CURSOR_SDM845_MASK,
.sblk = &sdm845_dma_sblk_2,
.xin_id = 9,
.type = SSPP_TYPE_DMA,
.clk_ctrl = DPU_CLK_CTRL_DMA2,
},
}; };
static const struct dpu_lm_cfg sc7180_lm[] = { static const struct dpu_lm_cfg sc7180_lm[] = {
LM_BLK("lm_0", LM_0, 0x44000, MIXER_SDM845_MASK, {
&sc7180_lm_sblk, PINGPONG_0, LM_1, DSPP_0), .name = "lm_0", .id = LM_0,
LM_BLK("lm_1", LM_1, 0x45000, MIXER_SDM845_MASK, .base = 0x44000, .len = 0x320,
&sc7180_lm_sblk, PINGPONG_1, LM_0, 0), .features = MIXER_SDM845_MASK,
.sblk = &sc7180_lm_sblk,
.lm_pair = LM_1,
.pingpong = PINGPONG_0,
.dspp = DSPP_0,
}, {
.name = "lm_1", .id = LM_1,
.base = 0x45000, .len = 0x320,
.features = MIXER_SDM845_MASK,
.sblk = &sc7180_lm_sblk,
.lm_pair = LM_0,
.pingpong = PINGPONG_1,
},
}; };
static const struct dpu_dspp_cfg sc7180_dspp[] = { static const struct dpu_dspp_cfg sc7180_dspp[] = {
DSPP_BLK("dspp_0", DSPP_0, 0x54000, DSPP_SC7180_MASK, {
&sm8150_dspp_sblk), .name = "dspp_0", .id = DSPP_0,
.base = 0x54000, .len = 0x1800,
.features = DSPP_SC7180_MASK,
.sblk = &sdm845_dspp_sblk,
},
}; };
static const struct dpu_pingpong_cfg sc7180_pp[] = { static const struct dpu_pingpong_cfg sc7180_pp[] = {
PP_BLK("pingpong_0", PINGPONG_0, 0x70000, PINGPONG_SM8150_MASK, 0, sdm845_pp_sblk, {
DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 8), .name = "pingpong_0", .id = PINGPONG_0,
-1), .base = 0x70000, .len = 0xd4,
PP_BLK("pingpong_1", PINGPONG_1, 0x70800, PINGPONG_SM8150_MASK, 0, sdm845_pp_sblk, .features = PINGPONG_SM8150_MASK,
DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 9), .sblk = &sdm845_pp_sblk,
-1), .merge_3d = 0,
.intr_done = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 8),
.intr_rdptr = -1,
}, {
.name = "pingpong_1", .id = PINGPONG_1,
.base = 0x70800, .len = 0xd4,
.features = PINGPONG_SM8150_MASK,
.sblk = &sdm845_pp_sblk,
.merge_3d = 0,
.intr_done = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 9),
.intr_rdptr = -1,
},
}; };
static const struct dpu_intf_cfg sc7180_intf[] = { static const struct dpu_intf_cfg sc7180_intf[] = {
INTF_BLK("intf_0", INTF_0, 0x6a000, 0x280, INTF_DP, MSM_DP_CONTROLLER_0, 24, INTF_SC7180_MASK, {
DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 24), .name = "intf_0", .id = INTF_0,
DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 25)), .base = 0x6a000, .len = 0x280,
INTF_BLK_DSI_TE("intf_1", INTF_1, 0x6a800, 0x2c0, INTF_DSI, 0, 24, INTF_SC7180_MASK, .features = INTF_SC7180_MASK,
DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 26), .type = INTF_DP,
DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 27), .controller_id = MSM_DP_CONTROLLER_0,
DPU_IRQ_IDX(MDP_INTF1_TEAR_INTR, 2)), .prog_fetch_lines_worst_case = 24,
.intr_underrun = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 24),
.intr_vsync = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 25),
.intr_tear_rd_ptr = -1,
}, {
.name = "intf_1", .id = INTF_1,
.base = 0x6a800, .len = 0x2c0,
.features = INTF_SC7180_MASK,
.type = INTF_DSI,
.controller_id = MSM_DSI_CONTROLLER_0,
.prog_fetch_lines_worst_case = 24,
.intr_underrun = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 26),
.intr_vsync = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 27),
.intr_tear_rd_ptr = DPU_IRQ_IDX(MDP_INTF1_TEAR_INTR, 2),
},
}; };
static const struct dpu_wb_cfg sc7180_wb[] = { static const struct dpu_wb_cfg sc7180_wb[] = {
WB_BLK("wb_2", WB_2, 0x65000, WB_SM8250_MASK, DPU_CLK_CTRL_WB2, 6, {
VBIF_RT, MDP_SSPP_TOP0_INTR, 4096, 4), .name = "wb_2", .id = WB_2,
.base = 0x65000, .len = 0x2c8,
.features = WB_SM8250_MASK,
.format_list = wb2_formats,
.num_formats = ARRAY_SIZE(wb2_formats),
.clk_ctrl = DPU_CLK_CTRL_WB2,
.xin_id = 6,
.vbif_idx = VBIF_RT,
.maxlinewidth = 4096,
.intr_wb_done = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 4),
},
}; };
static const struct dpu_perf_cfg sc7180_perf_data = { static const struct dpu_perf_cfg sc7180_perf_data = {
...@@ -131,11 +199,15 @@ static const struct dpu_perf_cfg sc7180_perf_data = { ...@@ -131,11 +199,15 @@ static const struct dpu_perf_cfg sc7180_perf_data = {
.bw_inefficiency_factor = 120, .bw_inefficiency_factor = 120,
}; };
static const struct dpu_mdss_version sc7180_mdss_ver = {
.core_major_ver = 6,
.core_minor_ver = 2,
};
const struct dpu_mdss_cfg dpu_sc7180_cfg = { const struct dpu_mdss_cfg dpu_sc7180_cfg = {
.mdss_ver = &sc7180_mdss_ver,
.caps = &sc7180_dpu_caps, .caps = &sc7180_dpu_caps,
.ubwc = &sc7180_ubwc_cfg, .mdp = &sc7180_mdp,
.mdp_count = ARRAY_SIZE(sc7180_mdp),
.mdp = sc7180_mdp,
.ctl_count = ARRAY_SIZE(sc7180_ctl), .ctl_count = ARRAY_SIZE(sc7180_ctl),
.ctl = sc7180_ctl, .ctl = sc7180_ctl,
.sspp_count = ARRAY_SIZE(sc7180_sspp), .sspp_count = ARRAY_SIZE(sc7180_sspp),
...@@ -153,12 +225,6 @@ const struct dpu_mdss_cfg dpu_sc7180_cfg = { ...@@ -153,12 +225,6 @@ const struct dpu_mdss_cfg dpu_sc7180_cfg = {
.vbif_count = ARRAY_SIZE(sdm845_vbif), .vbif_count = ARRAY_SIZE(sdm845_vbif),
.vbif = sdm845_vbif, .vbif = sdm845_vbif,
.perf = &sc7180_perf_data, .perf = &sc7180_perf_data,
.mdss_irqs = BIT(MDP_SSPP_TOP0_INTR) | \
BIT(MDP_SSPP_TOP0_INTR2) | \
BIT(MDP_SSPP_TOP0_HIST_INTR) | \
BIT(MDP_INTF0_INTR) | \
BIT(MDP_INTF1_INTR) | \
BIT(MDP_INTF1_TEAR_INTR),
}; };
#endif #endif
...@@ -17,19 +17,12 @@ static const struct dpu_caps sm6115_dpu_caps = { ...@@ -17,19 +17,12 @@ static const struct dpu_caps sm6115_dpu_caps = {
.pixel_ram_size = DEFAULT_PIXEL_RAM_SIZE, .pixel_ram_size = DEFAULT_PIXEL_RAM_SIZE,
}; };
static const struct dpu_ubwc_cfg sm6115_ubwc_cfg = { static const struct dpu_mdp_cfg sm6115_mdp = {
.ubwc_version = DPU_HW_UBWC_VER_10, .name = "top_0",
.highest_bank_bit = 0x1,
.ubwc_swizzle = 0x7,
};
static const struct dpu_mdp_cfg sm6115_mdp[] = {
{
.name = "top_0", .id = MDP_TOP,
.base = 0x0, .len = 0x494, .base = 0x0, .len = 0x494,
.features = 0, .clk_ctrls = {
.clk_ctrls[DPU_CLK_CTRL_VIG0] = { .reg_off = 0x2ac, .bit_off = 0 }, [DPU_CLK_CTRL_VIG0] = { .reg_off = 0x2ac, .bit_off = 0 },
.clk_ctrls[DPU_CLK_CTRL_DMA0] = { .reg_off = 0x2ac, .bit_off = 8 }, [DPU_CLK_CTRL_DMA0] = { .reg_off = 0x2ac, .bit_off = 8 },
}, },
}; };
...@@ -43,33 +36,69 @@ static const struct dpu_ctl_cfg sm6115_ctl[] = { ...@@ -43,33 +36,69 @@ static const struct dpu_ctl_cfg sm6115_ctl[] = {
}; };
static const struct dpu_sspp_cfg sm6115_sspp[] = { static const struct dpu_sspp_cfg sm6115_sspp[] = {
SSPP_BLK("sspp_0", SSPP_VIG0, 0x4000, 0x1f8, VIG_SC7180_MASK, {
sm6115_vig_sblk_0, 0, SSPP_TYPE_VIG, DPU_CLK_CTRL_VIG0), .name = "sspp_0", .id = SSPP_VIG0,
SSPP_BLK("sspp_8", SSPP_DMA0, 0x24000, 0x1f8, DMA_SDM845_MASK, .base = 0x4000, .len = 0x1f8,
sdm845_dma_sblk_0, 1, SSPP_TYPE_DMA, DPU_CLK_CTRL_DMA0), .features = VIG_SC7180_MASK,
.sblk = &sm6115_vig_sblk_0,
.xin_id = 0,
.type = SSPP_TYPE_VIG,
.clk_ctrl = DPU_CLK_CTRL_VIG0,
}, {
.name = "sspp_8", .id = SSPP_DMA0,
.base = 0x24000, .len = 0x1f8,
.features = DMA_SDM845_MASK,
.sblk = &sdm845_dma_sblk_0,
.xin_id = 1,
.type = SSPP_TYPE_DMA,
.clk_ctrl = DPU_CLK_CTRL_DMA0,
},
}; };
static const struct dpu_lm_cfg sm6115_lm[] = { static const struct dpu_lm_cfg sm6115_lm[] = {
LM_BLK("lm_0", LM_0, 0x44000, MIXER_QCM2290_MASK, {
&qcm2290_lm_sblk, PINGPONG_0, 0, DSPP_0), .name = "lm_0", .id = LM_0,
.base = 0x44000, .len = 0x320,
.features = MIXER_QCM2290_MASK,
.sblk = &qcm2290_lm_sblk,
.pingpong = PINGPONG_0,
.dspp = DSPP_0,
},
}; };
static const struct dpu_dspp_cfg sm6115_dspp[] = { static const struct dpu_dspp_cfg sm6115_dspp[] = {
DSPP_BLK("dspp_0", DSPP_0, 0x54000, DSPP_SC7180_MASK, {
&sm8150_dspp_sblk), .name = "dspp_0", .id = DSPP_0,
.base = 0x54000, .len = 0x1800,
.features = DSPP_SC7180_MASK,
.sblk = &sdm845_dspp_sblk,
},
}; };
static const struct dpu_pingpong_cfg sm6115_pp[] = { static const struct dpu_pingpong_cfg sm6115_pp[] = {
PP_BLK("pingpong_0", PINGPONG_0, 0x70000, PINGPONG_SM8150_MASK, 0, sdm845_pp_sblk, {
DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 8), .name = "pingpong_0", .id = PINGPONG_0,
-1), .base = 0x70000, .len = 0xd4,
.features = PINGPONG_SM8150_MASK,
.sblk = &sdm845_pp_sblk,
.merge_3d = 0,
.intr_done = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 8),
.intr_rdptr = -1,
},
}; };
static const struct dpu_intf_cfg sm6115_intf[] = { static const struct dpu_intf_cfg sm6115_intf[] = {
INTF_BLK_DSI_TE("intf_1", INTF_1, 0x6a800, 0x2c0, INTF_DSI, 0, 24, INTF_SC7180_MASK, {
DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 26), .name = "intf_1", .id = INTF_1,
DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 27), .base = 0x6a800, .len = 0x2c0,
DPU_IRQ_IDX(MDP_INTF1_TEAR_INTR, 2)), .features = INTF_SC7180_MASK,
.type = INTF_DSI,
.controller_id = MSM_DSI_CONTROLLER_0,
.prog_fetch_lines_worst_case = 24,
.intr_underrun = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 26),
.intr_vsync = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 27),
.intr_tear_rd_ptr = DPU_IRQ_IDX(MDP_INTF1_TEAR_INTR, 2),
},
}; };
static const struct dpu_perf_cfg sm6115_perf_data = { static const struct dpu_perf_cfg sm6115_perf_data = {
...@@ -101,11 +130,15 @@ static const struct dpu_perf_cfg sm6115_perf_data = { ...@@ -101,11 +130,15 @@ static const struct dpu_perf_cfg sm6115_perf_data = {
.bw_inefficiency_factor = 120, .bw_inefficiency_factor = 120,
}; };
static const struct dpu_mdss_version sm6115_mdss_ver = {
.core_major_ver = 6,
.core_minor_ver = 3,
};
const struct dpu_mdss_cfg dpu_sm6115_cfg = { const struct dpu_mdss_cfg dpu_sm6115_cfg = {
.mdss_ver = &sm6115_mdss_ver,
.caps = &sm6115_dpu_caps, .caps = &sm6115_dpu_caps,
.ubwc = &sm6115_ubwc_cfg, .mdp = &sm6115_mdp,
.mdp_count = ARRAY_SIZE(sm6115_mdp),
.mdp = sm6115_mdp,
.ctl_count = ARRAY_SIZE(sm6115_ctl), .ctl_count = ARRAY_SIZE(sm6115_ctl),
.ctl = sm6115_ctl, .ctl = sm6115_ctl,
.sspp_count = ARRAY_SIZE(sm6115_sspp), .sspp_count = ARRAY_SIZE(sm6115_sspp),
...@@ -121,11 +154,6 @@ const struct dpu_mdss_cfg dpu_sm6115_cfg = { ...@@ -121,11 +154,6 @@ const struct dpu_mdss_cfg dpu_sm6115_cfg = {
.vbif_count = ARRAY_SIZE(sdm845_vbif), .vbif_count = ARRAY_SIZE(sdm845_vbif),
.vbif = sdm845_vbif, .vbif = sdm845_vbif,
.perf = &sm6115_perf_data, .perf = &sm6115_perf_data,
.mdss_irqs = BIT(MDP_SSPP_TOP0_INTR) | \
BIT(MDP_SSPP_TOP0_INTR2) | \
BIT(MDP_SSPP_TOP0_HIST_INTR) | \
BIT(MDP_INTF1_INTR) | \
BIT(MDP_INTF1_TEAR_INTR),
}; };
#endif #endif
...@@ -19,22 +19,15 @@ static const struct dpu_caps sm6350_dpu_caps = { ...@@ -19,22 +19,15 @@ static const struct dpu_caps sm6350_dpu_caps = {
.pixel_ram_size = DEFAULT_PIXEL_RAM_SIZE, .pixel_ram_size = DEFAULT_PIXEL_RAM_SIZE,
}; };
static const struct dpu_ubwc_cfg sm6350_ubwc_cfg = { static const struct dpu_mdp_cfg sm6350_mdp = {
.ubwc_version = DPU_HW_UBWC_VER_20, .name = "top_0",
.ubwc_swizzle = 6,
.highest_bank_bit = 1,
};
static const struct dpu_mdp_cfg sm6350_mdp[] = {
{
.name = "top_0", .id = MDP_TOP,
.base = 0x0, .len = 0x494, .base = 0x0, .len = 0x494,
.features = 0, .clk_ctrls = {
.clk_ctrls[DPU_CLK_CTRL_VIG0] = { .reg_off = 0x2ac, .bit_off = 0 }, [DPU_CLK_CTRL_VIG0] = { .reg_off = 0x2ac, .bit_off = 0 },
.clk_ctrls[DPU_CLK_CTRL_DMA0] = { .reg_off = 0x2ac, .bit_off = 8 }, [DPU_CLK_CTRL_DMA0] = { .reg_off = 0x2ac, .bit_off = 8 },
.clk_ctrls[DPU_CLK_CTRL_DMA1] = { .reg_off = 0x2b4, .bit_off = 8 }, [DPU_CLK_CTRL_DMA1] = { .reg_off = 0x2b4, .bit_off = 8 },
.clk_ctrls[DPU_CLK_CTRL_DMA2] = { .reg_off = 0x2c4, .bit_off = 8 }, [DPU_CLK_CTRL_DMA2] = { .reg_off = 0x2c4, .bit_off = 8 },
.clk_ctrls[DPU_CLK_CTRL_REG_DMA] = { .reg_off = 0x2bc, .bit_off = 20 }, [DPU_CLK_CTRL_REG_DMA] = { .reg_off = 0x2bc, .bit_off = 20 },
}, },
}; };
...@@ -44,20 +37,17 @@ static const struct dpu_ctl_cfg sm6350_ctl[] = { ...@@ -44,20 +37,17 @@ static const struct dpu_ctl_cfg sm6350_ctl[] = {
.base = 0x1000, .len = 0x1dc, .base = 0x1000, .len = 0x1dc,
.features = BIT(DPU_CTL_ACTIVE_CFG), .features = BIT(DPU_CTL_ACTIVE_CFG),
.intr_start = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR2, 9), .intr_start = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR2, 9),
}, }, {
{
.name = "ctl_1", .id = CTL_1, .name = "ctl_1", .id = CTL_1,
.base = 0x1200, .len = 0x1dc, .base = 0x1200, .len = 0x1dc,
.features = BIT(DPU_CTL_ACTIVE_CFG), .features = BIT(DPU_CTL_ACTIVE_CFG),
.intr_start = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR2, 10), .intr_start = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR2, 10),
}, }, {
{
.name = "ctl_2", .id = CTL_2, .name = "ctl_2", .id = CTL_2,
.base = 0x1400, .len = 0x1dc, .base = 0x1400, .len = 0x1dc,
.features = BIT(DPU_CTL_ACTIVE_CFG), .features = BIT(DPU_CTL_ACTIVE_CFG),
.intr_start = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR2, 11), .intr_start = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR2, 11),
}, }, {
{
.name = "ctl_3", .id = CTL_3, .name = "ctl_3", .id = CTL_3,
.base = 0x1600, .len = 0x1dc, .base = 0x1600, .len = 0x1dc,
.features = BIT(DPU_CTL_ACTIVE_CFG), .features = BIT(DPU_CTL_ACTIVE_CFG),
...@@ -66,49 +56,120 @@ static const struct dpu_ctl_cfg sm6350_ctl[] = { ...@@ -66,49 +56,120 @@ static const struct dpu_ctl_cfg sm6350_ctl[] = {
}; };
static const struct dpu_sspp_cfg sm6350_sspp[] = { static const struct dpu_sspp_cfg sm6350_sspp[] = {
SSPP_BLK("sspp_0", SSPP_VIG0, 0x4000, 0x1f8, VIG_SC7180_MASK, {
sc7180_vig_sblk_0, 0, SSPP_TYPE_VIG, DPU_CLK_CTRL_VIG0), .name = "sspp_0", .id = SSPP_VIG0,
SSPP_BLK("sspp_8", SSPP_DMA0, 0x24000, 0x1f8, DMA_SDM845_MASK, .base = 0x4000, .len = 0x1f8,
sdm845_dma_sblk_0, 1, SSPP_TYPE_DMA, DPU_CLK_CTRL_DMA0), .features = VIG_SC7180_MASK,
SSPP_BLK("sspp_9", SSPP_DMA1, 0x26000, 0x1f8, DMA_CURSOR_SDM845_MASK, .sblk = &sc7180_vig_sblk_0,
sdm845_dma_sblk_1, 5, SSPP_TYPE_DMA, DPU_CLK_CTRL_DMA1), .xin_id = 0,
SSPP_BLK("sspp_10", SSPP_DMA2, 0x28000, 0x1f8, DMA_CURSOR_SDM845_MASK, .type = SSPP_TYPE_VIG,
sdm845_dma_sblk_2, 9, SSPP_TYPE_DMA, DPU_CLK_CTRL_DMA2), .clk_ctrl = DPU_CLK_CTRL_VIG0,
}, {
.name = "sspp_8", .id = SSPP_DMA0,
.base = 0x24000, .len = 0x1f8,
.features = DMA_SDM845_MASK,
.sblk = &sdm845_dma_sblk_0,
.xin_id = 1,
.type = SSPP_TYPE_DMA,
.clk_ctrl = DPU_CLK_CTRL_DMA0,
}, {
.name = "sspp_9", .id = SSPP_DMA1,
.base = 0x26000, .len = 0x1f8,
.features = DMA_CURSOR_SDM845_MASK,
.sblk = &sdm845_dma_sblk_1,
.xin_id = 5,
.type = SSPP_TYPE_DMA,
.clk_ctrl = DPU_CLK_CTRL_DMA1,
}, {
.name = "sspp_10", .id = SSPP_DMA2,
.base = 0x28000, .len = 0x1f8,
.features = DMA_CURSOR_SDM845_MASK,
.sblk = &sdm845_dma_sblk_2,
.xin_id = 9,
.type = SSPP_TYPE_DMA,
.clk_ctrl = DPU_CLK_CTRL_DMA2,
},
}; };
static const struct dpu_lm_cfg sm6350_lm[] = { static const struct dpu_lm_cfg sm6350_lm[] = {
LM_BLK("lm_0", LM_0, 0x44000, MIXER_SDM845_MASK, {
&sc7180_lm_sblk, PINGPONG_0, LM_1, DSPP_0), .name = "lm_0", .id = LM_0,
LM_BLK("lm_1", LM_1, 0x45000, MIXER_SDM845_MASK, .base = 0x44000, .len = 0x320,
&sc7180_lm_sblk, PINGPONG_1, LM_0, 0), .features = MIXER_SDM845_MASK,
.sblk = &sc7180_lm_sblk,
.lm_pair = LM_1,
.pingpong = PINGPONG_0,
.dspp = DSPP_0,
}, {
.name = "lm_1", .id = LM_1,
.base = 0x45000, .len = 0x320,
.features = MIXER_SDM845_MASK,
.sblk = &sc7180_lm_sblk,
.lm_pair = LM_0,
.pingpong = PINGPONG_1,
.dspp = 0,
},
}; };
static const struct dpu_dspp_cfg sm6350_dspp[] = { static const struct dpu_dspp_cfg sm6350_dspp[] = {
DSPP_BLK("dspp_0", DSPP_0, 0x54000, DSPP_SC7180_MASK, {
&sm8150_dspp_sblk), .name = "dspp_0", .id = DSPP_0,
.base = 0x54000, .len = 0x1800,
.features = DSPP_SC7180_MASK,
.sblk = &sdm845_dspp_sblk,
},
}; };
static struct dpu_pingpong_cfg sm6350_pp[] = { static struct dpu_pingpong_cfg sm6350_pp[] = {
PP_BLK("pingpong_0", PINGPONG_0, 0x70000, PINGPONG_SM8150_MASK, 0, sdm845_pp_sblk, {
DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 8), .name = "pingpong_0", .id = PINGPONG_0,
-1), .base = 0x70000, .len = 0xd4,
PP_BLK("pingpong_1", PINGPONG_1, 0x70800, PINGPONG_SM8150_MASK, 0, sdm845_pp_sblk, .features = PINGPONG_SM8150_MASK,
DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 9), .sblk = &sdm845_pp_sblk,
-1), .merge_3d = 0,
.intr_done = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 8),
.intr_rdptr = -1,
}, {
.name = "pingpong_1", .id = PINGPONG_1,
.base = 0x70800, .len = 0xd4,
.features = PINGPONG_SM8150_MASK,
.sblk = &sdm845_pp_sblk,
.merge_3d = 0,
.intr_done = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 9),
.intr_rdptr = -1,
},
}; };
static const struct dpu_dsc_cfg sm6350_dsc[] = { static const struct dpu_dsc_cfg sm6350_dsc[] = {
DSC_BLK("dsc_0", DSC_0, 0x80000, BIT(DPU_DSC_OUTPUT_CTRL)), {
.name = "dsc_0", .id = DSC_0,
.base = 0x80000, .len = 0x140,
.features = BIT(DPU_DSC_OUTPUT_CTRL),
},
}; };
static const struct dpu_intf_cfg sm6350_intf[] = { static const struct dpu_intf_cfg sm6350_intf[] = {
INTF_BLK("intf_0", INTF_0, 0x6a000, 0x280, INTF_DP, 0, 35, INTF_SC7180_MASK, {
DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 24), .name = "intf_0", .id = INTF_0,
DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 25)), .base = 0x6a000, .len = 0x280,
INTF_BLK_DSI_TE("intf_1", INTF_1, 0x6a800, 0x2c0, INTF_DSI, 0, 35, INTF_SC7180_MASK, .features = INTF_SC7180_MASK,
DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 26), .type = INTF_DP,
DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 27), .controller_id = MSM_DP_CONTROLLER_0,
DPU_IRQ_IDX(MDP_INTF1_TEAR_INTR, 2)), .prog_fetch_lines_worst_case = 35,
.intr_underrun = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 24),
.intr_vsync = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 25),
.intr_tear_rd_ptr = -1,
}, {
.name = "intf_1", .id = INTF_1,
.base = 0x6a800, .len = 0x2c0,
.features = INTF_SC7180_MASK,
.type = INTF_DSI,
.controller_id = MSM_DSI_CONTROLLER_0,
.prog_fetch_lines_worst_case = 35,
.intr_underrun = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 26),
.intr_vsync = DPU_IRQ_IDX(MDP_SSPP_TOP0_INTR, 27),
.intr_tear_rd_ptr = DPU_IRQ_IDX(MDP_INTF1_TEAR_INTR, 2),
},
}; };
static const struct dpu_perf_cfg sm6350_perf_data = { static const struct dpu_perf_cfg sm6350_perf_data = {
...@@ -140,11 +201,15 @@ static const struct dpu_perf_cfg sm6350_perf_data = { ...@@ -140,11 +201,15 @@ static const struct dpu_perf_cfg sm6350_perf_data = {
.bw_inefficiency_factor = 120, .bw_inefficiency_factor = 120,
}; };
static const struct dpu_mdss_version sm6350_mdss_ver = {
.core_major_ver = 6,
.core_minor_ver = 4,
};
const struct dpu_mdss_cfg dpu_sm6350_cfg = { const struct dpu_mdss_cfg dpu_sm6350_cfg = {
.mdss_ver = &sm6350_mdss_ver,
.caps = &sm6350_dpu_caps, .caps = &sm6350_dpu_caps,
.ubwc = &sm6350_ubwc_cfg, .mdp = &sm6350_mdp,
.mdp_count = ARRAY_SIZE(sm6350_mdp),
.mdp = sm6350_mdp,
.ctl_count = ARRAY_SIZE(sm6350_ctl), .ctl_count = ARRAY_SIZE(sm6350_ctl),
.ctl = sm6350_ctl, .ctl = sm6350_ctl,
.sspp_count = ARRAY_SIZE(sm6350_sspp), .sspp_count = ARRAY_SIZE(sm6350_sspp),
...@@ -162,12 +227,6 @@ const struct dpu_mdss_cfg dpu_sm6350_cfg = { ...@@ -162,12 +227,6 @@ const struct dpu_mdss_cfg dpu_sm6350_cfg = {
.vbif_count = ARRAY_SIZE(sdm845_vbif), .vbif_count = ARRAY_SIZE(sdm845_vbif),
.vbif = sdm845_vbif, .vbif = sdm845_vbif,
.perf = &sm6350_perf_data, .perf = &sm6350_perf_data,
.mdss_irqs = BIT(MDP_SSPP_TOP0_INTR) | \
BIT(MDP_SSPP_TOP0_INTR2) | \
BIT(MDP_SSPP_TOP0_HIST_INTR) | \
BIT(MDP_INTF0_INTR) | \
BIT(MDP_INTF1_INTR) | \
BIT(MDP_INTF1_TEAR_INTR),
}; };
#endif #endif
...@@ -12,8 +12,6 @@ ...@@ -12,8 +12,6 @@
#include "dpu_hw_catalog.h" #include "dpu_hw_catalog.h"
#define DPU_PERF_DEFAULT_MAX_CORE_CLK_RATE 412500000
/** /**
* struct dpu_core_perf_params - definition of performance parameters * struct dpu_core_perf_params - definition of performance parameters
* @max_per_pipe_ib: maximum instantaneous bandwidth request * @max_per_pipe_ib: maximum instantaneous bandwidth request
...@@ -29,21 +27,14 @@ struct dpu_core_perf_params { ...@@ -29,21 +27,14 @@ struct dpu_core_perf_params {
/** /**
* struct dpu_core_perf_tune - definition of performance tuning control * struct dpu_core_perf_tune - definition of performance tuning control
* @mode: performance mode * @mode: performance mode
* @min_core_clk: minimum core clock
* @min_bus_vote: minimum bus vote
*/ */
struct dpu_core_perf_tune { struct dpu_core_perf_tune {
u32 mode; u32 mode;
u64 min_core_clk;
u64 min_bus_vote;
}; };
/** /**
* struct dpu_core_perf - definition of core performance context * struct dpu_core_perf - definition of core performance context
* @dev: Pointer to drm device * @perf_cfg: Platform-specific performance configuration
* @debugfs_root: top level debug folder
* @catalog: Pointer to catalog configuration
* @core_clk: Pointer to the core clock
* @core_clk_rate: current core clock rate * @core_clk_rate: current core clock rate
* @max_core_clk_rate: maximum allowable core clock rate * @max_core_clk_rate: maximum allowable core clock rate
* @perf_tune: debug control for performance tuning * @perf_tune: debug control for performance tuning
...@@ -53,10 +44,7 @@ struct dpu_core_perf_tune { ...@@ -53,10 +44,7 @@ struct dpu_core_perf_tune {
* @fix_core_ab_vote: fixed core ab vote in bps used in mode 2 * @fix_core_ab_vote: fixed core ab vote in bps used in mode 2
*/ */
struct dpu_core_perf { struct dpu_core_perf {
struct drm_device *dev; const struct dpu_perf_cfg *perf_cfg;
struct dentry *debugfs_root;
const struct dpu_mdss_cfg *catalog;
struct clk *core_clk;
u64 core_clk_rate; u64 core_clk_rate;
u64 max_core_clk_rate; u64 max_core_clk_rate;
struct dpu_core_perf_tune perf_tune; struct dpu_core_perf_tune perf_tune;
...@@ -79,11 +67,10 @@ int dpu_core_perf_crtc_check(struct drm_crtc *crtc, ...@@ -79,11 +67,10 @@ int dpu_core_perf_crtc_check(struct drm_crtc *crtc,
* dpu_core_perf_crtc_update - update performance of the given crtc * dpu_core_perf_crtc_update - update performance of the given crtc
* @crtc: Pointer to crtc * @crtc: Pointer to crtc
* @params_changed: true if crtc parameters are modified * @params_changed: true if crtc parameters are modified
* @stop_req: true if this is a stop request
* return: zero if success, or error code otherwise * return: zero if success, or error code otherwise
*/ */
int dpu_core_perf_crtc_update(struct drm_crtc *crtc, int dpu_core_perf_crtc_update(struct drm_crtc *crtc,
int params_changed, bool stop_req); int params_changed);
/** /**
* dpu_core_perf_crtc_release_bw - release bandwidth of the given crtc * dpu_core_perf_crtc_release_bw - release bandwidth of the given crtc
...@@ -91,23 +78,15 @@ int dpu_core_perf_crtc_update(struct drm_crtc *crtc, ...@@ -91,23 +78,15 @@ int dpu_core_perf_crtc_update(struct drm_crtc *crtc,
*/ */
void dpu_core_perf_crtc_release_bw(struct drm_crtc *crtc); void dpu_core_perf_crtc_release_bw(struct drm_crtc *crtc);
/**
* dpu_core_perf_destroy - destroy the given core performance context
* @perf: Pointer to core performance context
*/
void dpu_core_perf_destroy(struct dpu_core_perf *perf);
/** /**
* dpu_core_perf_init - initialize the given core performance context * dpu_core_perf_init - initialize the given core performance context
* @perf: Pointer to core performance context * @perf: Pointer to core performance context
* @dev: Pointer to drm device * @perf_cfg: Pointer to platform performance configuration
* @catalog: Pointer to catalog * @max_core_clk_rate: Maximum core clock rate
* @core_clk: pointer to core clock
*/ */
int dpu_core_perf_init(struct dpu_core_perf *perf, int dpu_core_perf_init(struct dpu_core_perf *perf,
struct drm_device *dev, const struct dpu_perf_cfg *perf_cfg,
const struct dpu_mdss_cfg *catalog, unsigned long max_core_clk_rate);
struct clk *core_clk);
struct dpu_kms; struct dpu_kms;
......
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment