diff options
author | Bjorn Andersson <bjorn.andersson@linaro.org> | 2017-01-27 05:06:36 -0500 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2017-03-12 00:41:50 -0500 |
commit | 24d77f99a7b74b4b68682d54ee79992b8aed7421 (patch) | |
tree | 0b60ba0ebb10f3a70149ea8d3f454a80fcb6e4fe | |
parent | 4cf918c804c657c3a8b9cd4bb46171315bdfad62 (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.c | 7 |
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) |