Hacker Read top | best | new | newcomments | leaders | about | bookmarklet login

Actually it might be, Zink just got OpenGL 3.0 support.

Zink is an OpenGL Implementation on top of Vulkan and that might actually be a good way to do full OpenGL on these devices.



sort by: page size:

Zink requires a fairly advanced Vulkan driver, with many complex optional extensions. A basic Vulkan driver wouldn't cut it. So getting basic OpenGL working is much less work, especially since they can share a lot of work with Mesa's existing OpenGL drivers.

How big of a deal would proper native OpenGL support actually be? My understanding is that OpenGL is more or less deprecated, and any performance heavy graphics applications have long since switched to Vulkan. I would think the performance overhead of a translation layer like Zink would go largely unnoticed when running software old enough to need it on a modern GPU.

That's something of a sweeping generalization. Zink has managed to beat a native OpenGL driver in some particular benchmarks.

In many other benchmarks, it loses. That being said, it still manages decent performance, which is extremely impressive for a one man project using only the Vulkan interface. It wouldn't surprise me if it eventually becomes the default OpenGL driver in the open source driver stack (for HW capable enough to support a Vulkan driver, obviously).


Now Zink (GL over Vulkan) runs faster than OpenGL itself on supported platforms.

> OpenGL ES 3.1 or Vulkan 1.2.

Weird that it doesn't have the full OpenGL, even if it was through Zink.


I think there is already an OpenGL implementation over Nouveau (4.5 level)? So that can exists as is, or Zink can be an option. And remaining 4.6 parts are Vulkan related, so may be it can reach 4.6 without Zink too now.

mesa3d also has Zink, which implements opengl, opencl and gles on top of vulkan.

OpenGL ES is boring though. I want to know how well does desktop OpenGL on Zink on Vulkan runs.

I'm pretty confident that the original commit meant 1000% compared to the previous Zink performance - not that it's 1000% better than current OpenGL implementations.

That said I certainly hope Zink becomes a suitable OpenGL implementation since it would simplify development of open source video drivers. i.e. just implement vulkan and you get OpenGL for free.


Not necessarily, especially when you factor in limited (human) resources in.

Zink has outperformed native GL drivers even though it introduces an extra layer through vulkan.

Ideal world, we'd have direct GL to metal or hardware, but implementing a GL driver is a big effort.


Only OpenGL ES is disappointing. ARM's Mali Panfrost drivers get full desktop OpenGL, so do Snapdragon GPUs. Hopefully they implement enough of Vulkan for Zink.

It won't be OpenGL-like, it will probably just be OpenGL https://docs.mesa3d.org/drivers/zink.html

There already exists an opengl-to-vulcan shim driver (zink) that is better than most opengl platform drivers.

They can also take advantage of zink to implement opengl, at least on platforms that support mesa; and use wine's implementations of direct3d.

I expect that, in the future, gl and d3d will be implemented entirely on top of vulkan, and thus be more portable and make it easier to make GPUs and graphics drivers.


Thanks for sharing Zink, this gives me hope for OpenGL's future.

OpenGL is deprecated on MacOS only. It remains fully relevant on many platforms, else OpenGL 4.6 would have never happened. Existing heavily optimized legacy applications (especially games) are unlikely to ever switch to Vulkan if no clear advantages can be demonstrated.

Zink is very useful and maybe the best option if existing drivers are buggy or not that performant. But the performance impact is usually very apparent.


I suspect that, by now, the only reason the other mesa3d opengl drivers exist is historical.

If these vendors came up with different enough hardware to need a new driver from scratch, they'd just focus on Vulkan and use Zink for opengl.

After all, opengl is a relatively high level API. It is sensible to implement it in a hardware-independent manner on top of Vulkan.


I know OpenGL is still used, but it's not used much for performance intensive applications like AAA video games, it's used for things like desktop compositors, largely because the spec hasn't been improved or changed since 2014.

Maybe Zink is uniquely inefficient, but my frame of reference for how fast these translation layers can be is DXVK, which in some cases is even faster than native when translating DX11 to Vulkan.


OpenGL is huge. It's probably a better idea to use the shared code in Mesa and write a Gallium to Metal driver. That's how Zink (GL on Vulkan) and Microsofts GLonD3D12 work.
next

Legal | privacy