Lines Matching refs:workitem
682 struct dj_workitem *workitem) in logi_dj_recv_destroy_djhid_device() argument
689 dj_dev = djrcv_dev->paired_dj_devices[workitem->device_index]; in logi_dj_recv_destroy_djhid_device()
690 djrcv_dev->paired_dj_devices[workitem->device_index] = NULL; in logi_dj_recv_destroy_djhid_device()
703 struct dj_workitem *workitem) in logi_dj_recv_add_djhid_device() argument
709 u8 device_index = workitem->device_index; in logi_dj_recv_add_djhid_device()
735 dj_hiddev->product = (workitem->quad_id_msb << 8) | in logi_dj_recv_add_djhid_device()
736 workitem->quad_id_lsb; in logi_dj_recv_add_djhid_device()
737 if (workitem->device_type) { in logi_dj_recv_add_djhid_device()
740 switch (workitem->device_type) { in logi_dj_recv_add_djhid_device()
774 dj_dev->reports_supported = workitem->reports_supported; in logi_dj_recv_add_djhid_device()
805 struct dj_workitem workitem; in delayedwork_callback() local
825 count = kfifo_out(&djrcv_dev->notif_fifo, &workitem, sizeof(workitem)); in delayedwork_callback()
827 if (count != sizeof(workitem)) { in delayedwork_callback()
837 switch (workitem.type) { in delayedwork_callback()
839 logi_dj_recv_add_djhid_device(djrcv_dev, &workitem); in delayedwork_callback()
842 logi_dj_recv_destroy_djhid_device(djrcv_dev, &workitem); in delayedwork_callback()
871 struct dj_workitem workitem = { .type = WORKITEM_TYPE_UNKNOWN }; in logi_dj_recv_queue_unknown_work() local
877 kfifo_in(&djrcv_dev->notif_fifo, &workitem, sizeof(workitem)); in logi_dj_recv_queue_unknown_work()
885 struct dj_workitem workitem = { in logi_dj_recv_queue_notification() local
891 workitem.type = WORKITEM_TYPE_PAIRED; in logi_dj_recv_queue_notification()
894 workitem.type = WORKITEM_TYPE_EMPTY; in logi_dj_recv_queue_notification()
899 workitem.quad_id_msb = in logi_dj_recv_queue_notification()
901 workitem.quad_id_lsb = in logi_dj_recv_queue_notification()
903 workitem.reports_supported = get_unaligned_le32( in logi_dj_recv_queue_notification()
906 workitem.reports_supported |= HIDPP; in logi_dj_recv_queue_notification()
908 workitem.type = WORKITEM_TYPE_UNPAIRED; in logi_dj_recv_queue_notification()
915 kfifo_in(&djrcv_dev->notif_fifo, &workitem, sizeof(workitem)); in logi_dj_recv_queue_notification()
941 struct dj_workitem *workitem) in logi_hidpp_dev_conn_notif_equad() argument
946 workitem->type = WORKITEM_TYPE_PAIRED; in logi_hidpp_dev_conn_notif_equad()
947 workitem->device_type = hidpp_report->params[HIDPP_PARAM_DEVICE_INFO] & in logi_hidpp_dev_conn_notif_equad()
949 workitem->quad_id_msb = hidpp_report->params[HIDPP_PARAM_EQUAD_MSB]; in logi_hidpp_dev_conn_notif_equad()
950 workitem->quad_id_lsb = hidpp_report->params[HIDPP_PARAM_EQUAD_LSB]; in logi_hidpp_dev_conn_notif_equad()
951 switch (workitem->device_type) { in logi_hidpp_dev_conn_notif_equad()
953 workitem->reports_supported |= STD_KEYBOARD | MULTIMEDIA | in logi_hidpp_dev_conn_notif_equad()
956 id = (workitem->quad_id_msb << 8) | workitem->quad_id_lsb; in logi_hidpp_dev_conn_notif_equad()
960 workitem->reports_supported |= KBD_MOUSE; in logi_hidpp_dev_conn_notif_equad()
962 workitem->reports_supported |= STD_MOUSE; in logi_hidpp_dev_conn_notif_equad()
968 workitem->reports_supported |= STD_MOUSE | HIDPP; in logi_hidpp_dev_conn_notif_equad()
970 workitem->reports_supported |= MULTIMEDIA; in logi_hidpp_dev_conn_notif_equad()
977 struct dj_workitem *workitem) in logi_hidpp_dev_conn_notif_27mhz() argument
979 workitem->type = WORKITEM_TYPE_PAIRED; in logi_hidpp_dev_conn_notif_27mhz()
980 workitem->quad_id_lsb = hidpp_report->params[HIDPP_PARAM_27MHZ_DEVID]; in logi_hidpp_dev_conn_notif_27mhz()
984 workitem->device_type = HIDPP_DEVICE_TYPE_MOUSE; in logi_hidpp_dev_conn_notif_27mhz()
985 workitem->reports_supported |= STD_MOUSE | HIDPP; in logi_hidpp_dev_conn_notif_27mhz()
996 workitem->device_type = HIDPP_DEVICE_TYPE_KEYBOARD; in logi_hidpp_dev_conn_notif_27mhz()
997 workitem->reports_supported |= STD_KEYBOARD | MULTIMEDIA | in logi_hidpp_dev_conn_notif_27mhz()
1012 struct dj_workitem workitem = { in logi_hidpp_recv_queue_notif() local
1021 logi_hidpp_dev_conn_notif_equad(hdev, hidpp_report, &workitem); in logi_hidpp_recv_queue_notif()
1026 workitem.reports_supported &= ~HIDPP; in logi_hidpp_recv_queue_notif()
1031 logi_hidpp_dev_conn_notif_27mhz(hdev, hidpp_report, &workitem); in logi_hidpp_recv_queue_notif()
1035 logi_hidpp_dev_conn_notif_equad(hdev, hidpp_report, &workitem); in logi_hidpp_recv_queue_notif()
1039 logi_hidpp_dev_conn_notif_equad(hdev, hidpp_report, &workitem); in logi_hidpp_recv_queue_notif()
1046 logi_hidpp_dev_conn_notif_equad(hdev, hidpp_report, &workitem); in logi_hidpp_recv_queue_notif()
1050 logi_hidpp_dev_conn_notif_equad(hdev, hidpp_report, &workitem); in logi_hidpp_recv_queue_notif()
1051 workitem.reports_supported |= STD_KEYBOARD; in logi_hidpp_recv_queue_notif()
1058 logi_hidpp_dev_conn_notif_equad(hdev, hidpp_report, &workitem); in logi_hidpp_recv_queue_notif()
1062 logi_hidpp_dev_conn_notif_equad(hdev, hidpp_report, &workitem); in logi_hidpp_recv_queue_notif()
1063 workitem.reports_supported |= STD_KEYBOARD; in logi_hidpp_recv_queue_notif()
1067 logi_hidpp_dev_conn_notif_equad(hdev, hidpp_report, &workitem); in logi_hidpp_recv_queue_notif()
1068 workitem.reports_supported |= STD_KEYBOARD; in logi_hidpp_recv_queue_notif()
1073 logi_hidpp_dev_conn_notif_equad(hdev, hidpp_report, &workitem); in logi_hidpp_recv_queue_notif()
1074 workitem.reports_supported |= STD_KEYBOARD; in logi_hidpp_recv_queue_notif()
1080 workitem.reports_supported |= HIDPP; in logi_hidpp_recv_queue_notif()
1083 if (workitem.type == WORKITEM_TYPE_EMPTY) { in logi_hidpp_recv_queue_notif()
1096 kfifo_in(&djrcv_dev->notif_fifo, &workitem, sizeof(workitem)); in logi_hidpp_recv_queue_notif()
1646 struct dj_workitem workitem = { in logi_dj_hidpp_event() local
1650 kfifo_in(&djrcv_dev->notif_fifo, &workitem, sizeof(workitem)); in logi_dj_hidpp_event()