Hi,
I have a card whose VGA registers are not actually reachable, for
multiple reasons:
1. the system in question has multiple PCI domains
2. the system in question does not support IO access
3. one of the bridges involved does not support VGA register forwarding
Obviously, the "works for me" solution would be to teach vgaarb to check
if the VGA bit actually got set in the bridge control register (because
apparently, that is how a bridge indicates missing support), and return
an error. I plan to do that, but that doesn't solve the others.
The specific actual problem I'm trying to solve here is that there is a
workaround in the i915 and xe drivers that pokes the VGA register space
on the same card after changing power states, and this falls over on my
system. Skipping this is safe if we can guarantee that vgacon will not
generate accesses later, so I think having vgaarb recognize that the
card is unreachable and returning an error is sufficient here.
I have no idea whether this will break other systems though -- can we
reasonably assume that any PCI or PCIe bridge that is capable of
forwarding VGA accesses will proudly display the VGA bit set in the
bridge control register, or is a quirk needed here?
For multiple PCI domains, I have no clue how to determine where accesses
end up. My feeling is that it's supposed to be "all of them, mediated by
VGA bits on root bridges", but I don't know if this is actually true. Is
anyone actually building machines with a CPU architecture that has a
separate IO range, and multiple PCI domains?
For "no IO access", it is even more complex -- it appears that the
approach on POWER is to define inb/outb as MMIO, offset from a global
variable that points at a PCI range, which means this access will only
show up in one of the PCI(e) controllers.
What is unclear to me is
1. whether there is supposed to be a mechanism to generate IO accesses
from those,
2. whether this range should be excluded from MMIO to not accidentally
create conflicts
3. whether vgaarb needs to adjust this variable too
4. if this variable should instead be maintained by vgaarb
5. if we should have dedicated vga_inb/vga_outb macros or if we can
assume that any inb/outb on machines that don't have an IO range will be
VGA accesses anyway
6. whether it is interesting to create special handling for cards that
have VGA registers at the beginning of their non-prefetchable MMIO range
(AFAIK, some Intel cards do, and you can address them either via IO or
via MMIO to their non-prefetchable mapping).
7. whether this affects more than two users.
Simon