Changeset eceb300 in mainline for uspace/srv/audio/hound/main.c


Ignore:
Timestamp:
2012-07-15T20:51:20Z (12 years ago)
Author:
Jan Vesely <jano.vesely@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
50fa3f7
Parents:
a9aae16e
Message:

hound: Use libhound

File:
1 edited

Legend:

Unmodified
Added
Removed
  • uspace/srv/audio/hound/main.c

    ra9aae16e receb300  
    3838#include <bool.h>
    3939#include <errno.h>
    40 #include <loc.h>
    4140#include <stdio.h>
    4241#include <stdlib.h>
    4342#include <str_error.h>
     43#include <hound/server.h>
     44
    4445
    4546#include "hound.h"
     
    5152#include "audio_client.h"
    5253#include "log.h"
    53 #include "protocol.h"
    5454
    5555static hound_t hound;
    5656
    57 static inline audio_format_t read_format(const ipc_call_t *call)
    58 {
    59         audio_format_t format = {
    60                 .channels = IPC_GET_ARG1(*call),
    61                 .sampling_rate = IPC_GET_ARG2(*call),
    62                 .sample_format = IPC_GET_ARG3(*call),
    63         };
    64         return format;
    65 }
    66 static inline const char *get_name()
    67 {
    68         size_t size = 0;
    69         ipc_callid_t callid;
    70         async_data_write_receive(&callid, &size);
    71         char *buffer = malloc(size);
    72         if (buffer) {
    73                 async_data_write_finalize(callid, buffer, size);
    74                 buffer[size - 1] = 0;
    75                 log_verbose("Got name from client: %s", buffer);
    76         }
    77         return buffer;
    78 }
    79 static inline async_sess_t *get_session()
    80 {
    81         ipc_call_t call;
    82         ipc_callid_t callid = async_get_call(&call);
    83         async_sess_t *s = async_callback_receive_start(EXCHANGE_ATOMIC, &call);
    84         async_answer_0(callid, s ? EOK : ENOMEM);
    85         if (s) {
    86                 log_verbose("Received callback session");
    87         } else
    88                 log_debug("Failed to receive callback session");
    89         return s;
    90 }
    91 
     57static int device_callback(service_id_t id, const char *name)
     58{
     59        return hound_add_device(&hound, id, name);
     60}
    9261
    9362static void scan_for_devices(void)
    9463{
    95         static bool cat_resolved = false;
    96         static category_id_t cat;
    97 
    98         if (!cat_resolved) {
    99                 log_verbose("Resolving category \"%s\".", CATEGORY);
    100                 const int ret = loc_category_get_id(CATEGORY, &cat,
    101                     IPC_FLAG_BLOCKING);
    102                 if (ret != EOK) {
    103                         log_error("Failed to get category: %s", str_error(ret));
    104                         return;
    105                 }
    106                 cat_resolved = true;
    107         }
    108 
    109         log_verbose("Getting available services in category.");
    110 
    111         service_id_t *svcs = NULL;
    112         size_t count = 0;
    113         const int ret = loc_category_get_svcs(cat, &svcs, &count);
    114         if (ret != EOK) {
    115                 log_error("Failed to get audio devices: %s", str_error(ret));
    116                 return;
    117         }
    118 
    119         for (unsigned i = 0; i < count; ++i) {
    120                 char *name = NULL;
    121                 int ret = loc_service_get_name(svcs[i], &name);
    122                 if (ret != EOK) {
    123                         log_error("Failed to get dev name: %s", str_error(ret));
    124                         continue;
    125                 }
    126                 ret = hound_add_device(&hound, svcs[i], name);
    127                 if (ret != EOK && ret != EEXISTS) {
    128                         log_error("Failed to add audio device \"%s\": %s",
    129                             name, str_error(ret));
    130                 }
    131                 free(name);
    132         }
    133 
    134         free(svcs);
     64        hound_server_devices_iterate(device_callback);
    13565}
    13666
     
    14171        LIST_INITIALIZE(local_playback);
    14272        LIST_INITIALIZE(local_recording);
     73        audio_format_t format = {0};
     74        const char *name = NULL;
     75        async_sess_t *sess = NULL;
    14376
    14477        while (1) {
     
    14780                switch (IPC_GET_IMETHOD(call)) {
    14881                case HOUND_REGISTER_PLAYBACK: {
    149                         const audio_format_t format = read_format(&call);
    150                         const char *name = get_name();
    151                         async_sess_t *sess = get_session();
     82                        hound_server_get_register_params(&name, &sess,
     83                            &format.channels, &format.sampling_rate,
     84                            &format.sample_format);
    15285                        audio_client_t *client =
    15386                            audio_client_get_playback(name, &format, sess);
     
    173106                }
    174107                case HOUND_REGISTER_RECORDING: {
    175                         const audio_format_t format = read_format(&call);
    176                         const char *name = get_name();
    177                         async_sess_t *sess = get_session();
    178                         audio_client_t * client =
     108                        hound_server_get_register_params(&name, &sess,
     109                            &format.channels, &format.sampling_rate,
     110                            &format.sample_format);
     111                        audio_client_t *client =
    179112                            audio_client_get_recording(name, &format, sess);
    180113                        free(name);
     
    197130                }
    198131                case HOUND_UNREGISTER_PLAYBACK: {
    199                         const char *name = get_name();
     132                        const char *name = NULL;
     133                        hound_server_get_unregister_params(&name);
    200134                        int ret = ENOENT;
    201135                        list_foreach(local_playback, it) {
     
    217151                }
    218152                case HOUND_UNREGISTER_RECORDING: {
    219                         const char *name = get_name();
     153                        const char *name = NULL;
     154                        hound_server_get_unregister_params(&name);
    220155                        int ret = ENOENT;
    221156                        list_foreach(local_recording, it) {
     
    237172                }
    238173                case HOUND_CONNECT: {
    239                         const char *name_a = get_name();
    240                         const char *name_b = get_name();
    241                         const int ret = hound_connect(&hound, name_a, name_b);
     174                        const char *source = NULL, *sink = NULL;
     175                        hound_server_get_connection_params(&source, &sink);
     176                        const int ret = hound_connect(&hound, source, sink);
    242177                        if (ret != EOK)
    243178                                log_error("Failed to connect '%s' to '%s': %s",
    244                                     name_a, name_b, str_error(ret));
    245                         free(name_a);
    246                         free(name_b);
     179                                    source, sink, str_error(ret));
     180                        free(source);
     181                        free(sink);
    247182                        async_answer_0(callid, ret);
    248183                        break;
    249184                }
    250185                case HOUND_DISCONNECT: {
    251                         const char *name_a = get_name();
    252                         const char *name_b = get_name();
    253                         const int ret = hound_disconnect(&hound, name_a, name_b);
     186                        const char *source = NULL, *sink = NULL;
     187                        hound_server_get_connection_params(&source, &sink);
     188                        const int ret = hound_disconnect(&hound, source, sink);
    254189                        if (ret != EOK)
    255190                                log_error("Failed to disconnect '%s' from '%s'"
    256                                     ": %s", name_a, name_b, str_error(ret));
    257                         free(name_a);
    258                         free(name_b);
     191                                    ": %s", source, sink, str_error(ret));
     192                        free(source);
     193                        free(sink);
    259194                        async_answer_0(callid, ret);
    260195                        break;
     
    282217                                audio_client_destroy(client);
    283218                        }
    284                         //TODO remove all clients
    285219                        return;
    286220                }
     
    300234
    301235        async_set_client_connection(client_connection);
    302         ret = loc_server_register(NAME);
     236
     237        service_id_t id = 0;
     238        ret = hound_server_register(NAME, &id);
    303239        if (ret != EOK) {
    304                 log_fatal("Failed to register sound server: %s",
     240                log_fatal("Failed to register server: %s", str_error(ret));
     241                return -ret;
     242        }
     243
     244        ret = hound_server_set_device_change_callback(scan_for_devices);
     245        if (ret != EOK) {
     246                log_fatal("Failed to register for device changes: %s",
    305247                    str_error(ret));
    306                 return -ret;
    307         }
    308 
    309         char fqdn[LOC_NAME_MAXLEN + 1];
    310         snprintf(fqdn, LOC_NAME_MAXLEN, "%s/%s", NAMESPACE, NAME);
    311         service_id_t id = 0;
    312         ret = loc_service_register(fqdn, &id);
    313         if (ret != EOK) {
    314                 log_fatal("Failed to register sound service: %s",
    315                     str_error(ret));
    316                 return -ret;
    317         }
    318 
    319         ret = loc_register_cat_change_cb(scan_for_devices);
    320         if (ret != EOK) {
    321                 log_fatal("Failed to register for category changes: %s",
    322                     str_error(ret));
    323                 loc_service_unregister(id);
     248                hound_server_unregister(id);
    324249                return -ret;
    325250        }
Note: See TracChangeset for help on using the changeset viewer.