Page MenuHomeFreeBSD

kernel linkers: Validate linker set on lookup
AcceptedPublic

Authored by zlei on Apr 28 2023, 4:31 AM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Jan 20, 11:52 PM
Unknown Object (File)
Wed, Jan 15, 5:29 PM
Unknown Object (File)
Fri, Jan 10, 9:55 AM
Unknown Object (File)
Sep 30 2024, 6:37 PM
Unknown Object (File)
Sep 24 2024, 10:31 PM
Unknown Object (File)
Sep 21 2024, 5:00 PM
Unknown Object (File)
Sep 19 2024, 8:46 PM
Unknown Object (File)
Sep 19 2024, 3:05 PM
Subscribers

Details

Reviewers
kib

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

zlei requested review of this revision.Apr 28 2023, 4:32 AM

I do not have objections, but I am curious, did you see real (corrupted) files with wrapped around linker sets?

We do not harden linkers against bad-formed objects, there is no point in doing so.

This revision is now accepted and ready to land.Apr 28 2023, 4:37 AM

Fast response +1

In D39864#907436, @kib wrote:

I do not have objections, but I am curious, did you see real (corrupted) files with wrapped around linker sets?

I am inspired by @hselasky 's comment on D39638 :

#ifdef VIMAGE
static void
link_elf_propagate_vnets(linker_file_t lf)
{
	elf_file_t ef = (elf_file_t)lf;
	int size; // @hselasky Technically this variable should be "ssize_t".

	size = (uintptr_t)ef->vnet_stop - (uintptr_t)ef->vnet_start;
...
}

Ideally the var size should be size_t, if link_elf_lookup_set() can guaranty stop >= start.

I checked all consumers of link_elf_lookup_set() and the kernel can behaves good even stop < start. So this will not introduce any functional changes.
I produced some corrupted kmods via https://elfy.io/ and verified that.

I did not encounter this (real corrupted files), or someone did but the kernel still behaves good so they are ignored.

We do not harden linkers against bad-formed objects, there is no point in doing so.

I'm not getting that well. Do you mean validating bad-formed objects cost too much ? Or linkers are not responsible to validate ?

In D39864#907443, @zlei wrote:

We do not harden linkers against bad-formed objects, there is no point in doing so.

I'm not getting that well. Do you mean validating bad-formed objects cost too much ? Or linkers are not responsible to validate ?

It is both to hard and meaningless. Suppose you got a corrupted module loaded, and kernel crashes. Next, suppose you loaded correctly formed module but with malicious code. Is there a difference? Simply do not load modules from untrusted places.