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)
commitd2bd05d88d245c13b64c3bf9c8927a1c56453d8c
tree49b0a103f90f6d553a7bc69d5177f0784bda68e2
parentd6b186c1e2d852a92c43f090d0d8fad4704d51ef
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