summaryrefslogtreecommitdiff
path: root/src/fps.c
diff options
context:
space:
mode:
authorVito Caputo <vcaputo@gnugeneration.com>2017-01-18 19:12:41 -0800
committerGitHub <noreply@github.com>2017-01-18 19:12:41 -0800
commit467137113c8b3d6bcb73ecff8c76f23793f25cb7 (patch)
treeecf3064d6587ec875d5c021d46d44855dc814212 /src/fps.c
parentee2073d4e411555aba878277131b56f7eb562c84 (diff)
parent404a356b2b22a134aea151145d1baabf253ee491 (diff)
Merge build system cleanups
- Move source to src/ subdir - Use $(top_srcdir)/src instead of ../../
Diffstat (limited to 'src/fps.c')
-rw-r--r--src/fps.c46
1 files changed, 46 insertions, 0 deletions
diff --git a/src/fps.c b/src/fps.c
new file mode 100644
index 0000000..99a3f85
--- /dev/null
+++ b/src/fps.c
@@ -0,0 +1,46 @@
+#include <signal.h>
+#include <stdio.h>
+#include <sys/time.h>
+
+#include "fb.h"
+#include "util.h"
+
+
+static int print_fps;
+
+
+static void sigalrm_handler(int signum)
+{
+ print_fps = 1;
+}
+
+
+int fps_setup(void)
+{
+ struct itimerval interval = {
+ .it_interval = { .tv_sec = 1, .tv_usec = 0 },
+ .it_value = { .tv_sec = 1, .tv_usec = 0 },
+ };
+
+ if (signal(SIGALRM, sigalrm_handler) == SIG_ERR)
+ return 0;
+
+ if (setitimer(ITIMER_REAL, &interval, NULL) < 0)
+ return 0;
+
+ return 1;
+}
+
+
+void fps_print(fb_t *fb)
+{
+ unsigned n;
+
+ if (!print_fps)
+ return;
+
+ fb_get_put_pages_count(fb, &n);
+ printf("FPS: %u\n", n);
+
+ print_fps = 0;
+}
© All Rights Reserved