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, Oct 20, 6:11 AM
Unknown Object (File)
Mon, Oct 20, 6:11 AM
Unknown Object (File)
Mon, Oct 20, 6:11 AM
Unknown Object (File)
Sun, Oct 19, 3:31 PM
Unknown Object (File)
Tue, Sep 30, 7:07 AM
Unknown Object (File)
Sep 21 2025, 5:13 PM
Unknown Object (File)
Sep 19 2025, 8:09 AM
Unknown Object (File)
Sep 2 2025, 12:15 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.