Lines Matching full:pen
25 * uclogic_params_pen_inrange_to_str() - Convert a pen in-range reporting type
49 * uclogic_params_pen_hid_dbg() - Dump tablet interface pen parameters
50 * @hdev: The HID device the pen parameters describe.
51 * @pen: The pen parameters to dump.
53 * Dump tablet interface pen parameters with hid_dbg(). The dump is indented
57 const struct uclogic_params_pen *pen) in uclogic_params_pen_hid_dbg() argument
62 (pen->usage_invalid ? "true" : "false")); in uclogic_params_pen_hid_dbg()
63 hid_dbg(hdev, "\t.desc_ptr = %p\n", pen->desc_ptr); in uclogic_params_pen_hid_dbg()
64 hid_dbg(hdev, "\t.desc_size = %u\n", pen->desc_size); in uclogic_params_pen_hid_dbg()
65 hid_dbg(hdev, "\t.id = %u\n", pen->id); in uclogic_params_pen_hid_dbg()
67 for (i = 0; i < ARRAY_SIZE(pen->subreport_list); i++) { in uclogic_params_pen_hid_dbg()
69 pen->subreport_list[i].value, in uclogic_params_pen_hid_dbg()
70 pen->subreport_list[i].id, in uclogic_params_pen_hid_dbg()
71 i < (ARRAY_SIZE(pen->subreport_list) - 1) ? "," : ""); in uclogic_params_pen_hid_dbg()
75 uclogic_params_pen_inrange_to_str(pen->inrange)); in uclogic_params_pen_hid_dbg()
77 (pen->fragmented_hires ? "true" : "false")); in uclogic_params_pen_hid_dbg()
79 (pen->tilt_y_flipped ? "true" : "false")); in uclogic_params_pen_hid_dbg()
84 * @hdev: The HID device the pen parameters describe.
124 hid_dbg(hdev, ".pen = {\n"); in uclogic_params_hid_dbg()
125 uclogic_params_pen_hid_dbg(hdev, ¶ms->pen); in uclogic_params_hid_dbg()
203 * uclogic_params_pen (tablet interface's pen input parameters).
206 * @pen: Pen input parameters to cleanup. Cannot be NULL.
208 static void uclogic_params_pen_cleanup(struct uclogic_params_pen *pen) in uclogic_params_pen_cleanup() argument
210 kfree(pen->desc_ptr); in uclogic_params_pen_cleanup()
211 memset(pen, 0, sizeof(*pen)); in uclogic_params_pen_cleanup()
215 * uclogic_params_pen_init_v1() - initialize tablet interface pen
218 * @pen: Pointer to the pen parameters to initialize (to be
230 static int uclogic_params_pen_init_v1(struct uclogic_params_pen *pen, in uclogic_params_pen_init_v1() argument
241 /* Pen report descriptor template parameters */ in uclogic_params_pen_init_v1()
246 if (pen == NULL || pfound == NULL || hdev == NULL) { in uclogic_params_pen_init_v1()
252 * Read string descriptor containing pen input parameters. in uclogic_params_pen_init_v1()
260 "string descriptor with pen parameters not found, assuming not compatible\n"); in uclogic_params_pen_init_v1()
263 hid_err(hdev, "failed retrieving pen parameters: %d\n", rc); in uclogic_params_pen_init_v1()
267 …"string descriptor with pen parameters has invalid length (got %d, expected %d), assuming not comp… in uclogic_params_pen_init_v1()
297 * Generate pen report descriptor in uclogic_params_pen_init_v1()
311 memset(pen, 0, sizeof(*pen)); in uclogic_params_pen_init_v1()
312 pen->desc_ptr = desc_ptr; in uclogic_params_pen_init_v1()
314 pen->desc_size = uclogic_rdesc_v1_pen_template_size; in uclogic_params_pen_init_v1()
315 pen->id = UCLOGIC_RDESC_V1_PEN_ID; in uclogic_params_pen_init_v1()
316 pen->inrange = UCLOGIC_PARAMS_PEN_INRANGE_INVERTED; in uclogic_params_pen_init_v1()
343 * uclogic_params_pen_init_v2() - initialize tablet interface pen
346 * @pen: Pointer to the pen parameters to initialize (to be
368 static int uclogic_params_pen_init_v2(struct uclogic_params_pen *pen, in uclogic_params_pen_init_v2() argument
386 /* Pen report descriptor template parameters */ in uclogic_params_pen_init_v2()
391 if (pen == NULL || pfound == NULL || hdev == NULL) { in uclogic_params_pen_init_v2()
397 * Read string descriptor containing pen input parameters. in uclogic_params_pen_init_v2()
405 "string descriptor with pen parameters not found, assuming not compatible\n"); in uclogic_params_pen_init_v2()
408 hid_err(hdev, "failed retrieving pen parameters: %d\n", rc); in uclogic_params_pen_init_v2()
412 …"string descriptor with pen parameters is too short (got %d, expected at least %d), assuming not c… in uclogic_params_pen_init_v2()
430 "string descriptor with pen parameters seems to contain only text, assuming not compatible\n"); in uclogic_params_pen_init_v2()
457 * Generate pen report descriptor in uclogic_params_pen_init_v2()
471 memset(pen, 0, sizeof(*pen)); in uclogic_params_pen_init_v2()
472 pen->desc_ptr = desc_ptr; in uclogic_params_pen_init_v2()
474 pen->desc_size = uclogic_rdesc_v2_pen_template_size; in uclogic_params_pen_init_v2()
475 pen->id = UCLOGIC_RDESC_V2_PEN_ID; in uclogic_params_pen_init_v2()
476 pen->inrange = UCLOGIC_PARAMS_PEN_INRANGE_NONE; in uclogic_params_pen_init_v2()
477 pen->fragmented_hires = true; in uclogic_params_pen_init_v2()
478 pen->tilt_y_flipped = true; in uclogic_params_pen_init_v2()
655 uclogic_params_pen_cleanup(¶ms->pen); in uclogic_params_cleanup()
717 ADD_DESC(params->pen.desc_ptr, params->pen.desc_size); in uclogic_params_get_desc()
863 /* Keep everything intact, but mark pen usage invalid */ in uclogic_params_huion_init()
864 p.pen.usage_invalid = true; in uclogic_params_huion_init()
866 /* Else, if it's not a pen interface */ in uclogic_params_huion_init()
893 "transition firmware detected, not probing pen v2 parameters\n"); in uclogic_params_huion_init()
895 /* Try to probe v2 pen parameters */ in uclogic_params_huion_init()
896 rc = uclogic_params_pen_init_v2(&p.pen, &found, in uclogic_params_huion_init()
901 "failed probing pen v2 parameters: %d\n", rc); in uclogic_params_huion_init()
904 hid_dbg(hdev, "pen v2 parameters found\n"); in uclogic_params_huion_init()
918 /* Link from pen sub-report */ in uclogic_params_huion_init()
919 p.pen.subreport_list[0].value = 0xe0; in uclogic_params_huion_init()
920 p.pen.subreport_list[0].id = in uclogic_params_huion_init()
966 /* Link from pen sub-report */ in uclogic_params_huion_init()
967 p.pen.subreport_list[1].value = 0xf0; in uclogic_params_huion_init()
968 p.pen.subreport_list[1].id = in uclogic_params_huion_init()
988 /* Link from pen sub-report */ in uclogic_params_huion_init()
989 p.pen.subreport_list[2].value = 0xf1; in uclogic_params_huion_init()
990 p.pen.subreport_list[2].id = in uclogic_params_huion_init()
995 hid_dbg(hdev, "pen v2 parameters not found\n"); in uclogic_params_huion_init()
998 /* Try to probe v1 pen parameters */ in uclogic_params_huion_init()
999 rc = uclogic_params_pen_init_v1(&p.pen, &found, hdev); in uclogic_params_huion_init()
1002 "failed probing pen v1 parameters: %d\n", rc); in uclogic_params_huion_init()
1005 hid_dbg(hdev, "pen v1 parameters found\n"); in uclogic_params_huion_init()
1016 /* Link frame button subreports from pen reports */ in uclogic_params_huion_init()
1017 p.pen.subreport_list[0].value = 0xe0; in uclogic_params_huion_init()
1018 p.pen.subreport_list[0].id = in uclogic_params_huion_init()
1023 hid_dbg(hdev, "pen v1 parameters not found\n"); in uclogic_params_huion_init()
1041 * the XP-PEN Deco Mini 7, need to be initialized by sending them magic data.
1091 * pen and frame parameters returned by UGEE v2 devices.
1259 /* The XP-PEN Deco LW vendor, product and version are identical to the in uclogic_params_ugee_v2_has_battery()
1306 p->pen.subreport_list[1].value = 0xf2; in uclogic_params_ugee_v2_init_battery()
1307 p->pen.subreport_list[1].id = UCLOGIC_RDESC_UGEE_V2_BATTERY_ID; in uclogic_params_ugee_v2_init_battery()
1448 * Read the string descriptor containing pen and frame parameters. in uclogic_params_ugee_v2_init()
1454 hid_err(hdev, "failed retrieving pen and frame parameters: %d\n", rc); in uclogic_params_ugee_v2_init()
1469 /* Initialize the pen interface */ in uclogic_params_ugee_v2_init()
1479 p.pen.desc_ptr = rdesc_pen; in uclogic_params_ugee_v2_init()
1480 p.pen.desc_size = uclogic_rdesc_ugee_v2_pen_template_size; in uclogic_params_ugee_v2_init()
1481 p.pen.id = 0x02; in uclogic_params_ugee_v2_init()
1482 p.pen.subreport_list[0].value = 0xf0; in uclogic_params_ugee_v2_init()
1483 p.pen.subreport_list[0].id = UCLOGIC_RDESC_V1_FRAME_ID; in uclogic_params_ugee_v2_init()
1619 /* Try to probe v1 pen parameters */ in uclogic_params_init()
1620 rc = uclogic_params_pen_init_v1(&p.pen, in uclogic_params_init()
1624 "pen probing failed: %d\n", in uclogic_params_init()
1630 "pen parameters not found"); in uclogic_params_init()
1729 /* If this is the pen interface */ in uclogic_params_init()
1731 /* Probe v1 pen parameters */ in uclogic_params_init()
1732 rc = uclogic_params_pen_init_v1(&p.pen, &found, hdev); in uclogic_params_init()
1734 hid_err(hdev, "pen probing failed: %d\n", rc); in uclogic_params_init()
1738 hid_warn(hdev, "pen parameters not found"); in uclogic_params_init()
1747 /* If this is the pen and frame interface */ in uclogic_params_init()
1749 /* Probe v1 pen parameters */ in uclogic_params_init()
1750 rc = uclogic_params_pen_init_v1(&p.pen, &found, hdev); in uclogic_params_init()
1752 hid_err(hdev, "pen probing failed: %d\n", rc); in uclogic_params_init()
1787 /* Ignore non-pen interfaces */ in uclogic_params_init()
1793 rc = uclogic_params_pen_init_v1(&p.pen, &found, hdev); in uclogic_params_init()
1795 hid_err(hdev, "pen probing failed: %d\n", rc); in uclogic_params_init()
1814 hid_warn(hdev, "pen parameters not found"); in uclogic_params_init()
1821 /* Ignore non-pen interfaces */ in uclogic_params_init()
1827 rc = uclogic_params_pen_init_v1(&p.pen, &found, hdev); in uclogic_params_init()
1829 hid_err(hdev, "pen probing failed: %d\n", rc); in uclogic_params_init()
1844 hid_warn(hdev, "pen parameters not found"); in uclogic_params_init()