Page MenuHomeFreeBSD

cd9660: Add length checks to Rock Ridge parser
ClosedPublic

Authored by des on Apr 1 2026, 1:26 PM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, Jun 23, 2:05 PM
Unknown Object (File)
Tue, Jun 16, 6:43 AM
Unknown Object (File)
Thu, Jun 11, 12:04 AM
Unknown Object (File)
Sat, Jun 6, 5:24 PM
Unknown Object (File)
Fri, Jun 5, 11:44 PM
Unknown Object (File)
Tue, Jun 2, 11:26 PM
Unknown Object (File)
May 30 2026, 9:12 PM
Unknown Object (File)
May 28 2026, 9:47 PM
Subscribers

Details

Summary
  • cd9660_rrip_slink() did not check that the lengths of individual entries do not exceed the length of the overall record.
  • cd9660_rrip_altname() did not check that the length of the record was at least 5 before subtracting 5 from it.

Note that in both cases, a better solution would be to check the length
of the data before calling the handler, or immediately upon entry of
the handler, but this would require significant refactoring.

MFC after: 1 week
Reported by: Calif.io in collaboration with Claude and Anthropic Research
Reported by: Adam Crosser, Praetorian

Diff Detail

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