Blame SOURCES/0016-vdagent-volume-synchronization-from-client.patch

ad7ee3
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
ad7ee3
From: Victor Toso <victortoso@redhat.com>
ad7ee3
Date: Fri, 6 Mar 2015 18:15:35 +0100
ad7ee3
Subject: [PATCH] vdagent: volume synchronization from client.
ad7ee3
ad7ee3
Include the capability of volume sync to set volume or mute to default
ad7ee3
sink-input/source-output of guest.
ad7ee3
---
ad7ee3
 src/vdagent.c        | 11 +++++++++++
ad7ee3
 src/vdagentd-proto.h |  1 +
ad7ee3
 src/vdagentd.c       | 21 +++++++++++++++++++++
ad7ee3
 3 files changed, 33 insertions(+)
ad7ee3
ad7ee3
diff --git a/src/vdagent.c b/src/vdagent.c
ad7ee3
index c5e09ff..a26af73 100644
ad7ee3
--- a/src/vdagent.c
ad7ee3
+++ b/src/vdagent.c
ad7ee3
@@ -39,6 +39,7 @@
ad7ee3
 #include "udscs.h"
ad7ee3
 #include "vdagentd-proto.h"
ad7ee3
 #include "vdagentd-proto-strings.h"
ad7ee3
+#include "vdagent-audio.h"
ad7ee3
 #include "vdagent-x11.h"
ad7ee3
 #include "vdagent-file-xfers.h"
ad7ee3
 
ad7ee3
@@ -97,6 +98,16 @@ void daemon_read_complete(struct udscs_connection **connp,
ad7ee3
                                   (VDAgentFileXferStatusMessage *)data);
ad7ee3
         free(data);
ad7ee3
         break;
ad7ee3
+    case VDAGENTD_AUDIO_VOLUME_SYNC: {
ad7ee3
+        VDAgentAudioVolumeSync *avs = (VDAgentAudioVolumeSync *)data;
ad7ee3
+        if (avs->is_playback) {
ad7ee3
+            vdagent_audio_playback_sync(avs->mute, avs->nchannels, avs->volume);
ad7ee3
+        } else {
ad7ee3
+            vdagent_audio_record_sync(avs->mute, avs->nchannels, avs->volume);
ad7ee3
+        }
ad7ee3
+        free(data);
ad7ee3
+        break;
ad7ee3
+    }
ad7ee3
     case VDAGENTD_FILE_XFER_DATA:
ad7ee3
         vdagent_file_xfers_data(vdagent_file_xfers,
ad7ee3
                                 (VDAgentFileXferDataMessage *)data);
ad7ee3
diff --git a/src/vdagentd-proto.h b/src/vdagentd-proto.h
ad7ee3
index 25e6a36..0dbaaea 100644
ad7ee3
--- a/src/vdagentd-proto.h
ad7ee3
+++ b/src/vdagentd-proto.h
ad7ee3
@@ -36,6 +36,7 @@ enum {
ad7ee3
     VDAGENTD_CLIPBOARD_DATA,    /* arg1: sel, arg 2: type, data: data */
ad7ee3
     VDAGENTD_CLIPBOARD_RELEASE, /* arg1: selection */
ad7ee3
     VDAGENTD_VERSION,           /* daemon -> client, data: version string */
ad7ee3
+    VDAGENTD_AUDIO_VOLUME_SYNC,
ad7ee3
     VDAGENTD_FILE_XFER_START,
ad7ee3
     VDAGENTD_FILE_XFER_STATUS,
ad7ee3
     VDAGENTD_FILE_XFER_DATA,
ad7ee3
diff --git a/src/vdagentd.c b/src/vdagentd.c
ad7ee3
index 6280dfa..594f36b 100644
ad7ee3
--- a/src/vdagentd.c
ad7ee3
+++ b/src/vdagentd.c
ad7ee3
@@ -96,6 +96,7 @@ static void send_capabilities(struct vdagent_virtio_port *vport,
ad7ee3
     VD_AGENT_SET_CAPABILITY(caps->caps, VD_AGENT_CAP_CLIPBOARD_SELECTION);
ad7ee3
     VD_AGENT_SET_CAPABILITY(caps->caps, VD_AGENT_CAP_SPARSE_MONITORS_CONFIG);
ad7ee3
     VD_AGENT_SET_CAPABILITY(caps->caps, VD_AGENT_CAP_GUEST_LINEEND_LF);
ad7ee3
+    VD_AGENT_SET_CAPABILITY(caps->caps, VD_AGENT_CAP_AUDIO_VOLUME_SYNC);
ad7ee3
 
ad7ee3
     vdagent_virtio_port_write(vport, VDP_CLIENT_PORT,
ad7ee3
                               VD_AGENT_ANNOUNCE_CAPABILITIES, 0,
ad7ee3
@@ -151,6 +152,19 @@ static void do_client_monitors(struct vdagent_virtio_port *vport, int port_nr,
ad7ee3
                               (uint8_t *)&reply, sizeof(reply));
ad7ee3
 }
ad7ee3
 
ad7ee3
+static void do_client_volume_sync(struct vdagent_virtio_port *vport, int port_nr,
ad7ee3
+    VDAgentMessage *message_header,
ad7ee3
+    VDAgentAudioVolumeSync *avs)
ad7ee3
+{
ad7ee3
+    if (active_session_conn == NULL) {
ad7ee3
+        syslog(LOG_DEBUG, "No active session - Can't volume-sync");
ad7ee3
+        return;
ad7ee3
+    }
ad7ee3
+
ad7ee3
+    udscs_write(active_session_conn, VDAGENTD_AUDIO_VOLUME_SYNC, 0, 0,
ad7ee3
+                (uint8_t *)avs, message_header->size);
ad7ee3
+}
ad7ee3
+
ad7ee3
 static void do_client_capabilities(struct vdagent_virtio_port *vport,
ad7ee3
     VDAgentMessage *message_header,
ad7ee3
     VDAgentAnnounceCapabilities *caps)
ad7ee3
@@ -366,6 +380,13 @@ int virtio_port_read_complete(
ad7ee3
         vdagent_virtio_port_reset(vport, VDP_CLIENT_PORT);
ad7ee3
         do_client_disconnect();
ad7ee3
         break;
ad7ee3
+    case VD_AGENT_AUDIO_VOLUME_SYNC:
ad7ee3
+        if (message_header->size < sizeof(VDAgentAudioVolumeSync))
ad7ee3
+            goto size_error;
ad7ee3
+
ad7ee3
+        do_client_volume_sync(vport, port_nr, message_header,
ad7ee3
+                (VDAgentAudioVolumeSync *)data);
ad7ee3
+        break;
ad7ee3
     default:
ad7ee3
         syslog(LOG_WARNING, "unknown message type %d, ignoring",
ad7ee3
                message_header->type);