On Thu, Jun 02, 2016 at 12:28:05PM +0300, Max Gurtovoy wrote: > ib_device_cap_flags 64-bit expansion caused caps overlapping > and made consumers read wrong device capabilities. For example > IB_DEVICE_SG_GAPS_REG was falsely read by the iser driver causing > it to use a non-existing capability. This happened because signed > int becomes sign extended when converted it to u64. Fix this by > casting IB_DEVICE_ON_DEMAND_PAGING enumeration to ULL. > > Fixes: fb532d6a79b9 ('IB/{core, ulp} Support above 32 possible device capability flags') Everything fine, except this Fixes line, which is similar to the issue, but unrelated. The sign extension error was produced after adding bit(32) to the enum and the commit fb532d6a79b9 didn't do it and didn't mean to do it.
Attachment:
signature.asc
Description: Digital signature