2 * ppp_mod.c - modload support for PPP pseudo-device driver.
4 * Copyright (c) 1994 Paul Mackerras. All rights reserved.
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
13 * 2. Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in
15 * the documentation and/or other materials provided with the
18 * 3. The name(s) of the authors of this software must not be used to
19 * endorse or promote products derived from this software without
20 * prior written permission.
22 * 4. Redistributions of any form whatsoever must retain the following
24 * "This product includes software developed by Paul Mackerras
25 * <paulus@samba.org>".
27 * THE AUTHORS OF THIS SOFTWARE DISCLAIM ALL WARRANTIES WITH REGARD TO
28 * THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
29 * AND FITNESS, IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY
30 * SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
31 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN
32 * AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING
33 * OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
35 * $Id: ppp_mod.c,v 1.4 2002/12/06 09:49:16 paulus Exp $
39 * This file is used under Solaris 2.
42 #include <sys/types.h>
43 #include <sys/param.h>
46 #include <sys/modctl.h>
47 #include <sys/sunddi.h>
48 #include <sys/ksynch.h>
56 static int ppp_identify
__P((dev_info_t
*));
57 static int ppp_attach
__P((dev_info_t
*, ddi_attach_cmd_t
));
58 static int ppp_detach
__P((dev_info_t
*, ddi_detach_cmd_t
));
59 static int ppp_devinfo
__P((dev_info_t
*, ddi_info_cmd_t
, void *, void **));
61 extern struct streamtab pppinfo
;
62 extern krwlock_t ppp_lower_lock
;
64 static dev_info_t
*ppp_dip
;
66 static struct cb_ops cb_ppp_ops
= {
67 nulldev
, nulldev
, nodev
, nodev
, /* cb_open, ... */
68 nodev
, nodev
, nodev
, nodev
, /* cb_dump, ... */
69 nodev
, nodev
, nodev
, nochpoll
, /* cb_devmap, ... */
70 ddi_prop_op
, /* cb_prop_op */
71 &pppinfo
, /* cb_stream */
72 D_NEW
|D_MP
|D_MTQPAIR
|D_MTOUTPERIM
|D_MTOCEXCL
/* cb_flag */
75 static struct dev_ops ppp_ops
= {
76 DEVO_REV
, /* devo_rev */
78 ppp_devinfo
, /* devo_getinfo */
79 ppp_identify
, /* devo_identify */
80 nulldev
, /* devo_probe */
81 ppp_attach
, /* devo_attach */
82 ppp_detach
, /* devo_detach */
83 nodev
, /* devo_reset */
84 &cb_ppp_ops
, /* devo_cb_ops */
85 NULL
/* devo_bus_ops */
89 * Module linkage information
92 static struct modldrv modldrv
= {
93 &mod_driverops
, /* says this is a pseudo driver */
94 "PPP-2.3 multiplexing driver",
95 &ppp_ops
/* driver ops */
98 static struct modlinkage modlinkage
= {
107 return mod_install(&modlinkage
);
113 return mod_remove(&modlinkage
);
120 return mod_info(&modlinkage
, mip
);
127 return strcmp(ddi_get_name(dip
), "ppp") == 0? DDI_IDENTIFIED
:
134 ddi_attach_cmd_t cmd
;
137 if (cmd
!= DDI_ATTACH
)
139 if (ddi_create_minor_node(dip
, "ppp", S_IFCHR
, 0, DDI_PSEUDO
, CLONE_DEV
)
141 ddi_remove_minor_node(dip
, NULL
);
144 rw_init(&ppp_lower_lock
, NULL
, RW_DRIVER
, NULL
);
151 ddi_detach_cmd_t cmd
;
153 rw_destroy(&ppp_lower_lock
);
154 ddi_remove_minor_node(dip
, NULL
);
159 ppp_devinfo(dip
, cmd
, arg
, result
)
169 case DDI_INFO_DEVT2DEVINFO
:
173 *result
= (void *) ppp_dip
;
175 case DDI_INFO_DEVT2INSTANCE
: