Changeset 41811af in mainline for uspace/srv/hid/char_mouse/chardev.c


Ignore:
Timestamp:
2011-06-10T10:14:26Z (14 years ago)
Author:
Jiří Zárevúcky <zarevucky.jiri@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
ab547063
Parents:
9536e6e (diff), 390d80d (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:

Merge mainline

File:
1 edited

Legend:

Unmodified
Added
Removed
  • uspace/srv/hid/char_mouse/chardev.c

    r9536e6e r41811af  
    3636#include <ipc/char.h>
    3737#include <async.h>
     38#include <async_obsolete.h>
    3839#include <vfs/vfs.h>
    3940#include <fcntl.h>
    4041#include <errno.h>
    41 
     42#include <devmap.h>
     43#include <devmap_obsolete.h>
    4244#include <char_mouse.h>
    4345#include <mouse_port.h>
     
    5153int mouse_port_init(void)
    5254{
    53         const char *input = "/dev/char/ps2b";
    54         int input_fd;
    55 
    56         printf(NAME ": open %s\n", input);
    57 
    58         input_fd = open(input, O_RDONLY);
    59         if (input_fd < 0) {
    60                 printf(NAME ": Failed opening %s (%d)\n", input, input_fd);
    61                 return false;
     55        devmap_handle_t handle;
     56        int rc = devmap_device_get_handle("char/ps2b", &handle,
     57            IPC_FLAG_BLOCKING);
     58       
     59        if (rc != EOK) {
     60                printf("%s: Failed resolving PS/2\n", NAME);
     61                return rc;
    6262        }
    63 
    64         dev_phone = fd_phone(input_fd);
     63       
     64        dev_phone = devmap_obsolete_device_connect(handle, IPC_FLAG_BLOCKING);
    6565        if (dev_phone < 0) {
    66                 printf(NAME ": Failed to connect to device\n");
    67                 return false;
     66                printf("%s: Failed connecting to PS/2\n", NAME);
     67                return ENOENT;
    6868        }
    69 
     69       
    7070        /* NB: The callback connection is slotted for removal */
    71         if (async_connect_to_me(dev_phone, 0, 0, 0, chardev_events) != 0) {
     71        if (async_obsolete_connect_to_me(dev_phone, 0, 0, 0, chardev_events) != 0) {
    7272                printf(NAME ": Failed to create callback from device\n");
    7373                return false;
    7474        }
    75 
     75       
    7676        return 0;
    7777}
     
    8787void mouse_port_write(uint8_t data)
    8888{
    89         async_msg_1(dev_phone, CHAR_WRITE_BYTE, data);
     89        async_obsolete_msg_1(dev_phone, CHAR_WRITE_BYTE, data);
    9090}
    9191
     
    9999
    100100                int retval;
     101               
     102                if (!IPC_GET_IMETHOD(call)) {
     103                        /* TODO: Handle hangup */
     104                        return;
     105                }
    101106
    102107                switch (IPC_GET_IMETHOD(call)) {
    103                 case IPC_M_PHONE_HUNGUP:
    104                         /* TODO: Handle hangup */
    105                         return;
    106108                case IPC_FIRST_USER_METHOD:
    107109                        mouse_handle_byte(IPC_GET_ARG1(call));
Note: See TracChangeset for help on using the changeset viewer.