[PATCH v9 8/9] fbcon: Use screen info to find primary device
Mario Limonciello
superm1 at kernel.org
Tue Jul 22 15:39:08 UTC 2025
On 7/22/25 10:33 AM, Bjorn Helgaas wrote:
> On Tue, Jul 22, 2025 at 09:45:28AM -0500, Mario Limonciello wrote:
>> On 7/22/25 9:38 AM, Bjorn Helgaas wrote:
>>> On Thu, Jul 17, 2025 at 12:38:11PM -0500, Mario Limonciello wrote:
>>>> From: Mario Limonciello <mario.limonciello at amd.com>
>>>>
>>>> On systems with non VGA GPUs fbcon can't find the primary GPU because
>>>> video_is_primary_device() only checks the VGA arbiter.
>>>>
>>>> Add a screen info check to video_is_primary_device() so that callers
>>>> can get accurate data on such systems.
>>>
>>> This relies on screen_info, which I think is an x86 BIOS-ism. Isn't
>>> there a UEFI console path? How does that compare with this? Is that
>>> relevant or is it something completely different?
>>
>> When I created and tested this I actually did this on a UEFI system (which
>> provides a UEFI GOP driver).
>
> I guess screen_info is actually *not* an x86 BIOS-ism, and on UEFI
> systems, we do actually rely on UEFI, e.g., in efi_setup_gop(),
> alloc_screen_info(), init_screen_info()?
Right. This all works because of the framebuffer allocated pre-boot and
reused by the kernel.
>
> But this patch is x86-specific, so I'm guessing the same problem could
> occur on arm64, Loongson, or other UEFI platforms, and this series
> doesn't address those?
I've never seen a multi GPU solution on another architecture, but that
of course doesn't preclude one being created some day.
The series lays the groundwork that if it happens on another
architecture we can easily add an architecture specific solution for
those. If the solution is the same we could switch to a common helper.
>
>>>> bool video_is_primary_device(struct device *dev)
>>>> {
>>>> +#ifdef CONFIG_SCREEN_INFO
>>>> + struct screen_info *si = &screen_info;
>>>> +#endif
>>>> struct pci_dev *pdev;
>>>> if (!dev_is_pci(dev))
>>>> @@ -34,7 +38,18 @@ bool video_is_primary_device(struct device *dev)
>>>> pdev = to_pci_dev(dev);
>>>> - return (pdev == vga_default_device());
>>>> + if (!pci_is_display(pdev))
>>>> + return false;
>>>> +
>>>> + if (pdev == vga_default_device())
>>>> + return true;
>>>> +
>>>> +#ifdef CONFIG_SCREEN_INFO
>>>> + if (pdev == screen_info_pci_dev(si))
>>>> + return true;
>>>> +#endif
>>>> +
>>>> + return false;
>>>> }
>>>> EXPORT_SYMBOL(video_is_primary_device);
>>>> --
>>>> 2.43.0
>>>>
>>
More information about the dri-devel
mailing list