Page MenuHomeFreeBSD

Move 32-bit compat support for CDIOREADTOCENTRYS to the right place.
ClosedPublic

Authored by brooks on Oct 1 2018, 6:08 PM.
Tags
None
Referenced Files
F133191793: D17378.diff
Thu, Oct 23, 8:14 PM
Unknown Object (File)
Fri, Oct 17, 1:03 AM
Unknown Object (File)
Thu, Oct 16, 3:22 AM
Unknown Object (File)
Thu, Oct 9, 11:34 PM
Unknown Object (File)
Mon, Sep 29, 2:18 AM
Unknown Object (File)
Wed, Sep 24, 3:08 AM
Unknown Object (File)
Sep 24 2025, 12:40 AM
Unknown Object (File)
Sep 23 2025, 1:51 PM
Subscribers
None

Details

Reviewers
kib
jhb
emaste
Summary

ioctl(2) commands only have meaning in the context of a file descriptor
so translating them in the syscall layer is incorrect.

The new handler users an accessor to retrieve/construct a pointer from
the last member of the passed structure and relies on type punning to
access the other members which require no translation.

Obtained from: CheriBSD
Sponsored by: DARPA, AFRL

Diff Detail

Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 19900
Build 19423: arc lint + arc unit

Event Timeline

This seems to work, but the previous 'sincere' copy is better, IMO.

This revision is now accepted and ready to land.Oct 1 2018, 6:32 PM
sys/cam/scsi/scsi_cd.c
1299

In some ways it'd be nicer if this used the ioctl command itself rather than SV_CURPROC_FLAG to decide this as it's really the ioctl command value that determines the layout of the structure.

  • Pass cmd to te_data_get_ptr and switch on the size rather than SV_ILP32.
This revision now requires review to proceed.Oct 1 2018, 10:07 PM
brooks added inline comments.
sys/cam/scsi/scsi_cd.c
1299

I've alter the code to switch on the size embedded in the command. I'm using the size rather than the command it self because using the command isn't a scalable pattern for structs used by many ioctls.

brooks marked an inline comment as done.
  • Use sizeof(union->struct) consistantly.
This revision is now accepted and ready to land.Oct 2 2018, 4:39 PM