soc: qcom: smem: always ignore partitions with 0 offset or size
authorAlex Elder <elder@linaro.org>
Tue, 26 Jun 2018 00:58:47 +0000 (19:58 -0500)
committerAndy Gross <andy.gross@linaro.org>
Thu, 13 Sep 2018 21:56:55 +0000 (16:56 -0500)
In qcom_smem_enumerate_partitions(), any partition table entry
having a zero offset or size field is ignored.  Move those checks
earlier in the loop, because there's no sense in examining the
host fields for those entries.

Add the same checks in qcom_smem_set_global_partition(), so the
scan for the global partition skips over these invalid entries.
This allows a later check for zero size or offset once the global
entry is found to be eliminated.

Signed-off-by: Alex Elder <elder@linaro.org>
Signed-off-by: Andy Gross <andy.gross@linaro.org>
drivers/soc/qcom/smem.c

index 938ffb01d155ac65079f9fda1c761161a3a0d7f9..9378bee4d7d6f313c516eae0172ca402db1b620b 100644 (file)
@@ -743,9 +743,13 @@ static int qcom_smem_set_global_partition(struct qcom_smem *smem)
 
        for (i = 0; i < le32_to_cpu(ptable->num_entries); i++) {
                entry = &ptable->entry[i];
+               if (!le32_to_cpu(entry->offset))
+                       continue;
+               if (!le32_to_cpu(entry->size))
+                       continue;
+
                host0 = le16_to_cpu(entry->host0);
                host1 = le16_to_cpu(entry->host1);
-
                if (host0 == SMEM_GLOBAL_HOST && host0 == host1) {
                        found = true;
                        break;
@@ -757,11 +761,6 @@ static int qcom_smem_set_global_partition(struct qcom_smem *smem)
                return -EINVAL;
        }
 
-       if (!le32_to_cpu(entry->offset) || !le32_to_cpu(entry->size)) {
-               dev_err(smem->dev, "Invalid entry for global partition\n");
-               return -EINVAL;
-       }
-
        header = smem->regions[0].virt_base + le32_to_cpu(entry->offset);
        host0 = le16_to_cpu(header->host0);
        host1 = le16_to_cpu(header->host1);
@@ -810,18 +809,16 @@ static int qcom_smem_enumerate_partitions(struct qcom_smem *smem,
 
        for (i = 0; i < le32_to_cpu(ptable->num_entries); i++) {
                entry = &ptable->entry[i];
-               host0 = le16_to_cpu(entry->host0);
-               host1 = le16_to_cpu(entry->host1);
-
-               if (host0 != local_host && host1 != local_host)
-                       continue;
-
                if (!le32_to_cpu(entry->offset))
                        continue;
-
                if (!le32_to_cpu(entry->size))
                        continue;
 
+               host0 = le16_to_cpu(entry->host0);
+               host1 = le16_to_cpu(entry->host1);
+               if (host0 != local_host && host1 != local_host)
+                       continue;
+
                if (host0 == local_host)
                        remote_host = host1;
                else