• Home
  • Raw
  • Download

Lines Matching full:usage

63 #define map_abs(c)	hid_map_usage(hidinput, usage, &bit, &max, EV_ABS, (c))
64 #define map_rel(c) hid_map_usage(hidinput, usage, &bit, &max, EV_REL, (c))
65 #define map_key(c) hid_map_usage(hidinput, usage, &bit, &max, EV_KEY, (c))
66 #define map_led(c) hid_map_usage(hidinput, usage, &bit, &max, EV_LED, (c))
68 #define map_abs_clear(c) hid_map_usage_clear(hidinput, usage, &bit, \
70 #define map_key_clear(c) hid_map_usage_clear(hidinput, usage, &bit, \
73 static bool match_scancode(struct hid_usage *usage, in match_scancode() argument
76 return (usage->hid & (HID_USAGE_PAGE | HID_USAGE)) == scancode; in match_scancode()
79 static bool match_keycode(struct hid_usage *usage, in match_keycode() argument
85 return (usage->type == EV_KEY && usage->code == keycode); in match_keycode()
88 static bool match_index(struct hid_usage *usage, in match_index() argument
94 typedef bool (*hid_usage_cmp_t)(struct hid_usage *usage,
104 struct hid_usage *usage; in hidinput_find_key() local
110 usage = report->field[i]->usage + j; in hidinput_find_key()
111 if (usage->type == EV_KEY || usage->type == 0) { in hidinput_find_key()
112 if (match(usage, cur_idx, value)) { in hidinput_find_key()
115 return usage; in hidinput_find_key()
130 struct hid_usage *usage; in hidinput_locate_usage() local
134 usage = hidinput_find_key(hid, match_index, ke->index, index); in hidinput_locate_usage()
136 usage = hidinput_find_key(hid, match_scancode, scancode, index); in hidinput_locate_usage()
138 usage = NULL; in hidinput_locate_usage()
140 return usage; in hidinput_locate_usage()
147 struct hid_usage *usage; in hidinput_getkeycode() local
150 usage = hidinput_locate_usage(hid, ke, &index); in hidinput_getkeycode()
151 if (usage) { in hidinput_getkeycode()
152 ke->keycode = usage->type == EV_KEY ? in hidinput_getkeycode()
153 usage->code : KEY_RESERVED; in hidinput_getkeycode()
155 scancode = usage->hid & (HID_USAGE_PAGE | HID_USAGE); in hidinput_getkeycode()
169 struct hid_usage *usage; in hidinput_setkeycode() local
171 usage = hidinput_locate_usage(hid, ke, NULL); in hidinput_setkeycode()
172 if (usage) { in hidinput_setkeycode()
173 *old_keycode = usage->type == EV_KEY ? in hidinput_setkeycode()
174 usage->code : KEY_RESERVED; in hidinput_setkeycode()
175 usage->code = ke->keycode; in hidinput_setkeycode()
178 set_bit(usage->code, dev->keybit); in hidinput_setkeycode()
179 dbg_hid("Assigned keycode %d to HID usage code %x\n", in hidinput_setkeycode()
180 usage->code, usage->hid); in hidinput_setkeycode()
572 struct hid_usage *usage) in hidinput_configure_usage() argument
590 (usage->hid & HID_USAGE_PAGE) != HID_UP_LED) { in hidinput_configure_usage()
596 usage, &bit, &max); in hidinput_configure_usage()
603 switch (usage->hid & HID_USAGE_PAGE) { in hidinput_configure_usage()
610 if ((usage->hid & HID_USAGE) < 256) { in hidinput_configure_usage()
611 if (!hid_keyboard[usage->hid & HID_USAGE]) goto ignore; in hidinput_configure_usage()
612 map_key_clear(hid_keyboard[usage->hid & HID_USAGE]); in hidinput_configure_usage()
619 code = ((usage->hid - 1) & HID_USAGE); in hidinput_configure_usage()
650 switch (usage->hid & 0xffff) { in hidinput_configure_usage()
661 if ((usage->hid & 0xf0) == 0x80) { /* SystemControl */ in hidinput_configure_usage()
662 switch (usage->hid & 0xf) { in hidinput_configure_usage()
683 if ((usage->hid & 0xf0) == 0xb0) { /* SC - Display */ in hidinput_configure_usage()
684 switch (usage->hid & 0xf) { in hidinput_configure_usage()
700 if ((usage->hid & 0xf0) == 0x90) { /* D-pad */ in hidinput_configure_usage()
701 switch (usage->hid) { in hidinput_configure_usage()
702 case HID_GD_UP: usage->hat_dir = 1; break; in hidinput_configure_usage()
703 case HID_GD_DOWN: usage->hat_dir = 5; break; in hidinput_configure_usage()
704 case HID_GD_RIGHT: usage->hat_dir = 3; break; in hidinput_configure_usage()
705 case HID_GD_LEFT: usage->hat_dir = 7; break; in hidinput_configure_usage()
716 switch (usage->hid) { in hidinput_configure_usage()
717 /* These usage IDs map directly to the usage codes. */ in hidinput_configure_usage()
721 map_rel(usage->hid & 0xf); in hidinput_configure_usage()
723 map_abs_clear(usage->hid & 0xf); in hidinput_configure_usage()
728 map_rel(usage->hid & 0xf); in hidinput_configure_usage()
730 map_abs(usage->hid & 0xf); in hidinput_configure_usage()
734 usage->hat_min = field->logical_minimum; in hidinput_configure_usage()
735 usage->hat_max = field->logical_maximum; in hidinput_configure_usage()
757 switch (usage->hid & 0xffff) { /* HID-Value: */ in hidinput_configure_usage()
775 switch (usage->hid & 0xff) { in hidinput_configure_usage()
798 usage->type = EV_PWR; in hidinput_configure_usage()
827 * Actual eraser (BTN_TOOL_RUBBER) is set by Invert usage when in hidinput_configure_usage()
839 usage->type = EV_MSC; in hidinput_configure_usage()
840 usage->code = MSC_SERIAL; in hidinput_configure_usage()
850 switch (usage->hid & HID_USAGE) { in hidinput_configure_usage()
873 switch (usage->hid & HID_USAGE) { in hidinput_configure_usage()
1051 switch (usage->hid) { in hidinput_configure_usage()
1054 usage->type = EV_PWR; in hidinput_configure_usage()
1061 switch (usage->hid & HID_USAGE) { in hidinput_configure_usage()
1080 switch (usage->hid & HID_USAGE) { in hidinput_configure_usage()
1103 switch (usage->hid & HID_USAGE) { in hidinput_configure_usage()
1133 device->driver->input_mapped(device, hidinput, field, usage, in hidinput_configure_usage()
1137 * of the usage is desired. in hidinput_configure_usage()
1142 set_bit(usage->type, input->evbit); in hidinput_configure_usage()
1159 while (usage->code <= max && test_and_set_bit(usage->code, bit)) { in hidinput_configure_usage()
1161 usage->code = find_next_zero_bit(bit, in hidinput_configure_usage()
1163 usage->code); in hidinput_configure_usage()
1170 if (usage->code > max) in hidinput_configure_usage()
1173 if (usage->type == EV_ABS) { in hidinput_configure_usage()
1178 if ((device->quirks & HID_QUIRK_BADPAD) && (usage->code == ABS_X || usage->code == ABS_Y)) { in hidinput_configure_usage()
1184 input_set_abs_params(input, usage->code, a, b, (b - a) >> 8, (b - a) >> 4); in hidinput_configure_usage()
1185 else input_set_abs_params(input, usage->code, a, b, 0, 0); in hidinput_configure_usage()
1187 input_abs_set_res(input, usage->code, in hidinput_configure_usage()
1188 hidinput_calc_abs_res(field, usage->code)); in hidinput_configure_usage()
1191 if (usage->code == ABS_MT_POSITION_X && input->hint_events_per_packet == 0) in hidinput_configure_usage()
1195 if (usage->type == EV_ABS && in hidinput_configure_usage()
1196 (usage->hat_min < usage->hat_max || usage->hat_dir)) { in hidinput_configure_usage()
1198 for (i = usage->code; i < usage->code + 2 && i <= max; i++) { in hidinput_configure_usage()
1202 if (usage->hat_dir && !field->dpad) in hidinput_configure_usage()
1203 field->dpad = usage->code; in hidinput_configure_usage()
1206 /* for those devices which produce Consumer volume usage as relative, in hidinput_configure_usage()
1210 if ((usage->type == EV_ABS) && (field->flags & HID_MAIN_ITEM_RELATIVE) && in hidinput_configure_usage()
1211 (usage->code == ABS_VOLUME)) { in hidinput_configure_usage()
1216 if (usage->type == EV_KEY) { in hidinput_configure_usage()
1224 usage->type = 0; in hidinput_configure_usage()
1225 usage->code = 0; in hidinput_configure_usage()
1228 void hidinput_hid_event(struct hid_device *hid, struct hid_field *field, struct hid_usage *usage, _… in hidinput_hid_event() argument
1233 if (!usage->type) in hidinput_hid_event()
1236 if (usage->type == EV_PWR) { in hidinput_hid_event()
1246 if (usage->hat_min < usage->hat_max || usage->hat_dir) { in hidinput_hid_event()
1247 int hat_dir = usage->hat_dir; in hidinput_hid_event()
1249 hat_dir = (value - usage->hat_min) * 8 / (usage->hat_max - usage->hat_min + 1) + 1; in hidinput_hid_event()
1251 input_event(input, usage->type, usage->code , hid_hat_to_axis[hat_dir].x); in hidinput_hid_event()
1252 input_event(input, usage->type, usage->code + 1, hid_hat_to_axis[hat_dir].y); in hidinput_hid_event()
1256 if (usage->hid == (HID_UP_DIGITIZER | 0x003c)) { /* Invert */ in hidinput_hid_event()
1261 if (usage->hid == (HID_UP_DIGITIZER | 0x0032)) { /* InRange */ in hidinput_hid_event()
1263 input_event(input, usage->type, (*quirks & HID_QUIRK_INVERT) ? BTN_TOOL_RUBBER : usage->code, 1); in hidinput_hid_event()
1266 input_event(input, usage->type, usage->code, 0); in hidinput_hid_event()
1267 input_event(input, usage->type, BTN_TOOL_RUBBER, 0); in hidinput_hid_event()
1271 if (usage->hid == (HID_UP_DIGITIZER | 0x0030) && (*quirks & HID_QUIRK_NOTOUCH)) { /* Pressure */ in hidinput_hid_event()
1277 if (usage->hid == (HID_UP_PID | 0x83UL)) { /* Simultaneous Effects Max */ in hidinput_hid_event()
1282 if (usage->hid == (HID_UP_PID | 0x7fUL)) { in hidinput_hid_event()
1287 if ((usage->type == EV_KEY) && (usage->code == 0)) /* Key 0 is "unassigned", not KEY_UNKNOWN */ in hidinput_hid_event()
1290 if ((usage->type == EV_ABS) && (field->flags & HID_MAIN_ITEM_RELATIVE) && in hidinput_hid_event()
1291 (usage->code == ABS_VOLUME)) { in hidinput_hid_event()
1342 usage->usage_index < field->maxusage && in hidinput_hid_event()
1343 value == field->value[usage->usage_index]) in hidinput_hid_event()
1346 /* report the usage code as scancode if the key status has changed */ in hidinput_hid_event()
1347 if (usage->type == EV_KEY && in hidinput_hid_event()
1348 (!test_bit(usage->code, input->key)) == value) in hidinput_hid_event()
1349 input_event(input, EV_MSC, MSC_SCAN, usage->hid); in hidinput_hid_event()
1351 input_event(input, usage->type, usage->code, value); in hidinput_hid_event()
1354 usage->type == EV_KEY && value) { in hidinput_hid_event()
1356 input_event(input, usage->type, usage->code, 0); in hidinput_hid_event()
1381 if ((*field)->usage[j].type == type && (*field)->usage[j].code == code) in hidinput_find_field()
1401 if (field->usage[j].type == EV_LED) in hidinput_get_led_field()
1422 if (field->usage[j].type == EV_LED && in hidinput_count_leds()
1522 struct hid_usage *usage; in report_features() local
1533 usage = &rep->field[i]->usage[j]; in report_features()
1536 if (usage->hid == HID_DC_BATTERYSTRENGTH) in report_features()
1541 drv->feature_mapping(hid, rep->field[i], usage); in report_features()
1729 report->field[i]->usage + j); in hidinput_configure_usages()
1756 if (IS_INPUT_APPLICATION(col->usage)) in hidinput_connect()