-
Notifications
You must be signed in to change notification settings - Fork 229
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 hardware accel support under Linux #453
base: master
Are you sure you want to change the base?
Conversation
3ee8f81
to
5496ec4
Compare
5496ec4
to
e3b65ac
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Seems fine overall, i really wish we could pin down the modifier issue on x11 to something in cef's codebase... at least then we could see if it ever got fixed in the future.
Doesnt compile with |
Maybe i'm missing something on how this was tested, but current master sets the BrowserHwaccel option to false so nothing here takes effect until https://github.com/obsproject/obs-studio/blob/master/UI/obs-app.cpp#L1268-L1278 is flipped. |
https://gist.github.com/kkartaltepe/ebf66527a38f188c8b07eb43b2d37de6 I dont remember if this happened as well on my original test months ago. But on my steamdeck tier setup there is significant rendering performance loss so rendering is twice as slow for a scene with 10 browser sources. |
e3b65ac
to
f233a51
Compare
This is why we test, I don't know I would be able to reproduce… |
f233a51
to
535674d
Compare
Changes:
|
Testers have reported that CEF and NVIDIA driver does not seem to work well together.
535674d
to
b957a0a
Compare
Just streamed for six hours with these patches, minus the NVIDIA blacklisting and it solved some framedrops when certain browser overlays would draw to the screen for me. Instead of a blacklist, can it be a warning or something? It worked really well for me. |
/* NOTE: This a workaround under X11 where the modifier is always | ||
invalid where it can mean "no modifier" in Chromium's code. */ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
/* NOTE: This a workaround under X11 where the modifier is always | |
invalid where it can mean "no modifier" in Chromium's code. */ | |
/* NOTE: This a workaround under X11 where the modifier is always invalid where it can mean "no modifier" in | |
* Chromium's code. */ |
}, | ||
}; | ||
|
||
#define N_SUPPORTED_FORMATS (sizeof(supported_formats) / sizeof(supported_formats[0])) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think this can be constexpr?
constexpr size_t N_SUPPORTED_FORMATS = sizeof(supported_formats) / sizeof(supported_formats[0]);
if (drm_formats[i] != supported_formats[j].drm_format) | ||
continue; | ||
|
||
blog(LOG_DEBUG, "[obs-browser] CEF color type %s supported ", supported_formats[j].pretty_name); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
blog(LOG_DEBUG, "[obs-browser] CEF color type %s supported ", supported_formats[j].pretty_name); | |
blog(LOG_DEBUG, "[obs-browser]: CEF color type %s supported", supported_formats[j].pretty_name); |
blog(LOG_INFO, "[obs-browser]: " | ||
"Blacklisted driver " | ||
"detected, " | ||
"disabling browser " | ||
"source hardware " | ||
"acceleration."); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
blog(LOG_INFO, "[obs-browser]: " | |
"Blacklisted driver " | |
"detected, " | |
"disabling browser " | |
"source hardware " | |
"acceleration."); | |
blog(LOG_INFO, "[obs-browser]: Blacklisted driver detected, disabling browser source hardware acceleration."); |
Or let clang-format move the error string down one line, but it shouldn't require breaking it up.
bs->last_handle = info.shared_texture_handle; | ||
#else | ||
#elif defined(__APPLE__) && defined(_WIN32) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
How would both __APPLE__
and _WIN32
be defined? Was this meant to be inverted?
#elif !defined(__APPLE__) && !defined(_WIN32)
@@ -381,17 +418,21 @@ void BrowserClient::OnAcceleratedPaint(CefRefPtr<CefBrowser>, PaintElementType t | |||
//if (bs->texture) | |||
// gs_texture_acquire_sync(bs->texture, 1, INFINITE); | |||
|
|||
#else | |||
#elif defined(__WIN32) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
#elif defined(__WIN32) | |
#elif defined(_WIN32) |
Description
Requires:
Required by:
Add hwaccel support on Linux with CEF 6533 and later
Caution
NVIDIA might need to be blacklisted due to their inconsistency on supporting GBM and incomplete DRI3.TLDR: Only latest generations with latest driver has a likelihood to workNVIDIA driver has been blacklisted
Motivation and Context
Just wanted to try to make it somehow work for fun, ended up making it for real…
How Has This Been Tested?
Tested under Wayland and X11.
Types of changes
Checklist: