![]() |
|
Message-ID: <071df386-676e-47df-958d-287023b32ea2@gmail.com>
Date: Fri, 26 Sep 2025 21:33:26 -0500
From: Jacob Bachmeyer <jcb62281@...il.com>
To: Demi Marie Obenour <demiobenour@...il.com>,
oss-security@...ts.openwall.com, Peter Gutmann <pgut001@...auckland.ac.nz>,
"Adiletta, Andrew" <ajadiletta@....edu>, Solar Designer
<solar@...nwall.com>, Andrew Cooper <andrew.cooper3@...rix.com>
Cc: "openssh@...nssh.com" <openssh@...nssh.com>, "Tol, Caner" <mtol@....edu>,
"Sunar, Berk" <sunar@....edu>, "Doroz, Yarkin" <ydoroz@....edu>,
"Todd C. Miller" <Todd.Miller@...rtesan.com>
Subject: Re: Re: [EXT] Re: CVE-2023-51767: a
bogus CVE in OpenSSH
On 9/26/25 20:04, Demi Marie Obenour wrote:
> On 9/26/25 20:06, Jacob Bachmeyer wrote:
>> On 9/26/25 09:19, Demi Marie Obenour wrote:
>>> On 9/25/25 22:33, Jacob Bachmeyer wrote:
>>> [...]
>>>> It seems highly likely that Rowhammer is an inherent consequence of DRAM
>>>> density beyond a certain limit and highly *unlikely* that reducing DRAM
>>>> density below the "Rowhammer threshold" will prove to be an acceptable
>>>> solution.
>>> Seehttps://arxiv.org/pdf/2407.09995 for the proper solution: store a
>>> per-row activation counter alongside the row itself, and when any row
>>> in a bank exceeds the threshold, take action.
>> I am somewhat skeptical about this, simply because there have been many
>> "proper solutions" to Rowhammer that have thus far failed.
> Have any of them had a proof of correctness? MOAT at least claims to,
> and if that proof is correct, then either it is secure or one of the
> assumptions it is based on is invalid.
Unless I misunderstood the paper on a first reading, that proof is only
an upper bound on row activations before mitigations are applied. That
says *nothing* about actually preventing bit-flips.
In particular, the possibility of some as-yet-unknown access pattern not
mitigated by MOAT being usable for Rowhammer is simply out-of-scope for
MOAT's correctness proof---and disturbingly plausible to me as DRAM
densities continue to increase.
>>>> [...]
>>>>
>>>>
>>>> The stack is intrinsically aligned on much finer than page granularity;
>>>> introducing additional "jitter" to the locations of stack variables (and
>>>> spilled registers) is a solution available today with minimal cost. All
>>>> you need is "size_t slide_size=random_stack_slide_size(); void *
>>>> slide=alloca(slide_size); memset(slide,0,slide_size);" near the top of
>>>> main (and possibly other functions to "mix it up" more) and a function
>>>> random_stack_slide_size() that gives an appropriate unpredictable value.
>>>>
>>>> The key is to avoid trying to prevent bits from being flipped (that
>>>> proverbial ship has sailed on current hardware) but instead prevent an
>>>> attacker from being able to predict accomplishing something useful with
>>>> those bit-flips.
>>> I suspect that in general this is provably impossible.
>> You suspect that ASLR is generally provably useless? "Sliding" the
>> stack is the same basic principle as ASLR.
> ASLR is an awesome mitigation. It definitely makes attacks much harder.
> I have yet to see a case where it provably makes an attack impossible.
> If you are aware of one, I would love to know.
Provably impossible? No, but it *can* increase the number of bits that
an attacker must accurately guess beyond feasibility.
>> The "Rowhammer Mayhem" attack evades ASLR by exploiting the kernel's
>> physical page allocation policy, effectively converting the significant
>> address to an ordinal page number ("Nth page allocated") and offset
>> instead of a virtual or physical address.
>>
>>> My hope is that
>>> EU regulations like CRA and PLD will force hardware recalls when defects
>>> like Rowhammer are detected.
>> You realize that legal cudgels like that could very well kill the entire
>> computing industry if it turns out that Rowhammer is due to physical
>> limitations, right?
> There is no law saying that DRAM must be used, or that it must have
> a feature size as small as it has. A larger feature size (bigger
> capacitors) could stop the attack, albeit at great expense.
> Increasing the refresh rate and noise margins would also help.
Both of those are effectively mandated by the marketplace and current
technology. DRAM is the only currently practical ultra-high-density
fast working memory technology, and the small feature sizes are needed
both for capacity and performance.
It is not just a matter of "great expense"---bigger DRAM capacitors also
mean *slower* DRAM. The laws of physics are not subject to repeal or
revision to suit our wants.
> Another option is to cryptographically authenticate every row. If
> a full-width MAC is used, the attacker must flip at least 129 bits
> and they have absolutely no margin for error: even a single error
> will be detected. If the attacker cannot do this (and I have seen
> no paper suggesting they can), this prevents Rowhammer from being
> a memory corruption vulnerability. If the memory is also encrypted,
> this reduces Rowhammer to denial of service at worst. DRAM rows
> are very wide, so the cost of the MAC can be amortized across a
> large number of bits.
Computing a cryptographically-sound MAC is very expensive, although
using an authenticated encryption mode with existing hardware RAM
encryption could help. Even RAM encryption at all might help, if a
non-malleable mode is used, since then flipping one ciphertext bit will
cause multiple plaintext bits to flip.
> The burden should be on hardware vendors to create hardware without
> security holes. Formal verification at the HDL level can catch
> defects in the source code. Some proofs might be able to be
> generated automatically, while others might have to be written by
> hand and machine-checked. For other issues, there is no solution
> I know of other than being extremely careful in the design process.
Rowhammer relies on physical effects that are not normally modeled in
VLSI design and may or may not be sufficiently characterized to
predictively model. As far as I know, the DRAM vendors are not talking
about those details.
Further, normal programs do not make the access patterns that cause
Rowhammer bit flips. The hardware is arguably working correctly when
used as intended and not actually defective. On modern hardware, a
normal program frequently accessing the same row should hit DRAM once
and then the caches. Rowhammer attacks arrange fake working sets that
exceed the caches and produce highly unusual access patterns.
> If defects like Rowhammer, Zenbleed, or Spectre forced product
> recalls, there would be a massive economic incentive to produce
> hardware that lacked such defects. I suspect this would solve the
> problem in fairly short order. The question is whether the
> economic cost of doing so -- and of not doing so -- is something
> that society, and end users, are willing to pay.
You realize that between Zenbleed and Spectre, *both* current x86
processor vendors would likely now be bankrupt due to expensive recalls
if your proposal had been adopted? Where would that leave us? With
other CPU architectures? Well, then...
Rowhammer affects basically the entire DRAM industry. What would be the
economic results of an industry-wide recall? Would the recall simply be
ignored because users prefer to actually *have* computers?
I suspect that the result of such EU policies would be the industry
leaving the EU market.
-- Jacob
Content of type "text/html" skipped
Powered by blists - more mailing lists
Please check out the Open Source Software Security Wiki, which is counterpart to this mailing list.
Confused about mailing lists and their use? Read about mailing lists on Wikipedia and check out these guidelines on proper formatting of your messages.