-
Notifications
You must be signed in to change notification settings - Fork 109
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add an EGLDevice type attribute #206
Comments
@cubanismo - add James for his interest in EGLDevice. |
Gentle ping @cubanismo |
I don't have much to add. There's some debate around the Vulkan equivalent over how much apps should be reading into device type, especially for the "virtual" one (E.g., is a "virtual" GPU necessarily slower? E.g., is a non-virtual iGPU faster than a virtual dGPU? Is a pass-through PCI device considered a "virtual" GPU?), but it's there and this probably isn't going to be any worse. If you want to make it an EXT, I'm happy to sign on from the NV side. |
If you believe "virtual" should be omitted, I'd be happy to leave it out. Thanks for the feedback! |
Question: Is software vs hardware vs virtual the key? or are you trying to compare performance, to select the most performant option? |
Personally I'm only interested in checking whether it's a software implementation. I'm writing Wayland compositors, so the whole desktop will be super sluggish if a software implementation is used (e.g. because the driver doesn't support new hardware, or because the user forgot to install the correct driver). I want users to opt-in to software rendering if they really want to use that, since that'll almost always indicate something wrong. I've received a number of bug reports about confused users not understanding why everything is so slow, or why their battery dry up so quickly. |
There could be a number of things useful - local host CPU, would impact CPU use - verses a discrete GPU, maybe GPU flops metric would indicate a certain level of performance - to compare more than one device option. Just looking for what is most informative/useful for the need. The VkPhysicalDeviceType covers a lot of this, but if you have 2 GPUs, could you select the more performant? (integrated vs discrete). Is this similar to VkPhysicalDeviceType - enough? Makes it easy if Vulkan is your backend. |
I already have a GPU selected before-hand. I'm creating one EGL context per DRM device node. I'm just interested to know whether the EGL device matching my DRM device is backed by a real hardware driver instead of a software renderer. I'm not interested in knowing which GPU is "most performant" for my use-case. |
Vulkan has
VkPhysicalDeviceType
which indicates what kind of device theVkPhysicalDevice
is. It would be useful to add something similar toEGLDevice
. (I personally need to figure out whether it's a software-based renderer, and check forEGL_MESA_device_software
for now.)The text was updated successfully, but these errors were encountered: