Page MenuHomeFreeBSD

ipsec: Clear pad bytes in PF_KEY messages
ClosedPublic

Authored by markj on Jan 15 2023, 6:36 PM.
Tags
None
Referenced Files
F107312769: D38068.diff
Sun, Jan 12, 9:23 AM
Unknown Object (File)
Nov 23 2024, 2:42 PM
Unknown Object (File)
Nov 20 2024, 6:41 PM
Unknown Object (File)
Nov 2 2024, 8:12 PM
Unknown Object (File)
Sep 22 2024, 9:11 PM
Unknown Object (File)
Sep 22 2024, 9:11 PM
Unknown Object (File)
Sep 22 2024, 9:11 PM
Unknown Object (File)
Sep 22 2024, 9:11 PM

Details

Summary

Various handlers for SADB messages will allocate a new mbuf and populate
some structures in it. Some of these structures, such as
struct sadb_supported, contain reserved fields that are not initialized
and are thus leaked to userspace.

Fix the problem by adding a helper to allocate zeroed mbufs. This
reduces code duplication and the overhead of zeroing these messages
isn't harmful.

Reported by: KMSAN
Sponsored by: The FreeBSD Foundation

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 49132
Build 46021: arc lint + arc unit

Event Timeline

markj requested review of this revision.Jan 15 2023, 6:36 PM
zlei added a subscriber: zlei.

Looks good to me.

This revision is now accepted and ready to land.Jan 16 2023, 5:09 AM

LGTM.
It would be nice to add a test for the basic PF_KEY functionality (for example, add 1 SA entry and list it afterwards)

sys/netipsec/key.c
833

Nit: worth considering using m_getm2() to simplify the logic here?

markj marked an inline comment as done.

Use m_get2() instead.

This revision now requires review to proceed.Jan 16 2023, 12:39 PM

LGTM.
It would be nice to add a test for the basic PF_KEY functionality (for example, add 1 SA entry and list it afterwards)

Ok, I will give it a try. Though, this is indirectly tested already by the sys/netipsec tests' use of setkey, which is how I found the bug.

LGTM.
It would be nice to add a test for the basic PF_KEY functionality (for example, add 1 SA entry and list it afterwards)

Ok, I will give it a try. Though, this is indirectly tested already by the sys/netipsec tests' use of setkey, which is how I found the bug.

Ack, then it's not necessary. Did any of the tests explicitly failed?

LGTM.
It would be nice to add a test for the basic PF_KEY functionality (for example, add 1 SA entry and list it afterwards)

Ok, I will give it a try. Though, this is indirectly tested already by the sys/netipsec tests' use of setkey, which is how I found the bug.

Ack, then it's not necessary. Did any of the tests explicitly failed?

Sort of. :) The problem was found by running tests in a kernel with KMSAN enabled: https://ci.freebsd.org/job/FreeBSD-main-amd64-KMSAN_test/

By default, a KMSAN report causes a kernel crash, which is what happens in this case. I'm going through test suite failures (i.e., crashes) at the moment and fixing bugs.

LGTM.
It would be nice to add a test for the basic PF_KEY functionality (for example, add 1 SA entry and list it afterwards)

Ok, I will give it a try. Though, this is indirectly tested already by the sys/netipsec tests' use of setkey, which is how I found the bug.

Ack, then it's not necessary. Did any of the tests explicitly failed?

Sort of. :) The problem was found by running tests in a kernel with KMSAN enabled: https://ci.freebsd.org/job/FreeBSD-main-amd64-KMSAN_test/

By default, a KMSAN report causes a kernel crash, which is what happens in this case. I'm going through test suite failures (i.e., crashes) at the moment and fixing bugs.

Got it. So if we already have an automated way to check for the padding issues shat should be enough.

LGTM.
It would be nice to add a test for the basic PF_KEY functionality (for example, add 1 SA entry and list it afterwards)

Ok, I will give it a try. Though, this is indirectly tested already by the sys/netipsec tests' use of setkey, which is how I found the bug.

Ack, then it's not necessary. Did any of the tests explicitly failed?

Sort of. :) The problem was found by running tests in a kernel with KMSAN enabled: https://ci.freebsd.org/job/FreeBSD-main-amd64-KMSAN_test/

By default, a KMSAN report causes a kernel crash, which is what happens in this case. I'm going through test suite failures (i.e., crashes) at the moment and fixing bugs.

Got it. So if we already have an automated way to check for the padding issues shat should be enough.

I do think it would be useful to have some comprehensive PF_KEY tests; I'm not sure how much of that surface is actually covered by the existing tests. But that would take some effort to do properly.

This revision was not accepted when it landed; it landed in state Needs Review.Jan 16 2023, 4:38 PM
This revision was automatically updated to reflect the committed changes.