]> git.baikalelectronics.ru Git - kernel.git/commit
xen-pciback: return proper values during BAR sizing
authorJan Beulich <JBeulich@suse.com>
Fri, 24 Jun 2016 09:13:34 +0000 (03:13 -0600)
committerDavid Vrabel <david.vrabel@citrix.com>
Fri, 24 Jun 2016 09:53:03 +0000 (10:53 +0100)
commit774ef3af53c9a8d34b4fc84efbe6ea3af75a05d4
tree49b0a103f90f6d553a7bc69d5177f0784bda68e2
parent306675e88575cbfce1b6e8263268b97c9338c12a
xen-pciback: return proper values during BAR sizing

Reads following writes with all address bits set to 1 should return all
changeable address bits as one, not the BAR size (nor, as was the case
for the upper half of 64-bit BARs, the high half of the region's end
address). Presumably this didn't cause any problems so far because
consumers use the value to calculate the size (usually via val & -val),
and do nothing else with it.

But also consider the exception here: Unimplemented BARs should always
return all zeroes.

And finally, the check for whether to return the sizing address on read
for the ROM BAR should ignore all non-address bits, not just the ROM
Enable one.

Signed-off-by: Jan Beulich <jbeulich@suse.com>
Reviewed-by: Boris Ostrovsky <boris.ostrovsky@oracle.com>
Signed-off-by: David Vrabel <david.vrabel@citrix.com>
drivers/xen/xen-pciback/conf_space_header.c