@ -31,7 +31,7 @@
# include "evdev.h"
# include "evdev.h"
void
void
evdev_led_update ( struct wl_list * evdev_devices , enum weston_led leds )
evdev_led_update ( struct evdev_input_device * device , enum weston_led leds )
{
{
static const struct {
static const struct {
enum weston_led weston ;
enum weston_led weston ;
@ -41,10 +41,12 @@ evdev_led_update(struct wl_list *evdev_devices, enum weston_led leds)
{ LED_CAPS_LOCK , LED_CAPSL } ,
{ LED_CAPS_LOCK , LED_CAPSL } ,
{ LED_SCROLL_LOCK , LED_SCROLLL } ,
{ LED_SCROLL_LOCK , LED_SCROLLL } ,
} ;
} ;
struct evdev_input_device * device ;
struct input_event ev [ ARRAY_LENGTH ( map ) ] ;
struct input_event ev [ ARRAY_LENGTH ( map ) ] ;
unsigned int i ;
unsigned int i ;
if ( ! device - > caps & EVDEV_KEYBOARD )
return ;
memset ( ev , 0 , sizeof ( ev ) ) ;
memset ( ev , 0 , sizeof ( ev ) ) ;
for ( i = 0 ; i < ARRAY_LENGTH ( map ) ; i + + ) {
for ( i = 0 ; i < ARRAY_LENGTH ( map ) ; i + + ) {
ev [ i ] . type = EV_LED ;
ev [ i ] . type = EV_LED ;
@ -52,11 +54,8 @@ evdev_led_update(struct wl_list *evdev_devices, enum weston_led leds)
ev [ i ] . value = ! ! ( leds & map [ i ] . weston ) ;
ev [ i ] . value = ! ! ( leds & map [ i ] . weston ) ;
}
}
wl_list_for_each ( device , evdev_devices , link ) {
i = write ( device - > fd , ev , sizeof ev ) ;
if ( device - > caps & EVDEV_KEYBOARD )
( void ) i ; /* no, we really don't care about the return value */
i = write ( device - > fd , ev , sizeof ev ) ;
( void ) i ; /* no, we really don't care about the return value */
}
}
}
static inline void
static inline void