]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
soc: qcom: ocmem: Add OCMEM hardware version print
authorLuca Weiss <luca@z3ntu.xyz>
Mon, 29 May 2023 08:41:15 +0000 (10:41 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 13 Sep 2023 07:48:10 +0000 (09:48 +0200)
[ Upstream commit e81a16e77259294cd4ff0a9c1fbe5aa0e311a47d ]

It might be useful to know what hardware version of the OCMEM block the
SoC contains. Add a debug print for that.

Signed-off-by: Luca Weiss <luca@z3ntu.xyz>
Reviewed-by: Konrad Dybcio <konrad.dybcio@linaro.org>
Signed-off-by: Bjorn Andersson <andersson@kernel.org>
Link: https://lore.kernel.org/r/20230509-ocmem-hwver-v3-1-e51f3488e0f4@z3ntu.xyz
Stable-dep-of: a7b484b1c933 ("soc: qcom: ocmem: Fix NUM_PORTS & NUM_MACROS macros")
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/soc/qcom/ocmem.c

index 199fe9872035098d790cace43a800018bc6a5ee0..aaddc3cc53b7f3121c5b27576d053d85beb5b8e1 100644 (file)
@@ -76,6 +76,10 @@ struct ocmem {
 #define OCMEM_REG_GFX_MPU_START                        0x00001004
 #define OCMEM_REG_GFX_MPU_END                  0x00001008
 
+#define OCMEM_HW_VERSION_MAJOR(val)            FIELD_GET(GENMASK(31, 28), val)
+#define OCMEM_HW_VERSION_MINOR(val)            FIELD_GET(GENMASK(27, 16), val)
+#define OCMEM_HW_VERSION_STEP(val)             FIELD_GET(GENMASK(15, 0), val)
+
 #define OCMEM_HW_PROFILE_NUM_PORTS(val)                FIELD_PREP(0x0000000f, (val))
 #define OCMEM_HW_PROFILE_NUM_MACROS(val)       FIELD_PREP(0x00003f00, (val))
 
@@ -355,6 +359,12 @@ static int ocmem_dev_probe(struct platform_device *pdev)
                }
        }
 
+       reg = ocmem_read(ocmem, OCMEM_REG_HW_VERSION);
+       dev_dbg(dev, "OCMEM hardware version: %lu.%lu.%lu\n",
+               OCMEM_HW_VERSION_MAJOR(reg),
+               OCMEM_HW_VERSION_MINOR(reg),
+               OCMEM_HW_VERSION_STEP(reg));
+
        reg = ocmem_read(ocmem, OCMEM_REG_HW_PROFILE);
        ocmem->num_ports = OCMEM_HW_PROFILE_NUM_PORTS(reg);
        ocmem->num_macros = OCMEM_HW_PROFILE_NUM_MACROS(reg);