Every article tag can be clicked to get a list of all articles in that category. Every article tag also has an RSS feed! You can customize an RSS feed too!
We do often include affiliate links to earn us some pennies. See more here.
tagline-image
The awesome GameCube and Wii emulator Dolphin has officially dropped support for the D3D12 API in favour of going all-in with Vulkan.

In their progress report posted yesterday they detailed their reasoning. It mainly boils down to the fact that their Vulkan renderer was performing just as good as DirectX 12:
QuoteGoing forward, we're going to continue to optimize the existing graphics backends. In our testing, the Vulkan backend was as fast as, or nearly as fast as the D3D12 backend in every benchmark. While different drivers and graphics cards will not all perform identically, we're confident that moving forward the Vulkan backend will be able to handle the burden of users seeking the benefits of the newer graphics APIs.


This makes me happy to read, since it's another win for Vulkan, which is going to be pretty damn important for the future of Linux gaming as a whole.

I don't really use emulators myself, but I consider them really important since eventually old systems just vanish. I personally see no problem using them, especially if you own the games and the system already. Article taken from GamingOnLinux.com.
Tags: Emulation, Vulkan
28 Likes
About the author -
author picture
I am the owner of GamingOnLinux. After discovering Linux back in the days of Mandrake in 2003, I constantly checked on the progress of Linux until Ubuntu appeared on the scene and it helped me to really love it. You can reach me easily by emailing GamingOnLinux directly. You can also follow my personal adventures on Bluesky.
See more from me
The comments on this article are closed.
All posts need to follow our rules. For users logged in: please hit the Report Flag icon on any post that breaks the rules or contains illegal / harmful content. Guest readers can email us for any issues.
19 comments Subscribe

MaCroX95 4 Jun 2017
This is yet another Win for Vulkan over DX12, it's small wins like this we need, more vulkan usage amongst developers = more games on Vulkan which will make majority of new games playable, if not natively through wine with equal performances to Windows :)

