xref: /openbsd/lib/libusbhid/descr.c (revision be68eabd)
1*be68eabdSjcs /*	$OpenBSD: descr.c,v 1.8 2021/05/30 19:54:52 jcs Exp $	*/
27517eab2Snate /*	$NetBSD: descr.c,v 1.2 2002/02/20 20:31:07 christos Exp $	*/
3be8f1931Spvalchev 
4be8f1931Spvalchev /*
5be8f1931Spvalchev  * Copyright (c) 1999 Lennart Augustsson <augustss@netbsd.org>
6be8f1931Spvalchev  * All rights reserved.
7be8f1931Spvalchev  *
8be8f1931Spvalchev  * Redistribution and use in source and binary forms, with or without
9be8f1931Spvalchev  * modification, are permitted provided that the following conditions
10be8f1931Spvalchev  * are met:
11be8f1931Spvalchev  * 1. Redistributions of source code must retain the above copyright
12be8f1931Spvalchev  *    notice, this list of conditions and the following disclaimer.
13be8f1931Spvalchev  * 2. Redistributions in binary form must reproduce the above copyright
14be8f1931Spvalchev  *    notice, this list of conditions and the following disclaimer in the
15be8f1931Spvalchev  *    documentation and/or other materials provided with the distribution.
16be8f1931Spvalchev  *
17be8f1931Spvalchev  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
18be8f1931Spvalchev  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19be8f1931Spvalchev  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20be8f1931Spvalchev  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
21be8f1931Spvalchev  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22be8f1931Spvalchev  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23be8f1931Spvalchev  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24be8f1931Spvalchev  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25be8f1931Spvalchev  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26be8f1931Spvalchev  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27be8f1931Spvalchev  * SUCH DAMAGE.
28be8f1931Spvalchev  */
29be8f1931Spvalchev 
30be8f1931Spvalchev #include <sys/types.h>
31be8f1931Spvalchev 
32be8f1931Spvalchev #include <errno.h>
33be8f1931Spvalchev #include <stdlib.h>
34be8f1931Spvalchev #include <string.h>
35be8f1931Spvalchev #include <unistd.h>
36be8f1931Spvalchev #include <sys/time.h>
37be8f1931Spvalchev 
38be8f1931Spvalchev #include <dev/usb/usb.h>
39be8f1931Spvalchev 
40be8f1931Spvalchev #include "usbhid.h"
41be8f1931Spvalchev #include "usbvar.h"
42be8f1931Spvalchev 
43be8f1931Spvalchev report_desc_t
hid_get_report_desc(int fd)44be8f1931Spvalchev hid_get_report_desc(int fd)
45be8f1931Spvalchev {
46be8f1931Spvalchev 	struct usb_ctl_report_desc rep;
47be8f1931Spvalchev 
48674f1e1fSjasper 	rep.ucrd_size = 0;
49df69c215Sderaadt 	if (ioctl(fd, USB_GET_REPORT_DESC, &rep) == -1)
50be8f1931Spvalchev 		return (NULL);
51be8f1931Spvalchev 
529f9e15b2Snate 	return hid_use_report_desc(rep.ucrd_data, (unsigned int)rep.ucrd_size);
53be8f1931Spvalchev }
54be8f1931Spvalchev 
55be8f1931Spvalchev report_desc_t
hid_use_report_desc(unsigned char * data,unsigned int size)56be8f1931Spvalchev hid_use_report_desc(unsigned char *data, unsigned int size)
57be8f1931Spvalchev {
58be8f1931Spvalchev 	report_desc_t r;
59be8f1931Spvalchev 
60be8f1931Spvalchev 	r = malloc(sizeof(*r) + size);
6178e5c336Sderaadt 	if (r == NULL)
62be8f1931Spvalchev 		return (NULL);
63be8f1931Spvalchev 	r->size = size;
64be8f1931Spvalchev 	memcpy(r->data, data, size);
65be8f1931Spvalchev 	return (r);
66be8f1931Spvalchev }
67be8f1931Spvalchev 
68be8f1931Spvalchev void
hid_dispose_report_desc(report_desc_t r)69be8f1931Spvalchev hid_dispose_report_desc(report_desc_t r)
70be8f1931Spvalchev {
71be8f1931Spvalchev 
72be8f1931Spvalchev 	free(r);
73be8f1931Spvalchev }
74*be68eabdSjcs 
75*be68eabdSjcs void
hid_get_report_desc_data(report_desc_t d,uint8_t ** data,uint32_t * size)76*be68eabdSjcs hid_get_report_desc_data(report_desc_t d, uint8_t **data, uint32_t *size)
77*be68eabdSjcs {
78*be68eabdSjcs 	*data = d->data;
79*be68eabdSjcs 	*size = d->size;
80*be68eabdSjcs }
81