{"api_version":"1","generated_at":"2026-05-28T18:49:39+00:00","cve":"CVE-2026-46193","urls":{"html":"https://cve.report/CVE-2026-46193","api":"https://cve.report/api/cve/CVE-2026-46193.json","docs":"https://cve.report/api","cve_org":"https://www.cve.org/CVERecord?id=CVE-2026-46193","nvd":"https://nvd.nist.gov/vuln/detail/CVE-2026-46193"},"summary":{"title":"xfrm: ah: account for ESN high bits in async callbacks","description":"In the Linux kernel, the following vulnerability has been resolved:\n\nxfrm: ah: account for ESN high bits in async callbacks\n\nAH allocates its temporary auth/ICV layout differently when ESN is enabled:\nthe async ahash setup appends a 4-byte seqhi slot before the ICV or\nauth_data area, but the async completion callbacks still reconstruct the\ntemporary layout as if seqhi were absent.\n\nWith an async AH implementation selected, that makes AH copy or compare\nthe wrong bytes on both the IPv4 and IPv6 paths. In UML repro on IPv4 AH\nwith ESN and forced async hmac(sha1), ping fails with 100% packet loss,\nand the callback logs show the pre-fix drift:\n\n  ah4 output_done: esn=1 err=0 icv_off=20 expected_off=24\n  ah4 input_done: esn=1 auth_off=20 expected_auth_off=24 icv_off=32 expected_icv_off=36\n\nReconstruct the callback-side layout the same way the setup path built it\nby skipping the ESN seqhi slot before locating the saved auth_data or ICV.\nPer RFC 4302, the ESN high-order 32 bits participate in the AH ICV\ncomputation, so the async callbacks must account for the seqhi slot.\n\nPost-fix, the same IPv4 AH+ESN+forced-async-hmac(sha1) UML repro shows\nthe corrected offset (ah4 output_done: esn=1 err=0 icv_off=24\nexpected_off=24) and ping succeeds; net/ipv4/ah4.o and net/ipv6/ah6.o\nbuild clean at W=1. IPv6 AH+ESN was not exercised at runtime, and the\nchange has not been tested against a real async hardware AH engine.","state":"PUBLISHED","assigner":"Linux","published_at":"2026-05-28 10:16:34","updated_at":"2026-05-28 13:44:01"},"problem_types":[],"metrics":[],"references":[{"url":"https://git.kernel.org/stable/c/729899a2aa8bda7844be0cdcd3b470f11b912eda","name":"https://git.kernel.org/stable/c/729899a2aa8bda7844be0cdcd3b470f11b912eda","refsource":"416baaa9-dc9f-4396-8d5f-8c081fb06d67","tags":[],"title":"","mime":"","httpstatus":"","archivestatus":"0"},{"url":"https://git.kernel.org/stable/c/ec54093e6a8f87e800bb6aa15eb7fc1e33faa524","name":"https://git.kernel.org/stable/c/ec54093e6a8f87e800bb6aa15eb7fc1e33faa524","refsource":"416baaa9-dc9f-4396-8d5f-8c081fb06d67","tags":[],"title":"","mime":"","httpstatus":"","archivestatus":"0"},{"url":"https://git.kernel.org/stable/c/2ffaa7a94f9a4d22724364a1821735a0231d9f8d","name":"https://git.kernel.org/stable/c/2ffaa7a94f9a4d22724364a1821735a0231d9f8d","refsource":"416baaa9-dc9f-4396-8d5f-8c081fb06d67","tags":[],"title":"","mime":"","httpstatus":"","archivestatus":"0"},{"url":"https://git.kernel.org/stable/c/0555d4f526232b3c9e3afbcd490c0c0793aefec6","name":"https://git.kernel.org/stable/c/0555d4f526232b3c9e3afbcd490c0c0793aefec6","refsource":"416baaa9-dc9f-4396-8d5f-8c081fb06d67","tags":[],"title":"","mime":"","httpstatus":"","archivestatus":"0"},{"url":"https://git.kernel.org/stable/c/7db99a09b3bc87268287bc7ab5f2e7f382b5ad87","name":"https://git.kernel.org/stable/c/7db99a09b3bc87268287bc7ab5f2e7f382b5ad87","refsource":"416baaa9-dc9f-4396-8d5f-8c081fb06d67","tags":[],"title":"","mime":"","httpstatus":"","archivestatus":"0"},{"url":"https://www.cve.org/CVERecord?id=CVE-2026-46193","name":"CVE Program record","refsource":"CVE.ORG","tags":["canonical"]},{"url":"https://nvd.nist.gov/vuln/detail/CVE-2026-46193","name":"NVD vulnerability detail","refsource":"NVD","tags":["canonical","analysis"]}],"affected":[{"source":"CNA","vendor":"Linux","product":"Linux","version":"affected d4d573d0334d07341beffdcf97e2b85d3955d8ae 0555d4f526232b3c9e3afbcd490c0c0793aefec6 git","platforms":[]},{"source":"CNA","vendor":"Linux","product":"Linux","version":"affected d4d573d0334d07341beffdcf97e2b85d3955d8ae 729899a2aa8bda7844be0cdcd3b470f11b912eda git","platforms":[]},{"source":"CNA","vendor":"Linux","product":"Linux","version":"affected d4d573d0334d07341beffdcf97e2b85d3955d8ae 7db99a09b3bc87268287bc7ab5f2e7f382b5ad87 git","platforms":[]},{"source":"CNA","vendor":"Linux","product":"Linux","version":"affected d4d573d0334d07341beffdcf97e2b85d3955d8ae 2ffaa7a94f9a4d22724364a1821735a0231d9f8d git","platforms":[]},{"source":"CNA","vendor":"Linux","product":"Linux","version":"affected d4d573d0334d07341beffdcf97e2b85d3955d8ae ec54093e6a8f87e800bb6aa15eb7fc1e33faa524 git","platforms":[]},{"source":"CNA","vendor":"Linux","product":"Linux","version":"affected 3.15","platforms":[]},{"source":"CNA","vendor":"Linux","product":"Linux","version":"unaffected 3.15 semver","platforms":[]},{"source":"CNA","vendor":"Linux","product":"Linux","version":"unaffected 6.6.140 6.6.* semver","platforms":[]},{"source":"CNA","vendor":"Linux","product":"Linux","version":"unaffected 6.12.88 6.12.* semver","platforms":[]},{"source":"CNA","vendor":"Linux","product":"Linux","version":"unaffected 6.18.30 6.18.* semver","platforms":[]},{"source":"CNA","vendor":"Linux","product":"Linux","version":"unaffected 7.0.7 7.0.* semver","platforms":[]},{"source":"CNA","vendor":"Linux","product":"Linux","version":"unaffected 7.1-rc3 * original_commit_for_fix","platforms":[]}],"timeline":[],"solutions":[],"workarounds":[],"exploits":[],"credits":[],"nvd_cpes":[],"vendor_comments":[],"enrichments":{"kev":null,"epss":null,"legacy_qids":[]},"source_records":{"cve_program":{"containers":{"cna":{"affected":[{"defaultStatus":"unaffected","product":"Linux","programFiles":["net/ipv4/ah4.c","net/ipv6/ah6.c"],"repo":"https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git","vendor":"Linux","versions":[{"lessThan":"0555d4f526232b3c9e3afbcd490c0c0793aefec6","status":"affected","version":"d4d573d0334d07341beffdcf97e2b85d3955d8ae","versionType":"git"},{"lessThan":"729899a2aa8bda7844be0cdcd3b470f11b912eda","status":"affected","version":"d4d573d0334d07341beffdcf97e2b85d3955d8ae","versionType":"git"},{"lessThan":"7db99a09b3bc87268287bc7ab5f2e7f382b5ad87","status":"affected","version":"d4d573d0334d07341beffdcf97e2b85d3955d8ae","versionType":"git"},{"lessThan":"2ffaa7a94f9a4d22724364a1821735a0231d9f8d","status":"affected","version":"d4d573d0334d07341beffdcf97e2b85d3955d8ae","versionType":"git"},{"lessThan":"ec54093e6a8f87e800bb6aa15eb7fc1e33faa524","status":"affected","version":"d4d573d0334d07341beffdcf97e2b85d3955d8ae","versionType":"git"}]},{"defaultStatus":"affected","product":"Linux","programFiles":["net/ipv4/ah4.c","net/ipv6/ah6.c"],"repo":"https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git","vendor":"Linux","versions":[{"status":"affected","version":"3.15"},{"lessThan":"3.15","status":"unaffected","version":"0","versionType":"semver"},{"lessThanOrEqual":"6.6.*","status":"unaffected","version":"6.6.140","versionType":"semver"},{"lessThanOrEqual":"6.12.*","status":"unaffected","version":"6.12.88","versionType":"semver"},{"lessThanOrEqual":"6.18.*","status":"unaffected","version":"6.18.30","versionType":"semver"},{"lessThanOrEqual":"7.0.*","status":"unaffected","version":"7.0.7","versionType":"semver"},{"lessThanOrEqual":"*","status":"unaffected","version":"7.1-rc3","versionType":"original_commit_for_fix"}]}],"cpeApplicability":[{"nodes":[{"cpeMatch":[{"criteria":"cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*","versionEndExcluding":"6.6.140","versionStartIncluding":"3.15","vulnerable":true},{"criteria":"cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*","versionEndExcluding":"6.12.88","versionStartIncluding":"3.15","vulnerable":true},{"criteria":"cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*","versionEndExcluding":"6.18.30","versionStartIncluding":"3.15","vulnerable":true},{"criteria":"cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*","versionEndExcluding":"7.0.7","versionStartIncluding":"3.15","vulnerable":true},{"criteria":"cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*","versionEndExcluding":"7.1-rc3","versionStartIncluding":"3.15","vulnerable":true}],"negate":false,"operator":"OR"}]}],"descriptions":[{"lang":"en","value":"In the Linux kernel, the following vulnerability has been resolved:\n\nxfrm: ah: account for ESN high bits in async callbacks\n\nAH allocates its temporary auth/ICV layout differently when ESN is enabled:\nthe async ahash setup appends a 4-byte seqhi slot before the ICV or\nauth_data area, but the async completion callbacks still reconstruct the\ntemporary layout as if seqhi were absent.\n\nWith an async AH implementation selected, that makes AH copy or compare\nthe wrong bytes on both the IPv4 and IPv6 paths. In UML repro on IPv4 AH\nwith ESN and forced async hmac(sha1), ping fails with 100% packet loss,\nand the callback logs show the pre-fix drift:\n\n  ah4 output_done: esn=1 err=0 icv_off=20 expected_off=24\n  ah4 input_done: esn=1 auth_off=20 expected_auth_off=24 icv_off=32 expected_icv_off=36\n\nReconstruct the callback-side layout the same way the setup path built it\nby skipping the ESN seqhi slot before locating the saved auth_data or ICV.\nPer RFC 4302, the ESN high-order 32 bits participate in the AH ICV\ncomputation, so the async callbacks must account for the seqhi slot.\n\nPost-fix, the same IPv4 AH+ESN+forced-async-hmac(sha1) UML repro shows\nthe corrected offset (ah4 output_done: esn=1 err=0 icv_off=24\nexpected_off=24) and ping succeeds; net/ipv4/ah4.o and net/ipv6/ah6.o\nbuild clean at W=1. IPv6 AH+ESN was not exercised at runtime, and the\nchange has not been tested against a real async hardware AH engine."}],"providerMetadata":{"dateUpdated":"2026-05-28T09:36:46.611Z","orgId":"416baaa9-dc9f-4396-8d5f-8c081fb06d67","shortName":"Linux"},"references":[{"url":"https://git.kernel.org/stable/c/0555d4f526232b3c9e3afbcd490c0c0793aefec6"},{"url":"https://git.kernel.org/stable/c/729899a2aa8bda7844be0cdcd3b470f11b912eda"},{"url":"https://git.kernel.org/stable/c/7db99a09b3bc87268287bc7ab5f2e7f382b5ad87"},{"url":"https://git.kernel.org/stable/c/2ffaa7a94f9a4d22724364a1821735a0231d9f8d"},{"url":"https://git.kernel.org/stable/c/ec54093e6a8f87e800bb6aa15eb7fc1e33faa524"}],"title":"xfrm: ah: account for ESN high bits in async callbacks","x_generator":{"engine":"bippy-1.2.0"}}},"cveMetadata":{"assignerOrgId":"416baaa9-dc9f-4396-8d5f-8c081fb06d67","assignerShortName":"Linux","cveId":"CVE-2026-46193","datePublished":"2026-05-28T09:36:46.611Z","dateReserved":"2026-05-13T15:03:33.104Z","dateUpdated":"2026-05-28T09:36:46.611Z","state":"PUBLISHED"},"dataType":"CVE_RECORD","dataVersion":"5.2"},"nvd":{"publishedDate":"2026-05-28 10:16:34","lastModifiedDate":"2026-05-28 13:44:01","problem_types":[],"metrics":[],"configurations":[]},"legacy_mitre":{"record":{"CveYear":"2026","CveId":"46193","Ordinal":"1","Title":"xfrm: ah: account for ESN high bits in async callbacks","CVE":"CVE-2026-46193","Year":"2026"},"notes":[{"CveYear":"2026","CveId":"46193","Ordinal":"1","NoteData":"In the Linux kernel, the following vulnerability has been resolved:\n\nxfrm: ah: account for ESN high bits in async callbacks\n\nAH allocates its temporary auth/ICV layout differently when ESN is enabled:\nthe async ahash setup appends a 4-byte seqhi slot before the ICV or\nauth_data area, but the async completion callbacks still reconstruct the\ntemporary layout as if seqhi were absent.\n\nWith an async AH implementation selected, that makes AH copy or compare\nthe wrong bytes on both the IPv4 and IPv6 paths. In UML repro on IPv4 AH\nwith ESN and forced async hmac(sha1), ping fails with 100% packet loss,\nand the callback logs show the pre-fix drift:\n\n  ah4 output_done: esn=1 err=0 icv_off=20 expected_off=24\n  ah4 input_done: esn=1 auth_off=20 expected_auth_off=24 icv_off=32 expected_icv_off=36\n\nReconstruct the callback-side layout the same way the setup path built it\nby skipping the ESN seqhi slot before locating the saved auth_data or ICV.\nPer RFC 4302, the ESN high-order 32 bits participate in the AH ICV\ncomputation, so the async callbacks must account for the seqhi slot.\n\nPost-fix, the same IPv4 AH+ESN+forced-async-hmac(sha1) UML repro shows\nthe corrected offset (ah4 output_done: esn=1 err=0 icv_off=24\nexpected_off=24) and ping succeeds; net/ipv4/ah4.o and net/ipv6/ah6.o\nbuild clean at W=1. IPv6 AH+ESN was not exercised at runtime, and the\nchange has not been tested against a real async hardware AH engine.","Type":"Description","Title":"xfrm: ah: account for ESN high bits in async callbacks"}]}}}