]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
soc: qcom: geni-se: Enable QUPs on SA8255p Qualcomm platforms
authorPraveen Talari <quic_ptalari@quicinc.com>
Mon, 21 Jul 2025 17:45:27 +0000 (23:15 +0530)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 22 Jul 2025 16:52:50 +0000 (18:52 +0200)
On the sa8255p platform, resources such as clocks,interconnects
and TLMM (GPIO) configurations are managed by firmware.

Use the `num_clks` field in platform data to distinguish whether
resource control is performed by firmware or directly by the driver
in linux.

Signed-off-by: Praveen Talari <quic_ptalari@quicinc.com>
Link: https://lore.kernel.org/r/20250721174532.14022-4-quic_ptalari@quicinc.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/soc/qcom/qcom-geni-se.c

index 4cb959106efa9e1249893a4a5c0bcb9b8fce6cfc..3c3b796333a61e2664d54c2fc85d6894a128655d 100644 (file)
@@ -895,6 +895,7 @@ static int geni_se_probe(struct platform_device *pdev)
 {
        struct device *dev = &pdev->dev;
        struct geni_wrapper *wrapper;
+       const struct geni_se_desc *desc;
        int ret;
 
        wrapper = devm_kzalloc(dev, sizeof(*wrapper), GFP_KERNEL);
@@ -906,13 +907,10 @@ static int geni_se_probe(struct platform_device *pdev)
        if (IS_ERR(wrapper->base))
                return PTR_ERR(wrapper->base);
 
-       if (!has_acpi_companion(&pdev->dev)) {
-               const struct geni_se_desc *desc;
-               int i;
+       desc = device_get_match_data(&pdev->dev);
 
-               desc = device_get_match_data(&pdev->dev);
-               if (!desc)
-                       return -EINVAL;
+       if (!has_acpi_companion(&pdev->dev) && desc->num_clks) {
+               int i;
 
                wrapper->num_clks = min_t(unsigned int, desc->num_clks, MAX_CLKS);
 
@@ -953,6 +951,8 @@ static const struct geni_se_desc qup_desc = {
        .num_clks = ARRAY_SIZE(qup_clks),
 };
 
+static const struct geni_se_desc sa8255p_qup_desc = {};
+
 static const char * const i2c_master_hub_clks[] = {
        "s-ahb",
 };
@@ -965,6 +965,7 @@ static const struct geni_se_desc i2c_master_hub_desc = {
 static const struct of_device_id geni_se_dt_match[] = {
        { .compatible = "qcom,geni-se-qup", .data = &qup_desc },
        { .compatible = "qcom,geni-se-i2c-master-hub", .data = &i2c_master_hub_desc },
+       { .compatible = "qcom,sa8255p-geni-se-qup", .data = &sa8255p_qup_desc },
        {}
 };
 MODULE_DEVICE_TABLE(of, geni_se_dt_match);