Lines Matching refs:rc_map
58 struct rc_map *rc_map_get(const char *name) in rc_map_get()
129 static int ir_create_table(struct rc_map *rc_map, in ir_create_table() argument
132 rc_map->name = name; in ir_create_table()
133 rc_map->rc_type = rc_type; in ir_create_table()
134 rc_map->alloc = roundup_pow_of_two(size * sizeof(struct rc_map_table)); in ir_create_table()
135 rc_map->size = rc_map->alloc / sizeof(struct rc_map_table); in ir_create_table()
136 rc_map->scan = kmalloc(rc_map->alloc, GFP_KERNEL); in ir_create_table()
137 if (!rc_map->scan) in ir_create_table()
141 rc_map->size, rc_map->alloc); in ir_create_table()
152 static void ir_free_table(struct rc_map *rc_map) in ir_free_table() argument
154 rc_map->size = 0; in ir_free_table()
155 kfree(rc_map->scan); in ir_free_table()
156 rc_map->scan = NULL; in ir_free_table()
168 static int ir_resize_table(struct rc_map *rc_map, gfp_t gfp_flags) in ir_resize_table() argument
170 unsigned int oldalloc = rc_map->alloc; in ir_resize_table()
172 struct rc_map_table *oldscan = rc_map->scan; in ir_resize_table()
175 if (rc_map->size == rc_map->len) { in ir_resize_table()
177 if (rc_map->alloc >= IR_TAB_MAX_SIZE) in ir_resize_table()
184 if ((rc_map->len * 3 < rc_map->size) && (oldalloc > IR_TAB_MIN_SIZE)) { in ir_resize_table()
199 memcpy(newscan, rc_map->scan, rc_map->len * sizeof(struct rc_map_table)); in ir_resize_table()
200 rc_map->scan = newscan; in ir_resize_table()
201 rc_map->alloc = newalloc; in ir_resize_table()
202 rc_map->size = rc_map->alloc / sizeof(struct rc_map_table); in ir_resize_table()
219 struct rc_map *rc_map, in ir_update_mapping() argument
223 int old_keycode = rc_map->scan[index].keycode; in ir_update_mapping()
229 index, rc_map->scan[index].scancode); in ir_update_mapping()
230 rc_map->len--; in ir_update_mapping()
231 memmove(&rc_map->scan[index], &rc_map->scan[index+ 1], in ir_update_mapping()
232 (rc_map->len - index) * sizeof(struct rc_map_table)); in ir_update_mapping()
237 rc_map->scan[index].scancode, new_keycode); in ir_update_mapping()
238 rc_map->scan[index].keycode = new_keycode; in ir_update_mapping()
246 for (i = 0; i < rc_map->len; i++) { in ir_update_mapping()
247 if (rc_map->scan[i].keycode == old_keycode) { in ir_update_mapping()
254 ir_resize_table(rc_map, GFP_ATOMIC); in ir_update_mapping()
275 struct rc_map *rc_map, in ir_establish_scancode() argument
293 for (i = 0; i < rc_map->len; i++) { in ir_establish_scancode()
294 if (rc_map->scan[i].scancode == scancode) in ir_establish_scancode()
298 if (rc_map->scan[i].scancode >= scancode) in ir_establish_scancode()
303 if (rc_map->size == rc_map->len) { in ir_establish_scancode()
304 if (!resize || ir_resize_table(rc_map, GFP_ATOMIC)) in ir_establish_scancode()
309 if (i < rc_map->len) in ir_establish_scancode()
310 memmove(&rc_map->scan[i + 1], &rc_map->scan[i], in ir_establish_scancode()
311 (rc_map->len - i) * sizeof(struct rc_map_table)); in ir_establish_scancode()
312 rc_map->scan[i].scancode = scancode; in ir_establish_scancode()
313 rc_map->scan[i].keycode = KEY_RESERVED; in ir_establish_scancode()
314 rc_map->len++; in ir_establish_scancode()
333 struct rc_map *rc_map = &rdev->rc_map; in ir_setkeycode() local
339 spin_lock_irqsave(&rc_map->lock, flags); in ir_setkeycode()
343 if (index >= rc_map->len) { in ir_setkeycode()
352 index = ir_establish_scancode(rdev, rc_map, scancode, true); in ir_setkeycode()
353 if (index >= rc_map->len) { in ir_setkeycode()
359 *old_keycode = ir_update_mapping(rdev, rc_map, index, ke->keycode); in ir_setkeycode()
362 spin_unlock_irqrestore(&rc_map->lock, flags); in ir_setkeycode()
376 const struct rc_map *from) in ir_setkeytable()
378 struct rc_map *rc_map = &dev->rc_map; in ir_setkeytable() local
382 rc = ir_create_table(rc_map, from->name, in ir_setkeytable()
388 rc_map->size, rc_map->alloc); in ir_setkeytable()
391 index = ir_establish_scancode(dev, rc_map, in ir_setkeytable()
393 if (index >= rc_map->len) { in ir_setkeytable()
398 ir_update_mapping(dev, rc_map, index, in ir_setkeytable()
403 ir_free_table(rc_map); in ir_setkeytable()
417 static unsigned int ir_lookup_by_scancode(const struct rc_map *rc_map, in ir_lookup_by_scancode() argument
421 int end = rc_map->len - 1; in ir_lookup_by_scancode()
426 if (rc_map->scan[mid].scancode < scancode) in ir_lookup_by_scancode()
428 else if (rc_map->scan[mid].scancode > scancode) in ir_lookup_by_scancode()
450 struct rc_map *rc_map = &rdev->rc_map; in ir_getkeycode() local
457 spin_lock_irqsave(&rc_map->lock, flags); in ir_getkeycode()
466 index = ir_lookup_by_scancode(rc_map, scancode); in ir_getkeycode()
469 if (index < rc_map->len) { in ir_getkeycode()
470 entry = &rc_map->scan[index]; in ir_getkeycode()
493 spin_unlock_irqrestore(&rc_map->lock, flags); in ir_getkeycode()
509 struct rc_map *rc_map = &dev->rc_map; in rc_g_keycode_from_table() local
514 spin_lock_irqsave(&rc_map->lock, flags); in rc_g_keycode_from_table()
516 index = ir_lookup_by_scancode(rc_map, scancode); in rc_g_keycode_from_table()
517 keycode = index < rc_map->len ? in rc_g_keycode_from_table()
518 rc_map->scan[index].keycode : KEY_RESERVED; in rc_g_keycode_from_table()
520 spin_unlock_irqrestore(&rc_map->lock, flags); in rc_g_keycode_from_table()
1218 if (dev->rc_map.name) in rc_dev_uevent()
1219 ADD_HOTPLUG_VAR("NAME=%s", dev->rc_map.name); in rc_dev_uevent()
1303 spin_lock_init(&dev->rc_map.lock); in rc_allocate_device()
1334 struct rc_map *rc_map; in rc_register_device() local
1343 rc_map = rc_map_get(dev->map_name); in rc_register_device()
1344 if (!rc_map) in rc_register_device()
1345 rc_map = rc_map_get(RC_MAP_EMPTY); in rc_register_device()
1346 if (!rc_map || !rc_map->scan || rc_map->size == 0) in rc_register_device()
1388 rc = ir_setkeytable(dev, rc_map); in rc_register_device()
1445 u64 rc_type = (1ll << rc_map->rc_type); in rc_register_device()
1457 rc_map->name ? rc_map->name : "unknown", in rc_register_device()
1469 ir_free_table(&dev->rc_map); in rc_register_device()
1490 ir_free_table(&dev->rc_map); in rc_unregister_device()