Page MenuHomeFreeBSD

Fix ISP_FC_LIP and ISP_RESCAN on big-endian 64-bit systems.
ClosedPublic

Authored by brooks on Mar 12 2018, 9:25 PM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Oct 24, 7:28 PM
Unknown Object (File)
Tue, Oct 21, 8:54 AM
Unknown Object (File)
Mon, Oct 20, 10:48 AM
Unknown Object (File)
Mon, Oct 20, 10:48 AM
Unknown Object (File)
Mon, Oct 20, 1:01 AM
Unknown Object (File)
Sun, Oct 19, 8:22 PM
Unknown Object (File)
Thu, Oct 9, 12:27 PM
Unknown Object (File)
Wed, Oct 1, 11:53 PM
Subscribers

Details

Summary

For _IO() ioctls, addr is a pointer to uap->data which is a caddr_t.
When the caddr_t stores an int, dereferencing addr as an (int *) results
in truncation on little-endian 64-bit systems and corruption (owing to
extracting top bits) on big-endian 64-bit systems. In practice the
value of chan was probably always zero on systems of the latter type.

Diff Detail

Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 15528
Build 15569: arc lint + arc unit

Event Timeline

It makes some sense to me, but I suspect that this code is generally dead, since I don't know any user-space tool using it. Ken, do you?

This revision is now accepted and ready to land.Mar 12 2018, 9:46 PM
brooks retitled this revision from Fix ISP_FC_LIP and ISP_RESCAN on big-endian 64-bit systemss to Fix ISP_FC_LIP and ISP_RESCAN on big-endian 64-bit systems..Mar 12 2018, 11:05 PM
This revision was automatically updated to reflect the committed changes.