aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authordec05eba <dec05eba@protonmail.com>2024-01-11 10:50:14 +0100
committerdec05eba <dec05eba@protonmail.com>2024-01-11 10:50:14 +0100
commit94cbed9471ee2263aac6ff8b10a27cd38964eb67 (patch)
tree75e4d5db6d7e873f8c5deccb769dd505ebcc52ae
parent4c098a4f0397876110a950d99e9951c360fedca8 (diff)
Nvidia: use default p4 preset instead of p5, might fix frame issues
-rw-r--r--include/egl.h2
-rw-r--r--kms/client/kms_client.c2
-rw-r--r--src/capture/kms_vaapi.c2
-rw-r--r--src/capture/xcomposite_vaapi.c2
-rw-r--r--src/egl.c2
-rw-r--r--src/main.cpp8
6 files changed, 17 insertions, 1 deletions
diff --git a/include/egl.h b/include/egl.h
index ea71b5a..d8fdf97 100644
--- a/include/egl.h
+++ b/include/egl.h
@@ -180,6 +180,8 @@ typedef struct {
unsigned int (*glGetError)(void);
const unsigned char* (*glGetString)(unsigned int name);
+ void (*glFlush)(void);
+ void (*glFinish)(void);
void (*glClear)(unsigned int mask);
void (*glClearColor)(float red, float green, float blue, float alpha);
void (*glGenTextures)(int n, unsigned int *textures);
diff --git a/kms/client/kms_client.c b/kms/client/kms_client.c
index 02dce0b..4d69ee1 100644
--- a/kms/client/kms_client.c
+++ b/kms/client/kms_client.c
@@ -349,6 +349,8 @@ void cleanup_socket(gsr_kms_client *self, bool kill_server) {
if(kill_server && self->kms_server_pid != -1) {
kill(self->kms_server_pid, SIGKILL);
+ //int status;
+ //waitpid(self->kms_server_pid, &status, 0);
self->kms_server_pid = -1;
}
diff --git a/src/capture/kms_vaapi.c b/src/capture/kms_vaapi.c
index 2074657..e542d5b 100644
--- a/src/capture/kms_vaapi.c
+++ b/src/capture/kms_vaapi.c
@@ -545,6 +545,8 @@ static int gsr_capture_kms_vaapi_capture(gsr_capture *cap, AVFrame *frame) {
}
cap_kms->params.egl->eglSwapBuffers(cap_kms->params.egl->egl_display, cap_kms->params.egl->egl_surface);
+ //cap_kms->params.egl->glFlush();
+ //cap_kms->params.egl->glFinish();
return 0;
}
diff --git a/src/capture/xcomposite_vaapi.c b/src/capture/xcomposite_vaapi.c
index 2bc21a7..6cfea9f 100644
--- a/src/capture/xcomposite_vaapi.c
+++ b/src/capture/xcomposite_vaapi.c
@@ -445,6 +445,8 @@ static int gsr_capture_xcomposite_vaapi_capture(gsr_capture *cap, AVFrame *frame
texture_rotation);
cap_xcomp->params.egl->eglSwapBuffers(cap_xcomp->params.egl->egl_display, cap_xcomp->params.egl->egl_surface);
+ //cap_xcomp->params.egl->glFlush();
+ //cap_xcomp->params.egl->glFinish();
return 0;
}
diff --git a/src/egl.c b/src/egl.c
index faae6e7..b220612 100644
--- a/src/egl.c
+++ b/src/egl.c
@@ -363,6 +363,8 @@ static bool gsr_egl_load_gl(gsr_egl *self, void *library) {
dlsym_assign required_dlsym[] = {
{ (void**)&self->glGetError, "glGetError" },
{ (void**)&self->glGetString, "glGetString" },
+ { (void**)&self->glFlush, "glFlush" },
+ { (void**)&self->glFinish, "glFinish" },
{ (void**)&self->glClear, "glClear" },
{ (void**)&self->glClearColor, "glClearColor" },
{ (void**)&self->glGenTextures, "glGenTextures" },
diff --git a/src/main.cpp b/src/main.cpp
index 5b265b2..e28e3ce 100644
--- a/src/main.cpp
+++ b/src/main.cpp
@@ -598,6 +598,7 @@ static AVFrame* create_audio_frame(AVCodecContext *audio_codec_context) {
static void open_video(AVCodecContext *codec_context, VideoQuality video_quality, bool very_old_gpu, gsr_gpu_vendor vendor, PixelFormat pixel_format) {
AVDictionary *options = nullptr;
if(vendor == GSR_GPU_VENDOR_NVIDIA) {
+#if 0
bool supports_p4 = false;
bool supports_p5 = false;
@@ -610,6 +611,7 @@ static void open_video(AVCodecContext *codec_context, VideoQuality video_quality
supports_p5 = true;
}
}
+#endif
if(codec_context->codec_id == AV_CODEC_ID_AV1) {
switch(video_quality) {
@@ -657,7 +659,7 @@ static void open_video(AVCodecContext *codec_context, VideoQuality video_quality
break;
}
}
-
+#if 0
if(!supports_p4 && !supports_p5)
fprintf(stderr, "Info: your ffmpeg version is outdated. It's recommended that you use the flatpak version of gpu-screen-recorder version instead, which you can find at https://flathub.org/apps/details/com.dec05eba.gpu_screen_recorder\n");
@@ -680,6 +682,7 @@ static void open_video(AVCodecContext *codec_context, VideoQuality video_quality
av_dict_set(&options, "preset", supports_p4 ? "p4" : "medium", 0);
else
av_dict_set(&options, "preset", supports_p5 ? "p5" : "slow", 0);
+#endif
av_dict_set(&options, "tune", "hq", 0);
av_dict_set(&options, "rc", "constqp", 0);
@@ -1387,6 +1390,9 @@ int main(int argc, char **argv) {
signal(SIGUSR1, save_replay_handler);
signal(SIGUSR2, toggle_pause_handler);
+ // Stop nvidia driver from buffering frames
+ setenv("__GL_MaxFramesAllowed", "1", true);
+
if(argc <= 1)
usage_full();