Page MenuHomeFreeBSD

aesni: Avoid a potential out-of-bounds load in aes_encrypt_icm()
ClosedPublic

Authored by markj on Aug 30 2021, 5:40 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Jan 18, 4:53 AM
Unknown Object (File)
Dec 1 2024, 4:47 AM
Unknown Object (File)
Nov 25 2024, 8:07 AM
Unknown Object (File)
Nov 23 2024, 5:56 AM
Unknown Object (File)
Nov 22 2024, 9:17 AM
Unknown Object (File)
Nov 20 2024, 9:59 PM
Unknown Object (File)
Nov 20 2024, 4:01 AM
Unknown Object (File)
Nov 19 2024, 6:59 AM
Subscribers

Details

Summary

Given a partial block at the end of a payload, aes_encrypt_icm() would
perform a 16-byte load of the residual into a temporary variable. This
is unsafe in principle since the full block may cross a page boundary.
Fix the problem by copying up to the end of input into a stack variable
and operating on that instead.

Reported by: syzbot+b7e44cde9e2e89f0f6c9@syzkaller.appspotmail.com
Reported by: syzbot+4b5eaf123a99456b5160@syzkaller.appspotmail.com

Test Plan

cryptocheck (which is also able to trigger the panic with KASAN enabled)

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
No Lint Coverage
Unit
No Test Coverage
Build Status
Buildable 41265
Build 38154: arc lint + arc unit