soc: qcom: mdt_loader: Fix split image detection
authorBjorn Andersson <quic_bjorande@quicinc.com>
Mon, 12 Jun 2023 21:58:04 +0000 (14:58 -0700)
committerBjorn Andersson <andersson@kernel.org>
Tue, 13 Jun 2023 17:13:01 +0000 (10:13 -0700)
The enhanced detection introduced in commit '210d12c8197a ("soc: qcom:
mdt_loader: Enhance split binary detection")' requires that all segments
lies within the file on disk.

But the Qualcomm firmware files consistently has a BSS-like segment at
the end, with a p_offset aligned to the next 4k boundary. As the p_size
is 0 and there's nothing to load, the image is not padded to cover this
(empty) segment.

Ignore zero-sized segments when determining if the image is split, to
avoid this problem.

Fixes: 210d12c8197a ("soc: qcom: mdt_loader: Enhance split binary detection")
Signed-off-by: Bjorn Andersson <quic_bjorande@quicinc.com>
Reviewed-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
Tested-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org> # qrb5165-rb5
Signed-off-by: Bjorn Andersson <andersson@kernel.org>
Link: https://lore.kernel.org/r/20230612215804.1883458-1-quic_bjorande@quicinc.com
drivers/soc/qcom/mdt_loader.c

index 9418993a3a9203da8ed5f1bddb9a2df753160b0f..6f177e46fa0f8ec3adff1338c0f0de3a41633cf6 100644 (file)
@@ -275,6 +275,14 @@ static bool qcom_mdt_bins_are_split(const struct firmware *fw, const char *fw_na
        phdrs = (struct elf32_phdr *)(ehdr + 1);
 
        for (i = 0; i < ehdr->e_phnum; i++) {
+               /*
+                * The size of the MDT file is not padded to include any
+                * zero-sized segments at the end. Ignore these, as they should
+                * not affect the decision about image being split or not.
+                */
+               if (!phdrs[i].p_filesz)
+                       continue;
+
                seg_start = phdrs[i].p_offset;
                seg_end = phdrs[i].p_offset + phdrs[i].p_filesz;
                if (seg_start > fw->size || seg_end > fw->size)