Great news!
razing32 4 Jun 2017
![](http://volkerdeuss.com/wp-content/uploads/2016/03/good-news-everyone.jpg)
GustyGhost 4 Jun 2017
If you're the kind to see the thumbnail before reading the title, this post had very a different inference at quick glance.
natewardawg 4 Jun 2017
If you're the kind to see the thumbnail before reading the title, this post had very a different inference at quick glance.

Agreed, it looks like link is "dropping" Vulkan :D

With that said, dropping D3D12 (rather, not adopting it in the first place) makes a lot of sense for pretty much any multi-platform, but single purpose, engine.


Last edited by natewardawg on 4 Jun 2017 at 8:27 pm UTC
lucinos 4 Jun 2017
Unlike the D3D12 backend, the Vulkan backend is actively maintained and does not have the design flaws that made D3D12 harder to work with.

From the dolphin link progress report this sentence looks even more "interesting" than the one you quoted.


Last edited by lucinos on 4 Jun 2017 at 9:19 pm UTC
edo 4 Jun 2017
It all comes down to a simple situation: the guy that ported dx12 vanished and didn't keep supporting it. If he were still around giving dx12 support the situation would be different. It was nice that this emulator provided support for both APIs
lucinos 4 Jun 2017
It all comes down to a simple situation: the guy that ported dx12 vanished and didn't keep supporting it. If he were still around giving dx12 support the situation would be different. It was nice that this emulator provided support for both APIs

from reading more of their reports it looks more complicated and more in favor of Vulkan! Also supporting d3d12 leaving aside the double effort and more manpower is not good for compiling times as they say.

An other quote from the November report

5.0-1241 - Vulkan Cleanup and XFB Support by stenzek

While it was originally planned to wait for Hybrid XFB to wire up Vulkan to the eXternal FrameBuffer, it turns out that feature is taking quite a bit longer than anticipated. Thus, in his latest block of cleanups, stenzek decided to plug Vulkan into the existing XFB code. It was a relatively simple task, and more or less makes Vulkan feature complete. This means that Vulkan can properly run games that require Virtual or Real XFB, such as Star Wars Rogue Squadron II: Rogue Leader.

In terms of overall quality, the Vulkan backend is shaping up nicely. Unlike D3D12, which is still plagued by a lot of instabilities, Vulkan seems to run well on any of the cards that support it. That said, it's not going to revolutionize Dolphin; its merely a bit faster than the standard D3D11 and OpenGL backends outside of a few rare cases, like The Legend of Zelda: Twilight Princess. While OpenGL remains the most accurate backend, Vulkan brings most of the performance of D3D12 without the instabilities in its current form.

tmtvl 4 Jun 2017
In February a preliminary libretro Dolphin core was released, haven't really been tracking it further, but could be neat.
chimpy 4 Jun 2017
One of the devs posted on phoronix:

"No.

In most cases we found the D3D12 backend to be faster. It was faster because it did some threading tricks that the Vulkan backend currently doesn't do. However, that performance advantage slims significantly on higher end systems.

The D3D12 backend showed the most benefit for Intel iGPU users that could support D3D12, but not Vulkan. This was a lot of users. Intel iGPUs dominate our top GPUs used stat in analytics.

While it's unfortunate, we chose to keep the code base easier to maintain, and dropping D3D12 let us do just that. This was the biggest reason. Due to needing a very specific version of the Win10 SDK, retargeting the project to a new version every time the SDK updated wasn't feasible. As it requires buildbot admin coordination as well. And since we have no idea how microsoft intends to manage the Win10 SDK with VS 2017 which we recently migrated to, if microsoft chooses to constantly update it, that's a huge headache for us.

Additionally, the maintainer of the D3D12 backend pretty much disappeared after getting it merged to master, and due to the questionable quality of the code, none of the regular graphics devs wanted to touch it. It fell out of feature parity and users were frustrated that nobody was fixing anything in that backend."
Liam Dawe 4 Jun 2017
One of the devs posted on phoronix:

"No.

In most cases we found the D3D12 backend to be faster. It was faster because it did some threading tricks that the Vulkan backend currently doesn't do. However, that performance advantage slims significantly on higher end systems.

The D3D12 backend showed the most benefit for Intel iGPU users that could support D3D12, but not Vulkan. This was a lot of users. Intel iGPUs dominate our top GPUs used stat in analytics.

While it's unfortunate, we chose to keep the code base easier to maintain, and dropping D3D12 let us do just that. This was the biggest reason. Due to needing a very specific version of the Win10 SDK, retargeting the project to a new version every time the SDK updated wasn't feasible. As it requires buildbot admin coordination as well. And since we have no idea how microsoft intends to manage the Win10 SDK with VS 2017 which we recently migrated to, if microsoft chooses to constantly update it, that's a huge headache for us.

Additionally, the maintainer of the D3D12 backend pretty much disappeared after getting it merged to master, and due to the questionable quality of the code, none of the regular graphics devs wanted to touch it. It fell out of feature parity and users were frustrated that nobody was fixing anything in that backend."
Odd, since that contradicts what their official update post (as quoted in the article) says.
slaapliedje 4 Jun 2017
Sweet, this should mean the VR branch should gain support for SteamVR+Linux as well.

Metroid in VR was pretty cool, that's the only one I've tested though.
Leopard 4 Jun 2017
That can count as a win but a real winning will be the Sony PlayStation using Vulkan
elmapul 5 Jun 2017
The D3D12 backend showed the most benefit for Intel iGPU users that could support D3D12, but not Vulkan. This was a lot of users. Intel iGPUs dominate our top GPUs used stat in analytics.

a lot of people have iGPU but a lot of people also have an GPU or dont have windows 10
natis1 5 Jun 2017
View PC info
  • Supporter
They deprecated D3D9 in 2013. Now they are killing D3D12.

I have a feeling as their Vulcan pipeline improves D3D11 will go next. Especially since OpenGL seems to outperform it in benchmarks I have seen.
johndoe86x 5 Jun 2017
Somewhat related, in the same announcement they also mentioned the switch from WxWidgets to Qt! (Also, I learned it's pronounced "cute" instead of "que-tee" )


Last edited by johndoe86x on 6 Jun 2017 at 2:11 pm UTC
slaapliedje 6 Jun 2017
Somewhat related, in the same announcement they also mentioned the switch from WxWidgets to Qt! (Also, I learned it's pronounced "cute" instead of "que-tee")

I actually learned it was 'Cute' when following all of the nonsense around Nokia, the N900 -> N9 -> Windows Phone -> End of Nokia as we know it, debacle. For those that weren't paying attention to that, the old Nokia Internet Tablets were all GTK based, but then they bought Trolltech, started making everything on Symbian / MeeGo based on Qt, and then it all went up in smoke... so sad, they had such potential, but jerks were too weak to pull it off, gave up and sold off to MS, which then failed miserably trying to push Windows Phone, which also doesn't support Vulkan :P

It's kind of cool that they switched away from WxWidgets to something more modern, but Qt still seems out of place in a Gnome environment. The opposite usually isn't true though (GTK2/3 in a KDE environment.)

Still, looking forward to a Dolphin-VR port for Linux.
elmapul 6 Jun 2017
Somewhat related, in the same announcement they also mentioned the switch from WxWidgets to Qt! (Also, I learned it's pronounced "cute" instead of "que-tee")

migrating to KDE in 3...2...1!
johndoe86x 6 Jun 2017
Somewhat related, in the same announcement they also mentioned the switch from WxWidgets to Qt! (Also, I learned it's pronounced "cute" instead of "que-tee")

migrating to KDE in 3...2...1!

All the cool kids are doing it.
slaapliedje 20 Jun 2017
The funny thing about using Qt applications in a Gnome environment... they don't react well to HiDPI. So if I do some monitor switching on my laptop, suddenly the Qt application's fonts go mega-huge. I've also noticed that when using restart/power off, they will die instantly, and then you have to tell the system to restart/power off again because the dialog doesn't open. Steam does this as well, though I don't think it's a Qt or GTK based application, not entirely sure what widget it uses, I think it's kind of it's own thing...
While you're here, please consider supporting GamingOnLinux on:

Reward Tiers: Patreon. Plain Donations: PayPal.

This ensures all of our main content remains totally free for everyone! Patreon supporters can also remove all adverts and sponsors! Supporting us helps bring good, fresh content. Without your continued support, we simply could not continue!

You can find even more ways to support us on this dedicated page any time. If you already are, thank you!
The comments on this article are closed.