mirror of
				git://git.yoctoproject.org/linux-yocto.git
				synced 2025-10-22 23:13:01 +02:00 
			
		
		
		
	soc: qcom: mdt_loader: Actually use the e_phoff
Rather than relying/assuming that the tools generating the firmware places the program headers immediately following the ELF header, use e_phoff as intended to find the program headers. Reviewed-by: Dmitry Baryshkov <dmitry.baryshkov@oss.qualcomm.com> Signed-off-by: Bjorn Andersson <bjorn.andersson@oss.qualcomm.com> Link: https://lore.kernel.org/r/20250610-mdt-loader-validation-and-fixes-v2-3-f7073e9ab899@oss.qualcomm.com Signed-off-by: Bjorn Andersson <andersson@kernel.org>
This commit is contained in:
		
							parent
							
								
									cd840362b0
								
							
						
					
					
						commit
						47e339cac8
					
				|  | @ -117,7 +117,7 @@ ssize_t qcom_mdt_get_size(const struct firmware *fw) | |||
| 		return -EINVAL; | ||||
| 
 | ||||
| 	ehdr = (struct elf32_hdr *)fw->data; | ||||
| 	phdrs = (struct elf32_phdr *)(ehdr + 1); | ||||
| 	phdrs = (struct elf32_phdr *)(fw->data + ehdr->e_phoff); | ||||
| 
 | ||||
| 	for (i = 0; i < ehdr->e_phnum; i++) { | ||||
| 		phdr = &phdrs[i]; | ||||
|  | @ -172,7 +172,7 @@ void *qcom_mdt_read_metadata(const struct firmware *fw, size_t *data_len, | |||
| 		return ERR_PTR(-EINVAL); | ||||
| 
 | ||||
| 	ehdr = (struct elf32_hdr *)fw->data; | ||||
| 	phdrs = (struct elf32_phdr *)(ehdr + 1); | ||||
| 	phdrs = (struct elf32_phdr *)(fw->data + ehdr->e_phoff); | ||||
| 
 | ||||
| 	if (ehdr->e_phnum < 2) | ||||
| 		return ERR_PTR(-EINVAL); | ||||
|  | @ -255,7 +255,7 @@ int qcom_mdt_pas_init(struct device *dev, const struct firmware *fw, | |||
| 		return -EINVAL; | ||||
| 
 | ||||
| 	ehdr = (struct elf32_hdr *)fw->data; | ||||
| 	phdrs = (struct elf32_phdr *)(ehdr + 1); | ||||
| 	phdrs = (struct elf32_phdr *)(fw->data + ehdr->e_phoff); | ||||
| 
 | ||||
| 	for (i = 0; i < ehdr->e_phnum; i++) { | ||||
| 		phdr = &phdrs[i]; | ||||
|  | @ -310,7 +310,7 @@ static bool qcom_mdt_bins_are_split(const struct firmware *fw, const char *fw_na | |||
| 	int i; | ||||
| 
 | ||||
| 	ehdr = (struct elf32_hdr *)fw->data; | ||||
| 	phdrs = (struct elf32_phdr *)(ehdr + 1); | ||||
| 	phdrs = (struct elf32_phdr *)(fw->data + ehdr->e_phoff); | ||||
| 
 | ||||
| 	for (i = 0; i < ehdr->e_phnum; i++) { | ||||
| 		/*
 | ||||
|  | @ -355,7 +355,7 @@ static int __qcom_mdt_load(struct device *dev, const struct firmware *fw, | |||
| 
 | ||||
| 	is_split = qcom_mdt_bins_are_split(fw, fw_name); | ||||
| 	ehdr = (struct elf32_hdr *)fw->data; | ||||
| 	phdrs = (struct elf32_phdr *)(ehdr + 1); | ||||
| 	phdrs = (struct elf32_phdr *)(fw->data + ehdr->e_phoff); | ||||
| 
 | ||||
| 	for (i = 0; i < ehdr->e_phnum; i++) { | ||||
| 		phdr = &phdrs[i]; | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Bjorn Andersson
						Bjorn Andersson