Changeset ee1c2d9 in mainline for uspace/srv/hid/remcons/remcons.c


Ignore:
Timestamp:
2015-06-13T18:30:18Z (9 years ago)
Author:
Jan Vesely <jano.vesely@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
a157846
Parents:
0453261 (diff), 2f9a8e8 (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the (diff) links above to see all the changes relative to each parent.
Message:

mainline changes

File:
1 edited

Legend:

Unmodified
Added
Removed
  • uspace/srv/hid/remcons/remcons.c

    r0453261 ree1c2d9  
    4444#include <fibril_synch.h>
    4545#include <task.h>
    46 #include <net/in.h>
    47 #include <net/inet.h>
    48 #include <net/socket.h>
     46#include <inet/addr.h>
     47#include <inet/endpoint.h>
     48#include <inet/tcp.h>
    4949#include <io/console.h>
    5050#include <inttypes.h>
     
    9999};
    100100
     101static void remcons_new_conn(tcp_listener_t *lst, tcp_conn_t *conn);
     102
     103static tcp_listen_cb_t listen_cb = {
     104        .new_conn = remcons_new_conn
     105};
     106
     107static tcp_cb_t conn_cb = {
     108        .connected = NULL
     109};
     110
    101111static telnet_user_t *srv_to_user(con_srv_t *srv)
    102112{
     
    111121
    112122        /* Force character mode. */
    113         send(user->socket, (void *)telnet_force_character_mode_command,
    114             telnet_force_character_mode_command_count, 0);
     123        (void) tcp_conn_send(user->conn, (void *)telnet_force_character_mode_command,
     124            telnet_force_character_mode_command_count);
    115125
    116126        return EOK;
     
    272282}
    273283
    274 /** Fibril for each accepted socket.
    275  *
    276  * @param arg Corresponding @c telnet_user_t structure.
    277  */
    278 static int network_user_fibril(void *arg)
    279 {
    280         telnet_user_t *user = arg;
     284/** Handle network connection.
     285 *
     286 * @param lst  Listener
     287 * @param conn Connection
     288 */
     289static void remcons_new_conn(tcp_listener_t *lst, tcp_conn_t *conn)
     290{
     291        telnet_user_t *user = telnet_user_create(conn);
     292        assert(user);
     293
     294        con_srvs_init(&user->srvs);
     295        user->srvs.ops = &con_ops;
     296        user->srvs.sarg = user;
     297        user->srvs.abort_timeout = 1000;
     298
     299        telnet_user_add(user);
    281300
    282301        int rc = loc_service_register(user->service_name, &user->service_id);
     
    284303                telnet_user_error(user, "Unable to register %s with loc: %s.",
    285304                    user->service_name, str_error(rc));
    286                 return EOK;
     305                return;
    287306        }
    288307
    289308        telnet_user_log(user, "Service %s registerd with id %" PRIun ".",
    290309            user->service_name, user->service_id);
    291        
     310
    292311        fid_t spawn_fibril = fibril_create(spawn_task_fibril, user);
    293312        assert(spawn_fibril);
    294313        fibril_add_ready(spawn_fibril);
    295        
     314
    296315        /* Wait for all clients to exit. */
    297316        fibril_mutex_lock(&user->guard);
    298317        while (!user_can_be_destroyed_no_lock(user)) {
    299318                if (user->task_finished) {
    300                         closesocket(user->socket);
     319                        user->conn = NULL;
    301320                        user->socket_closed = true;
    302321                        user->srvs.aborted = true;
     
    310329        }
    311330        fibril_mutex_unlock(&user->guard);
    312        
     331
    313332        rc = loc_service_unregister(user->service_id);
    314333        if (rc != EOK) {
     
    320339        telnet_user_log(user, "Destroying...");
    321340        telnet_user_destroy(user);
    322 
    323         return EOK;
    324341}
    325342
    326343int main(int argc, char *argv[])
    327344{
    328         int port = 2223;
    329        
     345        int rc;
     346        tcp_listener_t *lst;
     347        tcp_t *tcp;
     348        inet_ep_t ep;
     349
    330350        async_set_client_connection(client_connection);
    331         int rc = loc_server_register(NAME);
     351        rc = loc_server_register(NAME);
    332352        if (rc != EOK) {
    333353                fprintf(stderr, "%s: Unable to register server\n", NAME);
    334354                return rc;
    335355        }
    336        
    337         struct sockaddr_in addr;
    338        
    339         addr.sin_family = AF_INET;
    340         addr.sin_port = htons(port);
    341        
    342         rc = inet_pton(AF_INET, "127.0.0.1", (void *)
    343             &addr.sin_addr.s_addr);
    344         if (rc != EOK) {
    345                 fprintf(stderr, "Error parsing network address: %s.\n",
    346                     str_error(rc));
    347                 return 2;
    348         }
    349 
    350         int listen_sd = socket(PF_INET, SOCK_STREAM, 0);
    351         if (listen_sd < 0) {
    352                 fprintf(stderr, "Error creating listening socket: %s.\n",
    353                     str_error(listen_sd));
    354                 return 3;
    355         }
    356 
    357         rc = bind(listen_sd, (struct sockaddr *) &addr, sizeof(addr));
    358         if (rc != EOK) {
    359                 fprintf(stderr, "Error binding socket: %s.\n",
    360                     str_error(rc));
    361                 return 4;
    362         }
    363 
    364         rc = listen(listen_sd, BACKLOG_SIZE);
    365         if (rc != EOK) {
    366                 fprintf(stderr, "listen() failed: %s.\n", str_error(rc));
    367                 return 5;
     356
     357        rc = tcp_create(&tcp);
     358        if (rc != EOK) {
     359                fprintf(stderr, "%s: Error initializing TCP.\n", NAME);
     360                return rc;
     361        }
     362
     363        inet_ep_init(&ep);
     364        ep.port = 2223;
     365
     366        rc = tcp_listener_create(tcp, &ep, &listen_cb, NULL, &conn_cb, NULL,
     367            &lst);
     368        if (rc != EOK) {
     369                fprintf(stderr, "%s: Error creating listener.\n", NAME);
     370                return rc;
    368371        }
    369372
    370373        printf("%s: HelenOS Remote console service\n", NAME);
    371374        task_retval(0);
    372 
    373         while (true) {
    374                 struct sockaddr_in raddr;
    375                 socklen_t raddr_len = sizeof(raddr);
    376                 int conn_sd = accept(listen_sd, (struct sockaddr *) &raddr,
    377                     &raddr_len);
    378 
    379                 if (conn_sd < 0) {
    380                         fprintf(stderr, "accept() failed: %s.\n",
    381                             str_error(rc));
    382                         continue;
    383                 }
    384 
    385                 telnet_user_t *user = telnet_user_create(conn_sd);
    386                 assert(user);
    387 
    388                 con_srvs_init(&user->srvs);
    389                 user->srvs.ops = &con_ops;
    390                 user->srvs.sarg = user;
    391                 user->srvs.abort_timeout = 1000;
    392 
    393                 telnet_user_add(user);
    394 
    395                 fid_t fid = fibril_create(network_user_fibril, user);
    396                 assert(fid);
    397                 fibril_add_ready(fid);
    398         }
    399 
     375        async_manager();
     376
     377        /* Not reached */
    400378        return 0;
    401379}
Note: See TracChangeset for help on using the changeset viewer.