-
Notifications
You must be signed in to change notification settings - Fork 86
Vulkan rendering backend #253
Comments
I just want to mention that there's also webgpu (spec draft: https://gpuweb.github.io/gpuweb/, implementation: https://github.com/gfx-rs/wgpu-native), which despite of its name can also be used out of the web.
|
No way in the foreseeable future. It’d be enormous work for dubious gain. |
Some work already have been done to give a Vulkan backend to upstream irrlicht: https://irrlicht.sourceforge.io/forum/viewtopic.php?t=52371 IrrlichtBAW (now Nabla) have a Vulkan backend: https://github.com/Devsh-Graphics-Programming/Nabla Maybe nobody have the time right now to try building a Vulkan backend, but Vulkan is the successor of OpenGL, with reworked concepts for 25y of GPU evolutions. Many serious game / game engines support or moved entirely to Vulkan: 0AD have an experimental Vulkan backend, Godot, Unreal Engine enable Vulkan by defaut, Source 2 based games uses Vulkan under Linux, all windows games running with Proton use Vulkan, etc. Vulkan is definitely something to think about for the future. |
You must be new here. Minetest uses OpenGL 2.0. And OpenGL ES 1 (though OpenGL ES 2 is supported too). Go change that. |
Minetest is based on a fork of irrlicht, so if other irrlicht forks have actually a vulkan backend it definitly seems possible. OpenGL 2.0 released in 2004 which was a looong time ago (wasn't even born btw). |
I didn’t say “impossible.” I said “not in the foreseeable future.” It’s a different thing entirely. Some years later it might become viable—or not. Maybe by the time Vulkan will be superseded with something else.
Yes. And you ask to jump from that to Vulkan. It’s like jumping from a horse to a jet. Besides, this wouldn’t buy us anything. Okay, maybe a bit better compatibility with these new shiny devices. But, even supporting non-generic shaders would require adding an entirely different codepath to Minetest, in a place which is rather hairy already (did I mention Irrlicht is built around the fixed-function pipeline [that doesn’t even exist in Vulkan, or in GL 3+ Core for that matter], with shaders bolted on?). Each non-trivial feature would require such ugly hacks. Instead, my plan is to keep OpenGL but via a single backend (there are several currently, separate “drivers” for OpenGL, OpenGL ES, OpenGL ES 2, and my new backend that supports both GL 3+ compat. and GL ES 2+), and make the API saner. Incidentally, that would make transition to Vulkan easier but that’s definitely not a goal. |
WebGPU (@Desour suggestion) can be also be considered a good candidate. Minetest for the web would be really nice.
Yes, but then we have to move forward in smaller steps
It's nice to see improvement to the OpenGL rendering system, but honestly the benefits of Vulcan are more than supporting shiny new devices. Vulcan have been around since almost the beginning of Minetest. Plus things like better VRR support are really great for Linux gaming. That's even older 😬 |
Like Minetest for the Web? (works on WebGL)
I didn’t mean there are no benefits. I meant Minetest wouldn’t be able to use them. But, if you think I overestimate the complexity of adding Vulkan support show it me. Implement it. In Minetest, not some random example. |
I am aware of this one, but last time I tried it was much slower than the desktop version, which make sense considering the architecture of WebGL. WebGPU official benchmarks shows 2x FPS difference with WebGL. Also I would like it to be an official version.
Minetest would definitely benefit from better VRR support and better handling of modern hardware. I am not speaking of RT API or anything like that.
Vulkan have a different API from OpenGL, I know that. And if I eventually get the time to learn OpenGL, Vulkan and C++, I will definitely try to. |
Good luck. You’ll need it. |
One very interesting stuff Vulkan could unlock is mesh shaders. It could allow for massive performance boost on modern GPUs.
These is a similar OpenGL 4 extension, but it's NVIDIA only. There is a Minecraft Java mod which uses the OpenGL extension, notably for terrain rasterization which gives massive performance boost for modern NVIDIA GPUs.
Mesh shaders are also planned for WebGPU. |
Performance-wise, there are other priorities (such as doing skinning on the GPU, or batching particles, which are both much less work) for optimizing Minetest's rendering than this neat feature which requires significant upfront investment and would have gains limited to modern devices. |
I also found this repository Irrlicht with Vulkan |
Currently Minetest only support OpenGL and OpenGL ES.
These are many things Minetest would benefits from a Vulkan rendering backend:
Links:
The text was updated successfully, but these errors were encountered: