Page MenuHomeFreeBSD

link_elf_obj: Apply protection based on section flags.
ClosedPublic

Authored by markj on Oct 4 2019, 4:12 PM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Jan 6, 8:55 PM
Unknown Object (File)
Oct 8 2024, 12:22 AM
Unknown Object (File)
Sep 5 2024, 12:38 PM
Unknown Object (File)
Sep 4 2024, 11:41 AM
Unknown Object (File)
Aug 31 2024, 6:55 PM
Unknown Object (File)
Aug 29 2024, 2:09 AM
Unknown Object (File)
Aug 22 2024, 8:51 PM
Unknown Object (File)
Aug 22 2024, 8:21 PM
Subscribers

Details

Summary

Unlike the case of DSOs, we cannot assume that protection boundaries are
page-aligned. In this case, we must take the union of the protections
for the sections sharing a page.

There may also be gaps between sections. For instance, the VNET and
DPCPU sections are allocated separately and do not lie within the linker
file mapping. Such gaps are mapped with VM_PROT_READ.

As for link_elf.c, we initially map the file with VM_PROT_ALL and
downgrade once all relocations are processed.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

sys/kern/link_elf_obj.c
213 ↗(On Diff #62903)

This relies on KERN_SUCCES == 0, I always want more explicitness in handling Mach<->errno translation.

Also, when could vm_map_protect() above fail ?

sys/kern/link_elf_obj.c
213 ↗(On Diff #62903)

In fact, it should be impossible for vm_map_protect() to fail here.

Assert that vm_map_protect() returns KERN_SUCCESS.

This revision is now accepted and ready to land.Oct 4 2019, 7:46 PM
This revision was automatically updated to reflect the committed changes.