Page MenuHomeFreeBSD

krb5: Fix handling of transient crypto request failures
ClosedPublic

Authored by markj on May 7 2025, 12:32 PM.
Tags
None
Referenced Files
F133261810: D50238.id155165.diff
Fri, Oct 24, 10:54 AM
F133239109: D50238.diff
Fri, Oct 24, 5:52 AM
Unknown Object (File)
Tue, Oct 14, 4:27 PM
Unknown Object (File)
Sun, Sep 28, 2:32 AM
Unknown Object (File)
Fri, Sep 26, 1:35 PM
Unknown Object (File)
Sep 22 2025, 4:25 PM
Unknown Object (File)
Sep 18 2025, 8:13 PM
Unknown Object (File)
Sep 15 2025, 4:29 PM
Subscribers

Details

Summary
  • Instead of using CRYPTO_F_DONE to decide whether a request has completed, use a custom protocol of setting crp_opaque = NULL in the callback and checking that instead. CRYPTO_F_DONE is set independent of whether an error occurred, but for transient errors signaled by EAGAIN, we want to simply retry the request.
  • Clear CRYPTO_F_DONE before retrying the request.
  • Panic if the request truly failed, as we currently have no way to pass hard errors back up.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable