Lines Matching refs:list
48 struct hidraw_list *list = file->private_data; in hidraw_read() local
52 mutex_lock(&list->read_mutex); in hidraw_read()
55 if (list->head == list->tail) { in hidraw_read()
56 add_wait_queue(&list->hidraw->wait, &wait); in hidraw_read()
59 while (list->head == list->tail) { in hidraw_read()
64 if (!list->hidraw->exist) { in hidraw_read()
74 mutex_unlock(&list->read_mutex); in hidraw_read()
76 mutex_lock(&list->read_mutex); in hidraw_read()
81 remove_wait_queue(&list->hidraw->wait, &wait); in hidraw_read()
87 len = list->buffer[list->tail].len > count ? in hidraw_read()
88 count : list->buffer[list->tail].len; in hidraw_read()
90 if (list->buffer[list->tail].value) { in hidraw_read()
91 if (copy_to_user(buffer, list->buffer[list->tail].value, len)) { in hidraw_read()
98 kfree(list->buffer[list->tail].value); in hidraw_read()
99 list->buffer[list->tail].value = NULL; in hidraw_read()
100 list->tail = (list->tail + 1) & (HIDRAW_BUFFER_SIZE - 1); in hidraw_read()
103 mutex_unlock(&list->read_mutex); in hidraw_read()
241 struct hidraw_list *list = file->private_data; in hidraw_poll() local
243 poll_wait(file, &list->hidraw->wait, wait); in hidraw_poll()
244 if (list->head != list->tail) in hidraw_poll()
246 if (!list->hidraw->exist) in hidraw_poll()
255 struct hidraw_list *list; in hidraw_open() local
258 if (!(list = kzalloc(sizeof(struct hidraw_list), GFP_KERNEL))) { in hidraw_open()
269 list->hidraw = hidraw_table[minor]; in hidraw_open()
270 mutex_init(&list->read_mutex); in hidraw_open()
271 list_add_tail(&list->node, &hidraw_table[minor]->list); in hidraw_open()
272 file->private_data = list; in hidraw_open()
293 kfree(list); in hidraw_open()
300 struct hidraw_list *list = file->private_data; in hidraw_fasync() local
302 return fasync_helper(fd, file, on, &list->fasync); in hidraw_fasync()
309 struct hidraw_list *list = file->private_data; in hidraw_release() local
319 list_del(&list->node); in hidraw_release()
322 if (list->hidraw->exist) { in hidraw_release()
326 kfree(list->hidraw); in hidraw_release()
331 kfree(list->buffer[i].value); in hidraw_release()
332 kfree(list); in hidraw_release()
458 struct hidraw_list *list; in hidraw_report_event() local
461 list_for_each_entry(list, &dev->list, node) { in hidraw_report_event()
462 int new_head = (list->head + 1) & (HIDRAW_BUFFER_SIZE - 1); in hidraw_report_event()
464 if (new_head == list->tail) in hidraw_report_event()
467 if (!(list->buffer[list->head].value = kmemdup(data, len, GFP_ATOMIC))) { in hidraw_report_event()
471 list->buffer[list->head].len = len; in hidraw_report_event()
472 list->head = new_head; in hidraw_report_event()
473 kill_fasync(&list->fasync, SIGIO, POLL_IN); in hidraw_report_event()
523 INIT_LIST_HEAD(&dev->list); in hidraw_connect()