1998-09-03 21:52:05 +00:00
|
|
|
.\" -*- nroff -*-
|
|
|
|
.\"
|
|
|
|
.\" Copyright (c) 1998 Doug Rabson
|
|
|
|
.\"
|
|
|
|
.\" All rights reserved.
|
|
|
|
.\"
|
|
|
|
.\" This program is free software.
|
|
|
|
.\"
|
|
|
|
.\" 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.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``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 DEVELOPERS 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-08-28 00:22:10 +00:00
|
|
|
.\" $FreeBSD$
|
1998-09-03 21:52:05 +00:00
|
|
|
.\"
|
|
|
|
.Dd June 16, 1998
|
|
|
|
.Dt DEVICE_PROBE 9
|
2001-07-10 15:31:11 +00:00
|
|
|
.Os
|
1998-09-03 21:52:05 +00:00
|
|
|
.Sh NAME
|
|
|
|
.Nm DEVICE_PROBE
|
|
|
|
.Nd probe for device existence
|
|
|
|
.Sh SYNOPSIS
|
|
|
|
.Fd #include <sys/param.h>
|
|
|
|
.Fd #include <sys/bus.h>
|
|
|
|
.Ft int
|
|
|
|
.Fn DEVICE_PROBE "device_t dev"
|
|
|
|
.Sh DESCRIPTION
|
1999-06-17 19:22:12 +00:00
|
|
|
This device method should probe to see if the device is present.
|
2000-11-22 16:11:48 +00:00
|
|
|
It should return 0 if the device exists,
|
|
|
|
.Er ENXIO
|
|
|
|
if it cannot be found.
|
2000-03-02 14:54:02 +00:00
|
|
|
If some other error happens during the probe (such as a memory
|
|
|
|
allocation failure), an appropriate error code should be returned.
|
|
|
|
For
|
1999-06-17 19:22:12 +00:00
|
|
|
cases where more than one driver matches a device, a priority value can
|
|
|
|
be returned. In this case, success codes are values less than or equal
|
|
|
|
to zero with the highest value representing the best match. Failure
|
|
|
|
codes are represented by positive values and the regular unix error
|
|
|
|
codes should be used for the purpose.
|
1998-09-03 21:52:05 +00:00
|
|
|
.Pp
|
1999-06-17 19:22:12 +00:00
|
|
|
If a driver returns a success code which is less than zero, it must
|
|
|
|
not assume that it will be the same driver which is attached to the
|
2000-03-02 14:54:02 +00:00
|
|
|
device.
|
|
|
|
In particular, it must not assume that any values stored in
|
1999-06-17 19:22:12 +00:00
|
|
|
the softc structure will be available for its attach method and any
|
|
|
|
resources allocated during probe must be released and re-allocated
|
2000-03-02 14:54:02 +00:00
|
|
|
if the attach method is called.
|
|
|
|
If a success code of zero is
|
1999-06-17 19:22:12 +00:00
|
|
|
returned, the driver can assume that it will be the one attached.
|
|
|
|
.Pp
|
|
|
|
Devices which implement busses should use this method to probe for
|
|
|
|
the existence of devices attached to the bus and add them as
|
2000-03-02 14:54:02 +00:00
|
|
|
children.
|
|
|
|
If this is combined with the use of
|
1998-09-03 21:52:05 +00:00
|
|
|
.Xr bus_generic_attach 9
|
|
|
|
the child devices will be automatically probed and attached.
|
|
|
|
.Sh RETURN VALUES
|
1999-06-17 19:22:12 +00:00
|
|
|
A value equal to or less than zero indicates success, greater than
|
|
|
|
zero indicates an error (errno). For values equal to or less than
|
|
|
|
zero: zero indicates highest priority, no further probing is done;
|
|
|
|
for a value less then zero, the lower the value the lower the
|
|
|
|
priority, e.g. -100 indicates a lower priority than -50.
|
1998-09-03 21:52:05 +00:00
|
|
|
.Sh SEE ALSO
|
|
|
|
.Xr device 9 ,
|
2001-03-10 19:53:38 +00:00
|
|
|
.Xr DEVICE_DETACH 9 ,
|
|
|
|
.Xr DEVICE_IDENTIFY 9 ,
|
|
|
|
.Xr DEVICE_PROBE 9 ,
|
|
|
|
.Xr DEVICE_SHUTDOWN 9
|
1998-09-03 21:52:05 +00:00
|
|
|
.Sh AUTHORS
|
|
|
|
This man page was written by
|
|
|
|
.An Doug Rabson .
|