Man Pages (1MTSOL): Maintenance and Administration Commands
  Suchtext Nur in diesem Buch
Dieses Buch im PDF-Format herunterladen

NAME

add_drv - Add a new device driver to the system

SYNOPSIS

add_drv [ -b basedir ] [ -c class_name ] [ -i 'identify_name. . .' ] [ -m 'permission','. . .' ] [ -n ] [ -f ] [ -v ] device_driver

AVAILABILITY

SUNWcsu

DESCRIPTION

The add_drv command is used to inform the system about newly installed device drivers.
Each device on the system has a name associated with it. This name is represented by the name property for the device. Similarly, the device may also have a list of driver names associated with it. This list is represented by the compatible property for the device.
The system determines which devices will be managed by the driver being added by examining the contents of the name property and the compatible property (if it exists) on each device. If the value in the name property does not match the driver being added, each entry in the compatible property is tried, in order, until either a match occurs or there are no more entries in the compatible property.
In some cases, adding a new driver may require a reconfiguration boot. See NOTES .

OPTIONS

-b basedir
Set the path to the root directory of the diskless client. Used on the server to execute add_drv for a diskless client. The client machine must be rebooted to install the driver.
-c class_name
The driver being added to the system exports the class class_name.
-i 'identify_name'
A white-space-separated list of aliases for the driver device_driver
-m 'permission'
Specify the file system permissions for device nodes created by the system on behalf of device_driver.
-n
Do not try to load and attach device_driver; just modify the system configuration files for the device_driver.
-f
Normally if a reconfiguration boot is required to complete the configuration of the driver into the system, add_drv will not add the driver. The force flag forces add_drv to add the driver even if a reconfiguration boot is required. See the -v flag.
-v
The verbose flag causes add_drv to provide additional information regarding the success or failure of a driver's configuration into the system. See EXAMPLES .

EXAMPLES

The following example adds the SUNW,example driver to the system, with an alias name of SUNW,alias. This example assumes the driver has already been copied to
/usr/kernel/drv.

example# add_drv -m '* 0666 bin bin','a 0644 root sys' \
-i 'SUNW,alias' SUNW,example
Every minor node created by the system for the SUNW,example driver will have the permission 0666 and be owned by user bin in the group bin, except for the minor device a , which will be owned by root, group sys, and have a permission of 0644 .
The following example adds the driver to the client /export/root/sun1. The driver is installed and loaded when the client machine, sun1, is rebooted. This second example produces the same result as the first, except the changes are on the diskless client, sun1, and the client must be rebooted for the driver to be installed.
example# add_drv -m '* 0666 bin bin','a 0644 root sys' \
        -i 'SUNW,alias' -b /export/root/sun1 \
        SUNW,example

The following example illustrates the case in which a new driver is added for a device that is already managed by an existing driver. Consider a device that is currently managed by the driver dumb_framebuffer. These are name and compatible properties for this device:
        name="display"
        compatible="whizzy_framebuffer", "dumb_framebuffer"
If add_drv is used to add the whizzy_framebuffer driver, the following will result.
        example# add_drv whizzy_framebuffer
        Error: Could not install driver (whizzy_framebuffer)
        Device managed by another driver.
If the -v flag is specified, the following will result.
        example# add_drv -v whizzy_framebuffer
        Error: Could not install driver (whizzy_framebuffer)
        Device managed by another driver.

Driver installation failed because the following
        entries in /devices would be affected:

/devices/iommu@f,e0000000/sbus@f,e0001000/display[:* ]
            (Device currently managed by driver "dumb_framebuffer")

        The following entries in /dev would be affected:

/dev/fbs/dumb_framebuffer0
If the -v and -f flags are specified, the driver will be added resulting in the following:
        example# add_drv -vf whizzy_framebuffer

A reconfiguration boot must be performed to complete the
installation of this driver.

The following entries in /devices will be affected:

/devices/iommu@f,e0000000/sbus@f,e0001000/display[:* ]
    (Device currently managed by driver "dumb_framebuffer"

The following entries in /dev will be affected:
/dev/fbs/dumb_framebuffer0
This example is currently relevant only for devices exporting a generic device name.

EXIT STATUS

Upon success, add_drv returns 0 . Upon failure, add_drv returns 1 .

SUMMARY OF TRUSTED

To succeed, this command needs the sys_devices privilege. This command is intended to be invoked at ADMIN_LOW with effective user ID 0 ;if invoked by other users, the command needs the file_dac_write privilege.

SOLARIS CHANGES

FILES

/kernel/drv
Boot device drivers
/usr/kernel/drv
Other drivers that could potentially be shared between
platforms
/platform/`uname -i`/kernel/drv Platform-dependent drivers /etc/driver_aliases
Driver aliases file
/etc/driver_classes
Driver classes file
/etc/minor_perm
Minor node permissions
/etc/name_to_major
Major number binding

SEE ALSO

boot(1M), devlinks(1M), disks(1M), drvconfig(1M), kernel(1M), modinfo(1M), ports(1M), rem_drv(1M), tapes(1M), driver.conf(4), system(4), ddi_create_minor_node(9F)
Writing Device Drivers

NOTES

Aliases may require quoting (with double-quotes) if they contain numbers.
It is possible to add a driver for a device already being managed by a different driver, where the driver being added appears in the device's compatible list before the current driver. In such cases, a reconfiguration boot is required. [See boot(1M) and kernel(1M).] After the reconfiguration boot, device nodes in /devices, entries in /dev, and references to these files may no longer be valid (see -v option). If a reconfiguration boot would be required to complete the driver installation, add_drv will fail unless the -f option is specified. See the last example in EXAMPLES .

BUGS

add_drv will accept a full path name for device_driver. However, the kernel does not use the full path name; the kernel uses only the final component and searches the internal driver search path for the driver. Thus the kernel may load a different driver from the
one expected.
For this reason, do not use add_drv with a full path name. See kernel(1M) for more information on the driver search path.