On Tue, Dec 17, 2013 at 10:17:24AM -0800, Keith Packard wrote: > Chris Wilson <chris@xxxxxxxxxxxxxxxxxx> writes: > > > The bspec still says we must assert SR01 bit5 prior to disabling the VGA > > plane. > > > > Perhaps the test should be whether (vga_reg & VGA_DISP_DISABLE) == 0 and > > do nothing if the plane is already off. > > The problem is that for some reason we're smashing *some other video > card* when it's being used via efifb. Ok, so as no vgaarb_clients have yet been registered and so the call to grab the IO resource does not actually disable VGA IO routing to the nvidia card. > I'm wondering if vgaarb just doesn't work because efifb isn't telling > vgaarb that it's using those registers (I mean, how would it even know?) Agreed, that does seem to be the nub of the problem. > The other simple option is to just not disable VGA if the card isn't > primary; presumably it wasn't ever enabled. > > And, yes, I know that the card probably won't work at all if it isn't > primary because so much currently depends on the BIOS setting up bits of > the card that we can't autodetect. So, another simple option would be to > just refuse to load the driver if the card is secondary... If you care to update the changelog to explain the problem is that vgaarb is ineffective before all clients are registered, then I think this is a good temporary hack. It should be possible for vgaarb to mark resources as locked if the device is interpretting IO access and has no method for disabling the IO grab (and then a vga_tryget() check here). -Chris -- Chris Wilson, Intel Open Source Technology Centre _______________________________________________ Intel-gfx mailing list Intel-gfx@xxxxxxxxxxxxxxxxxxxxx http://lists.freedesktop.org/mailman/listinfo/intel-gfx