aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBjorn Andersson <bjorn.andersson@linaro.org>2017-01-27 05:06:36 -0500
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2017-03-12 00:41:50 -0500
commit24d77f99a7b74b4b68682d54ee79992b8aed7421 (patch)
tree0b60ba0ebb10f3a70149ea8d3f454a80fcb6e4fe
parent4cf918c804c657c3a8b9cd4bb46171315bdfad62 (diff)
remoteproc: qcom: mdt_loader: Don't overwrite firmware object
commit 3e8b571a9a0881ba3381ca0915995696da145ab8 upstream. The "fw" firmware object is passed from the remoteproc core and should not be overwritten, as that results in leaked buffers and a double free of the the last firmware object. Fixes: 051fb70fd4ea ("remoteproc: qcom: Driver for the self-authenticating Hexagon v5") Signed-off-by: Bjorn Andersson <bjorn.andersson@linaro.org> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-rw-r--r--drivers/remoteproc/qcom_mdt_loader.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/drivers/remoteproc/qcom_mdt_loader.c b/drivers/remoteproc/qcom_mdt_loader.c
index 114e8e4cef67..04db02d9059d 100644
--- a/drivers/remoteproc/qcom_mdt_loader.c
+++ b/drivers/remoteproc/qcom_mdt_loader.c
@@ -115,6 +115,7 @@ int qcom_mdt_load(struct rproc *rproc,
115 const struct elf32_phdr *phdrs; 115 const struct elf32_phdr *phdrs;
116 const struct elf32_phdr *phdr; 116 const struct elf32_phdr *phdr;
117 const struct elf32_hdr *ehdr; 117 const struct elf32_hdr *ehdr;
118 const struct firmware *seg_fw;
118 size_t fw_name_len; 119 size_t fw_name_len;
119 char *fw_name; 120 char *fw_name;
120 void *ptr; 121 void *ptr;
@@ -153,16 +154,16 @@ int qcom_mdt_load(struct rproc *rproc,
153 154
154 if (phdr->p_filesz) { 155 if (phdr->p_filesz) {
155 sprintf(fw_name + fw_name_len - 3, "b%02d", i); 156 sprintf(fw_name + fw_name_len - 3, "b%02d", i);
156 ret = request_firmware(&fw, fw_name, &rproc->dev); 157 ret = request_firmware(&seg_fw, fw_name, &rproc->dev);
157 if (ret) { 158 if (ret) {
158 dev_err(&rproc->dev, "failed to load %s\n", 159 dev_err(&rproc->dev, "failed to load %s\n",
159 fw_name); 160 fw_name);
160 break; 161 break;
161 } 162 }
162 163
163 memcpy(ptr, fw->data, fw->size); 164 memcpy(ptr, seg_fw->data, seg_fw->size);
164 165
165 release_firmware(fw); 166 release_firmware(seg_fw);
166 } 167 }
167 168
168 if (phdr->p_memsz > phdr->p_filesz) 169 if (phdr->p_memsz > phdr->p_filesz)