xref: /illumos-gate/usr/src/man/man9e/usba_hcdi_cb_ops.9e (revision 7f3d7c9289dee6488b3cd2848a68c0b8580d750c)
1.\"
2.\" This file and its contents are supplied under the terms of the
3.\" Common Development and Distribution License ("CDDL"), version 1.0.
4.\" You may only use this file in accordance with the terms of version
5.\" 1.0 of the CDDL.
6.\"
7.\" A full copy of the text of the CDDL should have accompanied this
8.\" source.  A copy of the CDDL is also available via the Internet at
9.\" http://www.illumos.org/license/CDDL.
10.\"
11.\"
12.\" Copyright 2016 Joyent, Inc.
13.\"
14.Dd August 22, 2023
15.Dt USBA_HCDI_CB_OPS 9E
16.Os
17.Sh NAME
18.Nm usba_hcdi_cb_ops ,
19.Nm usba_hcdi_cb_open ,
20.Nm usba_hcdi_cb_ioctl ,
21.Nm usba_hcdi_cb_close
22.Nd USBA HCD Character Device character functions
23.Sh SYNOPSIS
24.In sys/types.h
25.In sys/file.h
26.In sys/errno.h
27.In sys/open.h
28.In sys/cred.h
29.In sys/ddi.h
30.In sys/sunddi.h
31.Ft int
32.Fo prefix_open
33.Fa "dev_t *devp"
34.Fa "int flag"
35.Fa "int otyp"
36.Fa "cred_t *credp"
37.Fc
38.Ft int
39.Fo prefix_ioctl
40.Fa "dev_t dev"
41.Fa "int cmd"
42.Fa "intptr_t arg"
43.Fa "int mode"
44.Fa "cred_t *cred_p"
45.Fa "int *rval_p"
46.Fc
47.Ft int
48.Fo prefix_close
49.Fa "dev_t dev"
50.Fa "int flag"
51.Fa "int otyp"
52.Fa "cred_t *cred_p"
53.Fc
54.Sh INTERFACE LEVEL
55.Sy Volatile -
56illumos USB HCD private function
57.Pp
58This describes private interfaces that are not part of the stable DDI.
59This may be removed or changed at any time.
60.Sh PARAMETERS
61For parameter descriptions, see
62.Xr open 9E ,
63.Xr ioctl 9E ,
64and
65.Xr close 9E .
66.Sh DESCRIPTION
67The entry points listed here are the traditional character device
68.Xr open 9E ,
69.Xr ioctl 9E ,
70and
71.Xr close 9E
72entry points.
73As discussed in
74.Xr usba_hcdi 9E
75all HCD drivers are required to implement these functions and vector
76them to
77.Xr usba_hubdi_open 9F ,
78.Xr usba_hubdi_ioctl 9F ,
79and
80.Xr usba_hubdi_close 9F
81respectively.
82For background information on these functions and how they interact in the
83broader operating system, please see the general manual pages
84.Xr open 9E ,
85.Xr ioctl 9E ,
86and
87.Xr close 9E .
88.Pp
89The arguments between the two types of functions are slightly different.
90The
91.Sx EXAMPLES
92section provides a sketch for how most HCD drivers should perform those
93transformations.
94.Pp
95One important distinction from the traditional character routines is
96that the USBA controls a bit more of the minor space.
97Therefore, the driver needs to take extra care around the values encoded in the
98.Sy dev_t
99and it should not perform any cloning or renumbering in its
100.Xr open 9E
101entry point.
102.Sh EXAMPLES
103The following example is adapted from the
104.Xr xhci 4D
105driver which shows how an HCD driver might arrange things.
106This assumes that a driver is following the recommendations in
107.Xr usba_hcdi 9E
108and has initialized a soft state structure through the
109.Xr ddi_soft_state_init 9F
110function.
111This design also requires that the soft state structure contains a pointer to
112the
113.Sy dev_info_t
114structure during its
115.Xr attach 9E callback.
116.Pp
117This example does not stand alone, it will need to be adapted for a
118driver:
119.Bd -literal
120#include <sys/types.h>
121#include <sys/file.h>
122#include <sys/errno.h>
123#include <sys/open.h>
124#include <sys/cred.h>
125#include <sys/ddi.h>
126#include <sys/sunddi.h>
127
128static void *prefix_soft_state;
129
130/*
131 * Per-instance structure
132 */
133typedef struct prefix {
134	dev_info_t	*prefix_dev_info;
135	...
136} prefix_t;
137
138static dev_info_t *
139prefix_get_dip(dev_t dev)
140{
141	prefix_t *p;
142	int instance = getminor(dev) & ~HUBD_IS_ROOT_HUB;
143
144	p = ddi_get_soft_state(prefix_soft_state, instance);
145	if (p != NULL)
146		return (p->prefix_dip);
147	return (NULL);
148}
149
150static int
151prefix_open(dev_t *devp, int flags, int otyp, cred_t *credp)
152{
153	dev_info_t *dip = prefix_get_dip(*devp);
154
155	return (usba_hubdi_open(dip, devp, flags, otyp, credp));
156}
157
158static int
159prefix_ioctl(dev_t dev, int cmd, intptr_t arg, int mode, cred_t *credp,
160    int *rvalp)
161{
162	dev_info_t *dip = prefix_get_dip(dev);
163
164	/* Potentially handle private ioctls */
165
166	return (usba_hubdi_ioctl(dip, dev, cmd, arg, mode, credp, rvalp));
167}
168
169static int
170prefix_close(dev_t dev, int flag, int otyp, cred_t *credp)
171{
172	dev_info_t *dip = prefix_get_dip(dev);
173
174	return (usba_hubdi_close(dip, dev, flag, otyp, credp));
175}
176
177static int
178prefix_attach(dev_info_t *dip, ddi_attach_cmd_t cmd)
179{
180	int instance;
181	prefix_t *p;
182
183	/* Perform normal checking of cmd */
184
185	instance = ddi_get_instance(dip);
186	if (ddi_soft_state_zalloc(prefix_soft_state, inst) != 0)
187		return (DDI_FAILURE);
188	p = ddi_get_soft_state(prefix_soft_state, instance);
189	p->prefix_dev_info = dip;
190
191	/* Continue with normal attach(9E) initialization */
192}
193
194int
195_init(void)
196{
197	int ret;
198
199	if ((ret = ddi_soft_state_init(&prefx_soft_state, sizeof (prefx_t),
200	    0)) != 0) {
201		return (ret);
202	}
203
204	/* Perform normal module initialization here */
205
206	return (ret);
207}
208
209int
210_fini(void)
211{
212
213	/* Perform normal module teardown first */
214
215	ddi_soft_state_fini(&prefix_soft_state);
216
217	return (0);
218}
219.Ed
220.Sh SEE ALSO
221.Xr xhci 4D ,
222.Xr attach 9E ,
223.Xr close 9E ,
224.Xr ioctl 9E ,
225.Xr open 9E ,
226.Xr usba_hcdi 9E ,
227.Xr ddi_soft_state_init 9F ,
228.Xr usba_hubdi_close 9F ,
229.Xr usba_hubdi_ioctl 9F ,
230.Xr usba_hubdi_open 9F
231