Lines Matching refs:list
43 struct hidraw_list *list = file->private_data; in hidraw_read() local
47 mutex_lock(&list->read_mutex); in hidraw_read()
50 if (list->head == list->tail) { in hidraw_read()
51 add_wait_queue(&list->hidraw->wait, &wait); in hidraw_read()
54 while (list->head == list->tail) { in hidraw_read()
59 if (!list->hidraw->exist) { in hidraw_read()
69 mutex_unlock(&list->read_mutex); in hidraw_read()
71 mutex_lock(&list->read_mutex); in hidraw_read()
76 remove_wait_queue(&list->hidraw->wait, &wait); in hidraw_read()
82 len = list->buffer[list->tail].len > count ? in hidraw_read()
83 count : list->buffer[list->tail].len; in hidraw_read()
85 if (list->buffer[list->tail].value) { in hidraw_read()
86 if (copy_to_user(buffer, list->buffer[list->tail].value, len)) { in hidraw_read()
93 kfree(list->buffer[list->tail].value); in hidraw_read()
94 list->buffer[list->tail].value = NULL; in hidraw_read()
95 list->tail = (list->tail + 1) & (HIDRAW_BUFFER_SIZE - 1); in hidraw_read()
98 mutex_unlock(&list->read_mutex); in hidraw_read()
253 struct hidraw_list *list = file->private_data; in hidraw_poll() local
256 poll_wait(file, &list->hidraw->wait, wait); in hidraw_poll()
257 if (list->head != list->tail) in hidraw_poll()
259 if (!list->hidraw->exist) in hidraw_poll()
268 struct hidraw_list *list; in hidraw_open() local
272 if (!(list = kzalloc(sizeof(struct hidraw_list), GFP_KERNEL))) { in hidraw_open()
304 list->hidraw = hidraw_table[minor]; in hidraw_open()
305 mutex_init(&list->read_mutex); in hidraw_open()
307 list_add_tail(&list->node, &hidraw_table[minor]->list); in hidraw_open()
309 file->private_data = list; in hidraw_open()
314 kfree(list); in hidraw_open()
321 struct hidraw_list *list = file->private_data; in hidraw_fasync() local
323 return fasync_helper(fd, file, on, &list->fasync); in hidraw_fasync()
354 struct hidraw_list *list = file->private_data; in hidraw_release() local
360 while (list->tail != list->head) { in hidraw_release()
361 kfree(list->buffer[list->tail].value); in hidraw_release()
362 list->buffer[list->tail].value = NULL; in hidraw_release()
363 list->tail = (list->tail + 1) & (HIDRAW_BUFFER_SIZE - 1); in hidraw_release()
365 list_del(&list->node); in hidraw_release()
367 kfree(list); in hidraw_release()
522 struct hidraw_list *list; in hidraw_report_event() local
527 list_for_each_entry(list, &dev->list, node) { in hidraw_report_event()
528 int new_head = (list->head + 1) & (HIDRAW_BUFFER_SIZE - 1); in hidraw_report_event()
530 if (new_head == list->tail) in hidraw_report_event()
533 if (!(list->buffer[list->head].value = kmemdup(data, len, GFP_ATOMIC))) { in hidraw_report_event()
537 list->buffer[list->head].len = len; in hidraw_report_event()
538 list->head = new_head; in hidraw_report_event()
539 kill_fasync(&list->fasync, SIGIO, POLL_IN); in hidraw_report_event()
590 INIT_LIST_HEAD(&dev->list); in hidraw_connect()