net: ipa: populate clock and interconnect data
authorAlex Elder <elder@linaro.org>
Thu, 19 Nov 2020 22:40:40 +0000 (16:40 -0600)
committerJakub Kicinski <kuba@kernel.org>
Sat, 21 Nov 2020 02:45:00 +0000 (18:45 -0800)
Populate the core clock rate and interconnect average and peak
bandwidth data for SDM845 and SC7180 in their configuration data
files.  At this point we still don't *use* this data.

Note that SC7180 actually defines a new core clock rate (100 MHz
instead of 75 MHz) and new interconnect bandwidth values.  They
will be activated in the next commit, which uses the configured
values rather than the fixed constants.

Signed-off-by: Alex Elder <elder@linaro.org>
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/ipa/ipa_data-sc7180.c
drivers/net/ipa/ipa_data-sdm845.c

index 37dada4..5cc0ed7 100644 (file)
@@ -309,6 +309,26 @@ static struct ipa_mem_data ipa_mem_data = {
        .smem_size      = 0x00002000,
 };
 
+static struct ipa_clock_data ipa_clock_data = {
+       .core_clock_rate        = 100 * 1000 * 1000,    /* Hz */
+       /* Interconnect rates are in 1000 byte/second units */
+       .interconnect = {
+               [IPA_INTERCONNECT_MEMORY] = {
+                       .peak_rate      = 465000,       /* 465 MBps */
+                       .average_rate   = 80000,        /* 80 MBps */
+               },
+               /* Average rate is unused for the next two interconnects */
+               [IPA_INTERCONNECT_IMEM] = {
+                       .peak_rate      = 68570,        /* 68.570 MBps */
+                       .average_rate   = 0,            /* unused */
+               },
+               [IPA_INTERCONNECT_CONFIG] = {
+                       .peak_rate      = 30000,        /* 30 MBps */
+                       .average_rate   = 0,            /* unused */
+               },
+       },
+};
+
 /* Configuration data for the SC7180 SoC. */
 const struct ipa_data ipa_data_sc7180 = {
        .version        = IPA_VERSION_4_2,
@@ -316,4 +336,5 @@ const struct ipa_data ipa_data_sc7180 = {
        .endpoint_data  = ipa_gsi_endpoint_data,
        .resource_data  = &ipa_resource_data,
        .mem_data       = &ipa_mem_data,
+       .clock_data     = &ipa_clock_data,
 };
index bd92b61..f8fee8d 100644 (file)
@@ -329,6 +329,26 @@ static struct ipa_mem_data ipa_mem_data = {
        .smem_size      = 0x00002000,
 };
 
+static struct ipa_clock_data ipa_clock_data = {
+       .core_clock_rate        = 75 * 1000 * 1000,     /* Hz */
+       /* Interconnect rates are in 1000 byte/second units */
+       .interconnect = {
+               [IPA_INTERCONNECT_MEMORY] = {
+                       .peak_rate      = 600000,       /* 600 MBps */
+                       .average_rate   = 80000,        /* 80 MBps */
+               },
+               /* Average rate is unused for the next two interconnects */
+               [IPA_INTERCONNECT_IMEM] = {
+                       .peak_rate      = 350000,       /* 350 MBps */
+                       .average_rate   = 0,            /* unused */
+               },
+               [IPA_INTERCONNECT_CONFIG] = {
+                       .peak_rate      = 40000,        /* 40 MBps */
+                       .average_rate   = 0,            /* unused */
+               },
+       },
+};
+
 /* Configuration data for the SDM845 SoC. */
 const struct ipa_data ipa_data_sdm845 = {
        .version        = IPA_VERSION_3_5_1,
@@ -336,4 +356,5 @@ const struct ipa_data ipa_data_sdm845 = {
        .endpoint_data  = ipa_gsi_endpoint_data,
        .resource_data  = &ipa_resource_data,
        .mem_data       = &ipa_mem_data,
+       .clock_data     = &ipa_clock_data,
 };