1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-05-31 06:58:11 +00:00
serenity/Servers/AudioServer/ASClientConnection.cpp
Andreas Kling 15afc88ffe AudioServer: Add a "main mix volume" and a simple program to get/set it
Give the mixer a main volume value (percent) that we scale all the
outgoing samples by (before clipping.)

Also add a simple "avol" program for querying and setting the volume:

- "avol" prints the current volume.
- "avol 200" sets the main mix volume to 200%
2019-07-29 19:06:58 +02:00

92 lines
2.6 KiB
C++

#include "ASClientConnection.h"
#include "ASMixer.h"
#include <LibAudio/ABuffer.h>
#include <LibAudio/ASAPI.h>
#include <LibCore/CEventLoop.h>
#include <SharedBuffer.h>
#include <errno.h>
#include <stdio.h>
#include <sys/socket.h>
#include <sys/types.h>
#include <sys/uio.h>
#include <unistd.h>
ASClientConnection::ASClientConnection(CLocalSocket& client_socket, int client_id, ASMixer& mixer)
: Connection(client_socket, client_id)
, m_mixer(mixer)
{
}
ASClientConnection::~ASClientConnection()
{
}
void ASClientConnection::send_greeting()
{
ASAPI_ServerMessage message;
message.type = ASAPI_ServerMessage::Type::Greeting;
message.greeting.server_pid = getpid();
message.greeting.your_client_id = client_id();
post_message(message);
}
bool ASClientConnection::handle_message(const ASAPI_ClientMessage& message, const ByteBuffer&&)
{
switch (message.type) {
case ASAPI_ClientMessage::Type::Greeting:
set_client_pid(message.greeting.client_pid);
break;
case ASAPI_ClientMessage::Type::EnqueueBuffer: {
auto shared_buffer = SharedBuffer::create_from_shared_buffer_id(message.play_buffer.buffer_id);
if (!shared_buffer) {
did_misbehave();
return false;
}
ASAPI_ServerMessage reply;
reply.type = ASAPI_ServerMessage::Type::EnqueueBufferResponse;
reply.playing_buffer.buffer_id = message.play_buffer.buffer_id;
if (!m_queue)
m_queue = m_mixer.create_queue(*this);
if (m_queue->is_full()) {
reply.success = false;
} else {
m_queue->enqueue(ABuffer::create_with_shared_buffer(*shared_buffer));
}
post_message(reply);
break;
}
case ASAPI_ClientMessage::Type::GetMainMixVolume: {
ASAPI_ServerMessage reply;
reply.type = ASAPI_ServerMessage::Type::DidGetMainMixVolume;
reply.value = m_mixer.main_volume();
post_message(reply);
break;
}
case ASAPI_ClientMessage::Type::SetMainMixVolume: {
ASAPI_ServerMessage reply;
reply.type = ASAPI_ServerMessage::Type::DidSetMainMixVolume;
m_mixer.set_main_volume(message.value);
post_message(reply);
break;
}
case ASAPI_ClientMessage::Type::Invalid:
default:
dbgprintf("ASClientConnection: Unexpected message ID %d\n", int(message.type));
did_misbehave();
}
return true;
}
void ASClientConnection::did_finish_playing_buffer(Badge<ASMixer>, int buffer_id)
{
ASAPI_ServerMessage reply;
reply.type = ASAPI_ServerMessage::Type::FinishedPlayingBuffer;
reply.playing_buffer.buffer_id = buffer_id;
post_message(reply);
}