UPSTREAM: rmodtool: correct final memory size calculation
Apparently when I originally wrote this I confused myself to no end. The code/data of an rmodule has a set memory size which is associated with the .payload section. The relocation entries may increase the overall footprint of the memory size if the rmodule has no bss but a lot of relocations. Therefore, just compare relocation entries size plus the file size of the .payload section with the memory size of the paylod section. The .empty section is added only when we have not met the final target size. BUG=chrome-os-partner:31615 BRANCH=None TEST=Compiles successfully and the elf.rmod created is verified using readelf and objdump Change-Id: I67d8c1267b2216786019eadc02f48b6502026602 Author: Aaron Durbin <adurbin@chromium.org> Signed-off-by: Furquan Shaikh <furquan@google.com> Reviewed-on: https://chromium-review.googlesource.com/214324 Tested-by: Furquan Shaikh <furquan@chromium.org> Reviewed-by: Aaron Durbin <adurbin@chromium.org> Commit-Queue: Aaron Durbin <adurbin@chromium.org>
This commit is contained in:
parent
cae87fb1ef
commit
935a0041ac
1 changed files with 3 additions and 3 deletions
|
|
@ -548,11 +548,11 @@ write_elf(const struct rmod_context *ctx, const struct buffer *in,
|
|||
* is considered a part of the program.
|
||||
*/
|
||||
total_size += buffer_size(&rmod_header);
|
||||
total_size += ctx->phdr->p_memsz;
|
||||
if (buffer_size(&relocs) + ctx->phdr->p_filesz > total_size) {
|
||||
total_size -= ctx->phdr->p_memsz;
|
||||
if (buffer_size(&relocs) + ctx->phdr->p_filesz > ctx->phdr->p_memsz) {
|
||||
total_size += buffer_size(&relocs);
|
||||
total_size += ctx->phdr->p_filesz;
|
||||
} else {
|
||||
total_size += ctx->phdr->p_memsz;
|
||||
}
|
||||
|
||||
ret = add_section(ew, &rmod_header, ".header", addr,
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue