Changeset 5b0ae4be in mainline for kernel/genarch/src/kbd/i8042.c


Ignore:
Timestamp:
2009-02-22T15:51:40Z (15 years ago)
Author:
Jakub Jermar <jakub@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
691eb52
Parents:
f9f9a13
Message:

The kernel i8042 driver should be instance-neutral.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • kernel/genarch/src/kbd/i8042.c

    rf9f9a13 r5b0ae4be  
    9090};
    9191
    92 /** Structure for i8042's IRQ. */
    93 static irq_t i8042_kbd_irq;
    94 static irq_t i8042_mouse_irq;
    95 
    9692static irq_ownership_t i8042_claim(irq_t *irq)
    9793{
     
    126122
    127123/** Initialize i8042. */
    128 void
    129 i8042_init(devno_t kbd_devno, inr_t kbd_inr, devno_t mouse_devno,
    130     inr_t mouse_inr)
     124bool
     125i8042_init(i8042_t *dev, devno_t devno, inr_t inr)
    131126{
    132         i8042_t *dev = lgcy_i8042_instance.i8042;
     127        i8042_instance_t *instance;
    133128
    134129        chardev_initialize("i8042_kbd", &kbrd, &ops);
    135130        stdin = &kbrd;
    136131       
    137         irq_initialize(&i8042_kbd_irq);
    138         i8042_kbd_irq.devno = kbd_devno;
    139         i8042_kbd_irq.inr = kbd_inr;
    140         i8042_kbd_irq.claim = i8042_claim;
    141         i8042_kbd_irq.handler = i8042_irq_handler;
    142         i8042_kbd_irq.instance = &lgcy_i8042_instance;
    143         irq_register(&i8042_kbd_irq);
     132        instance = malloc(sizeof(i8042_instance_t), FRAME_ATOMIC);
     133        if (!instance)
     134                return false;
    144135       
    145         irq_initialize(&i8042_mouse_irq);
    146         i8042_mouse_irq.devno = mouse_devno;
    147         i8042_mouse_irq.inr = mouse_inr;
    148         i8042_mouse_irq.claim = i8042_claim;
    149         i8042_mouse_irq.handler = i8042_irq_handler;
    150         i8042_mouse_irq.instance = &lgcy_i8042_instance;
    151         irq_register(&i8042_mouse_irq);
     136        instance->devno = devno;
     137        instance->i8042 = dev;
    152138       
    153         trap_virtual_enable_irqs(1 << kbd_inr);
    154         trap_virtual_enable_irqs(1 << mouse_inr);
     139        irq_initialize(&instance->irq);
     140        instance->irq.devno = devno;
     141        instance->irq.inr = inr;
     142        instance->irq.claim = i8042_claim;
     143        instance->irq.handler = i8042_irq_handler;
     144        instance->irq.instance = instance;
     145        irq_register(&instance->irq);
     146       
     147        trap_virtual_enable_irqs(1 << inr);
    155148       
    156149        /*
     
    165158         */
    166159        sysinfo_set_item_val("kbd", NULL, true);
    167         sysinfo_set_item_val("kbd.devno", NULL, kbd_devno);
    168         sysinfo_set_item_val("kbd.inr", NULL, kbd_inr);
     160        sysinfo_set_item_val("kbd.devno", NULL, devno);
     161        sysinfo_set_item_val("kbd.inr", NULL, inr);
    169162#ifdef KBD_LEGACY
    170163        sysinfo_set_item_val("kbd.type", NULL, KBD_LEGACY);
    171164#endif
    172         sysinfo_set_item_val("mouse", NULL, true);
    173         sysinfo_set_item_val("mouse.devno", NULL, mouse_devno);
    174         sysinfo_set_item_val("mouse.inr", NULL, mouse_inr);
     165
     166        return true;
    175167}
    176168
Note: See TracChangeset for help on using the changeset viewer.