2002-02-07 10:00:09 +03:00
|
|
|
.\" $NetBSD: usbhid.3,v 1.5 2002/02/07 07:00:52 ross Exp $
|
1999-05-12 01:02:24 +04:00
|
|
|
.\"
|
2001-12-29 02:06:02 +03:00
|
|
|
.\" Copyright (c) 1999, 2001 Lennart Augustsson <augustss@netbsd.org>
|
1999-05-12 01:02:24 +04:00
|
|
|
.\" All rights reserved.
|
|
|
|
.\"
|
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
.\" are met:
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
|
|
.\"
|
1999-05-12 01:15:46 +04:00
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
.\" ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
|
|
.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
.\" SUCH DAMAGE.
|
1999-05-12 01:02:24 +04:00
|
|
|
.\"
|
2001-12-29 02:06:02 +03:00
|
|
|
.Dd December 29, 2001
|
|
|
|
.Dt USBHID 3
|
1999-05-12 01:02:24 +04:00
|
|
|
.Os
|
|
|
|
.Sh NAME
|
2001-12-29 02:06:02 +03:00
|
|
|
.Nm usbhid ,
|
1999-05-18 03:47:27 +04:00
|
|
|
.Nm hid_get_report_desc ,
|
2000-09-24 06:13:24 +04:00
|
|
|
.Nm hid_use_report_desc ,
|
1999-05-18 03:47:27 +04:00
|
|
|
.Nm hid_dispose_report_desc ,
|
1999-05-12 04:04:49 +04:00
|
|
|
.Nm hid_start_parse ,
|
|
|
|
.Nm hid_end_parse ,
|
|
|
|
.Nm hid_get_item ,
|
|
|
|
.Nm hid_report_size ,
|
1999-11-09 01:33:40 +03:00
|
|
|
.Nm hid_locate ,
|
1999-05-18 03:47:27 +04:00
|
|
|
.Nm hid_usage_page ,
|
|
|
|
.Nm hid_usage_in_page ,
|
|
|
|
.Nm hid_init ,
|
|
|
|
.Nm hid_get_data ,
|
|
|
|
.Nm hid_set_data
|
1999-05-12 01:02:24 +04:00
|
|
|
.Nd USB HID access routines
|
|
|
|
.Sh LIBRARY
|
2001-12-29 02:06:02 +03:00
|
|
|
.Lb libusbhid
|
1999-05-12 01:02:24 +04:00
|
|
|
.Sh SYNOPSIS
|
2002-02-07 10:00:09 +03:00
|
|
|
.Fd #include \*[Lt]usbhid.h\*[Gt]
|
1999-05-12 04:04:49 +04:00
|
|
|
.Ft report_desc_t
|
1999-05-18 03:47:27 +04:00
|
|
|
.Fn hid_get_report_desc "int file"
|
2000-09-24 06:13:24 +04:00
|
|
|
.Ft report_desc_t
|
|
|
|
.Fn hid_use_report_desc "unsigned char *data" "unsigned int size"
|
1999-05-12 04:04:49 +04:00
|
|
|
.Ft void
|
1999-05-18 03:47:27 +04:00
|
|
|
.Fn hid_dispose_report_desc "report_desc_t d"
|
1999-05-12 04:04:49 +04:00
|
|
|
.Ft hid_data_t
|
2001-12-28 20:45:25 +03:00
|
|
|
.Fn hid_start_parse "report_desc_t d" "int kindset" "int id"
|
1999-05-12 04:04:49 +04:00
|
|
|
.Ft void
|
|
|
|
.Fn hid_end_parse "hid_data_t s"
|
|
|
|
.Ft int
|
|
|
|
.Fn hid_get_item "hid_data_t s" "hid_item_t *h"
|
|
|
|
.Ft int
|
2001-12-28 20:45:25 +03:00
|
|
|
.Fn hid_report_size "report_desc_t d" "hid_kind_t k" "int id"
|
1999-05-12 04:04:49 +04:00
|
|
|
.Ft int
|
2001-12-28 20:45:25 +03:00
|
|
|
.Fn hid_locate "report_desc_t d" "u_int usage" "hid_kind_t k" "hid_item_t *h" "int id"
|
1999-05-12 04:04:49 +04:00
|
|
|
.Ft char *
|
1999-05-18 03:47:27 +04:00
|
|
|
.Fn hid_usage_page "int i"
|
1999-05-12 04:04:49 +04:00
|
|
|
.Ft char *
|
1999-05-18 03:47:27 +04:00
|
|
|
.Fn hid_usage_in_page "u_int u"
|
2000-09-24 06:17:52 +04:00
|
|
|
.Ft int
|
|
|
|
.Fn hid_parse_usage_page "const char *"
|
|
|
|
.Ft char *
|
|
|
|
.Fn hid_parse_usage_in_page "const char *"
|
1999-05-12 04:04:49 +04:00
|
|
|
.Ft void
|
1999-05-18 03:47:27 +04:00
|
|
|
.Fn hid_init "char *file"
|
1999-05-12 04:04:49 +04:00
|
|
|
.Ft int
|
1999-05-18 03:47:27 +04:00
|
|
|
.Fn hid_get_data "void *data" "hid_item_t *h"
|
1999-05-12 04:04:49 +04:00
|
|
|
.Ft void
|
1999-05-18 03:47:27 +04:00
|
|
|
.Fn hid_set_data "void *data" "hid_item_t *h" "u_int data"
|
1999-05-12 01:02:24 +04:00
|
|
|
.Sh DESCRIPTION
|
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
library provides routines to extract data from USB Human Interface Devices.
|
1999-11-09 01:19:17 +03:00
|
|
|
.Ss INTRODUCTION
|
2000-02-22 15:39:22 +03:00
|
|
|
USB HID devices send and receive data layed out in a device dependent
|
1999-05-12 04:04:49 +04:00
|
|
|
way. The
|
|
|
|
.Nm
|
|
|
|
library contains routines to extract the
|
|
|
|
.Em report descriptor
|
|
|
|
which contains the data layout information and then use this information.
|
|
|
|
.Pp
|
1999-07-24 05:42:49 +04:00
|
|
|
The routines can be divided into four parts: extraction of the descriptor,
|
1999-05-12 04:04:49 +04:00
|
|
|
parsing of the descriptor, translating to/from symbolic names, and
|
|
|
|
data manipulation.
|
1999-11-09 01:19:17 +03:00
|
|
|
.Ss DESCRIPTOR FUNCTIONS
|
1999-05-12 04:04:49 +04:00
|
|
|
A report descriptor can be obtained by calling
|
1999-05-18 03:47:27 +04:00
|
|
|
.Fn hid_get_report_desc
|
1999-05-12 04:04:49 +04:00
|
|
|
with a file descriptor obtained by opening a
|
|
|
|
.Xr uhid 4
|
2000-09-24 06:13:24 +04:00
|
|
|
device. Alternatively a data buffer containing the report descriptor can be
|
|
|
|
passed into
|
|
|
|
.Fn hid_use_report_desc .
|
|
|
|
The data is copied into an internal structure. When the report descriptor
|
|
|
|
is no longer needed it should be freed by calling
|
1999-05-18 03:47:27 +04:00
|
|
|
.Fn hid_dispose_report_desc .
|
1999-07-02 19:46:05 +04:00
|
|
|
The type
|
1999-05-12 04:04:49 +04:00
|
|
|
.Fa report_desc_t
|
|
|
|
is opaque and should be used when calling the parsing functions.
|
2000-09-24 06:13:24 +04:00
|
|
|
If
|
|
|
|
.Fn hid_dispose_report_desc
|
|
|
|
fails it will return
|
|
|
|
.Fa NULL .
|
1999-11-09 01:19:17 +03:00
|
|
|
.Ss DESCRIPTOR PARSING FUNCTIONS
|
1999-05-12 04:04:49 +04:00
|
|
|
To parse the report descriptor the
|
|
|
|
.Fn hid_start_parse
|
|
|
|
function should be called with a report descriptor and a set that
|
|
|
|
describes which items that are interesting. The set is obtained
|
2000-02-22 15:39:22 +03:00
|
|
|
by or-ing together values
|
2002-02-07 10:00:09 +03:00
|
|
|
.Fa "(1 \*[Lt]\*[Lt] k)"
|
1999-05-12 04:04:49 +04:00
|
|
|
where
|
|
|
|
.Fa k
|
1999-07-02 19:46:05 +04:00
|
|
|
is an item of type
|
1999-05-12 04:04:49 +04:00
|
|
|
.Fa hid_kind_t .
|
2001-12-28 20:45:25 +03:00
|
|
|
The report id (if present) is given by
|
|
|
|
.Fa id .
|
1999-05-12 04:04:49 +04:00
|
|
|
The function returns
|
|
|
|
.Fa NULL
|
|
|
|
if the initialization fails, otherwise an opaque value to be used
|
|
|
|
in subsequent calls.
|
|
|
|
After parsing the
|
|
|
|
.Fn hid_end_parse
|
|
|
|
function should be called to free internal data structures.
|
|
|
|
.Pp
|
|
|
|
To iterate through all the items in the report descriptor
|
|
|
|
.Fn hid_get_item
|
|
|
|
should be called while it returns a value greater than 0.
|
|
|
|
When the report descriptor ends it will returns 0; a syntax
|
|
|
|
error within the report descriptor will cause a return value less
|
|
|
|
than 0.
|
|
|
|
The struct pointed to by
|
|
|
|
.Fa h
|
|
|
|
will be filled with the relevant data for the item.
|
1999-07-02 19:46:05 +04:00
|
|
|
The definition of
|
1999-05-12 04:14:58 +04:00
|
|
|
.Fa hid_item_t
|
|
|
|
can be found in
|
2002-02-07 10:00:09 +03:00
|
|
|
.Pa \*[Lt]usbhid.h\*[Gt]
|
1999-05-12 04:14:58 +04:00
|
|
|
and the meaning of the components in the USB HID documentation.
|
1999-05-12 04:04:49 +04:00
|
|
|
.Pp
|
1999-07-24 05:42:49 +04:00
|
|
|
Data should be read/written to the device in the size of
|
1999-05-12 04:04:49 +04:00
|
|
|
the report. The size of a report (of a certain kind) can be
|
|
|
|
computed by the
|
|
|
|
.Fn hid_report_size
|
|
|
|
function. If the report is prefixed by an ID byte it is
|
2001-12-28 20:45:25 +03:00
|
|
|
given by
|
|
|
|
.Fa id .
|
1999-05-12 04:04:49 +04:00
|
|
|
.Pp
|
|
|
|
To locate a single item the
|
|
|
|
.Fn hid_locate
|
|
|
|
function can be used. It should be given the usage code of
|
|
|
|
the item and its kind and it will fill the item and return
|
|
|
|
non-zero if the item was found.
|
1999-11-09 01:19:17 +03:00
|
|
|
.Ss NAME TRANSLATION FUNCTIONS
|
1999-05-12 04:04:49 +04:00
|
|
|
The function
|
1999-05-18 03:47:27 +04:00
|
|
|
.Fn hid_usage_page
|
1999-05-12 04:04:49 +04:00
|
|
|
will return the symbolic name of a usage page, and the function
|
1999-05-18 03:47:27 +04:00
|
|
|
.Fn hid_usage_in_page
|
1999-05-12 04:04:49 +04:00
|
|
|
will return the symbolic name of the usage within the page.
|
|
|
|
Both these functions may return a pointer to static data.
|
2000-09-24 06:17:52 +04:00
|
|
|
.Pp
|
|
|
|
The functions
|
|
|
|
.Fn hid_parse_usage_page
|
|
|
|
and
|
|
|
|
.Fn hid_parse_usage_in_page
|
|
|
|
are the inverses of
|
|
|
|
.Fn hid_usage_page
|
|
|
|
and
|
|
|
|
.Fn hid_usage_in_page .
|
|
|
|
They take a usage string and return the number of the usage, or -1
|
|
|
|
if it cannot be found.
|
|
|
|
.Pp
|
|
|
|
Before any of these functions can be called the usage table
|
1999-07-24 05:42:49 +04:00
|
|
|
must be parsed, this is done by calling
|
1999-05-18 03:47:27 +04:00
|
|
|
.Fn hid_init
|
1999-05-12 04:04:49 +04:00
|
|
|
with the name of the table. Passing
|
|
|
|
.Fa NULL
|
|
|
|
to this function will cause it to use the default table.
|
1999-11-09 01:19:17 +03:00
|
|
|
.Ss DATA EXTRACTION FUNCTIONS
|
1999-05-12 04:04:49 +04:00
|
|
|
Given the data obtained from a HID device and an item in the
|
|
|
|
report descriptor the
|
1999-05-18 03:47:27 +04:00
|
|
|
.Fn hid_get_data
|
1999-05-12 04:04:49 +04:00
|
|
|
function extracts the value of the item.
|
|
|
|
Conversely
|
1999-05-18 03:47:27 +04:00
|
|
|
.Fn hid_set_data
|
1999-05-12 04:04:49 +04:00
|
|
|
can be used to put data into a report (which must be zeroed first).
|
|
|
|
.Sh FILES
|
|
|
|
.Pa /usr/share/misc/usb_hid_usages
|
|
|
|
The default HID usage table.
|
2001-12-29 02:06:02 +03:00
|
|
|
.\" .Sh EXAMPLES
|
1999-05-12 01:02:24 +04:00
|
|
|
.Sh SEE ALSO
|
1999-07-02 19:46:05 +04:00
|
|
|
The
|
|
|
|
.Tn USB
|
1999-05-12 04:14:58 +04:00
|
|
|
specifications can be found at
|
2002-01-19 03:08:17 +03:00
|
|
|
.Dv http://www.usb.org/developers/docs.html .
|
1999-05-12 04:14:58 +04:00
|
|
|
.Pp
|
2002-01-13 01:22:55 +03:00
|
|
|
.Xr uhid 4 ,
|
2000-07-05 19:45:28 +04:00
|
|
|
.Xr usb 4
|
1999-05-12 01:02:24 +04:00
|
|
|
.Sh HISTORY
|
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
library first appeared in
|
2001-12-29 02:06:02 +03:00
|
|
|
.Nx 1.5
|
|
|
|
as
|
|
|
|
.Nm usb
|
|
|
|
library
|
|
|
|
and was renamed to
|
|
|
|
.Nm
|
|
|
|
for
|
|
|
|
.Nx 1.6 .
|
|
|
|
.Sh BUGS
|
|
|
|
This man page is woefully incomplete.
|