Page MenuHomeFreeBSD

Move per-operation data out of the csession structure.
ClosedPublic

Authored by jhb on Jan 16 2018, 12:59 AM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Apr 27, 11:54 PM
Unknown Object (File)
Wed, Apr 22, 10:23 AM
Unknown Object (File)
Wed, Apr 22, 8:37 AM
Unknown Object (File)
Sun, Apr 19, 9:21 PM
Unknown Object (File)
Apr 17 2026, 3:12 AM
Unknown Object (File)
Apr 15 2026, 1:44 PM
Unknown Object (File)
Apr 14 2026, 4:51 AM
Unknown Object (File)
Apr 11 2026, 4:43 PM
Subscribers

Details

Summary

Create a struct cryptop_data which contains state needed for a single
symmetric crypto operation and move that state out of the session. This
closes a race with the CRYPTO_F_DONE flag that can result in use after
free.

PR: 218597

Test Plan
  • cryptocheck and cryptotest.py against cryptosoft0, ccr0, and aesni0.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

kib added inline comments.
sys/opencrypto/cryptodev.c
1094 ↗(On Diff #38021)

What is the purpose of this locking ?

This revision is now accepted and ready to land.Jan 17 2018, 9:29 AM
sys/opencrypto/cryptodev.c
1094 ↗(On Diff #38021)

Just to avoid losing wakeups() with the loop at line 1050.

This revision was automatically updated to reflect the committed changes.