summaryrefslogtreecommitdiffstats
path: root/src/pacat.c
diff options
context:
space:
mode:
authorLennart Poettering <lennart@poettering.net>2004-07-15 21:18:18 +0000
committerLennart Poettering <lennart@poettering.net>2004-07-15 21:18:18 +0000
commit710233bbf68c845ec5f1713679f4ff0b74c517de (patch)
treed6a88e5339790207f792d80cb00663af840f8250 /src/pacat.c
parentd8f13006614dca80de8903f5380b7cb718f26fcc (diff)
implement get_latency native command
git-svn-id: file:///home/lennart/svn/public/pulseaudio/trunk@72 fefdeb5f-60dc-0310-8127-8f9354f1896f
Diffstat (limited to 'src/pacat.c')
-rw-r--r--src/pacat.c20
1 files changed, 20 insertions, 0 deletions
diff --git a/src/pacat.c b/src/pacat.c
index c9257d03..2c5198fb 100644
--- a/src/pacat.c
+++ b/src/pacat.c
@@ -221,6 +221,25 @@ static void exit_signal_callback(void *id, int sig, void *userdata) {
}
+static void stream_get_latency_callback(struct pa_stream *s, uint32_t latency, void *userdata) {
+ assert(s);
+
+ if (latency == (uint32_t) -1) {
+ fprintf(stderr, "Failed to get latency: %s\n", strerror(errno));
+ quit(1);
+ return;
+ }
+
+ fprintf(stderr, "Current latency is %u usecs.\n", latency);
+}
+
+static void sigusr1_signal_callback(void *id, int sig, void *userdata) {
+ if (mode == PLAYBACK) {
+ fprintf(stderr, "Got SIGUSR1, requesting latency.\n");
+ pa_stream_get_latency(stream, stream_get_latency_callback, NULL);
+ }
+}
+
int main(int argc, char *argv[]) {
struct pa_mainloop* m = NULL;
int ret = 1, r;
@@ -246,6 +265,7 @@ int main(int argc, char *argv[]) {
r = pa_signal_init(mainloop_api);
assert(r == 0);
pa_signal_register(SIGINT, exit_signal_callback, NULL);
+ pa_signal_register(SIGUSR1, sigusr1_signal_callback, NULL);
signal(SIGPIPE, SIG_IGN);
if (!(stdio_source = mainloop_api->source_io(mainloop_api,