Hi,
On 1/4/22 11:32, Mark Brown wrote:
On Thu, Dec 09, 2021 at 11:10:48AM +0000, Szabolcs Nagy wrote:
The 12/08/2021 18:23, Catalin Marinas wrote:
On Mon, Nov 15, 2021 at 03:27:10PM +0000, Mark Brown wrote:
memory is already mapped with PROT_EXEC. This series resolves this by
handling the BTI property for both the interpreter and the main
executable.
Given the silence on this series over the past months, I propose we drop
it. It's a bit unfortunate that systemd's MemoryDenyWriteExecute cannot
work with BTI but I also think the former is a pretty blunt hardening
mechanism (rejecting any mprotect(PROT_EXEC) regardless of the previous
attributes).
i still think it would be better if the kernel dealt with
PROT_BTI for the exe loaded by the kernel.
The above message from Catalin isn't quite the full story here - my
understanding from backchannel is that there's concern from others that
we might be creating future issues by enabling PROT_BTI, especially in
the case where the same permissions issue prevents the dynamic linker
disabling PROT_BTI. They'd therefore rather stick with the status quo
and not create any new ABI. Unfortunately that's not something people
have been willing to say on the list, hopefully the above captures the
thinking well enough.
Personally I'm a bit ambivalent on this, I do see the potential issue
but I'm having trouble constructing an actual scenario and my instinct
is that since we handle PROT_EXEC we should also handle PROT_BTI for
consistency.
I'm hardly a security expert, but it seems to me that BTI hardens
against a wider set of possible exploits than MDWE. Yet, we are silently
turning it off for systemd services which are considered some of the
most security critical things in the machine right now (ex:logind, etc).
So despite 'systemd-analyze secuirty` flagging those services as the
most secure ones on a system, they might actually be less secure.
It also seems that getting BTI turned on earlier, as this patch is doing
is itself a win.
So, mentally i'm having a hard time balancing the hypothetical problem
laid out, as it should only really exist in an environment similar to
the MDWE one, since AFAIK, its possible today to just flip it back off
unless MDWE stops that from happening.
What are the the remaining alternatives? A new syscall? But that is by
definition a new ABI, and wouldn't benefit from having BTI turned on as
early as this patch is doing. Should we disable MDWE on a BTI machine?
I'm not sure that is a good look, particularly if MDWE happens to
successfully stop some exploit. AFAIK, MDWE+BTI are a good strong
combination, it seems a shame if we can't get them both working together.
I hesitate to suggest it, but maybe this patch should be conditional
somehow, that way !systemd/MDWE machines can behave as they do today,
and systemd/MDWE machines can request BTI be turned on by the kernel
automatically?