DRV_GETPARM(9F) Kernel Functions for Drivers DRV_GETPARM(9F)
NAME
drv_getparm - retrieve kernel state information
SYNOPSIS
#include <sys/ddi.h>
int drv_getparm(
unsigned int parm,
void *value_p);
INTERFACE LEVEL
Architecture independent level 1 (DDI/DKI).
PARAMETERS
parm The kernel parameter to be obtained. Possible values are:
LBOLT Read the value of
lbolt.
lbolt is a
clock_t that is
unconditionally incremented by one at each clock tick. No
special treatment is applied when this value overflows the
maximum value of the signed integral type
clock_t. When this
occurs, its value will be negative, and its magnitude will be
decreasing until it again passes zero. It can therefore not be
relied upon to provide an indication of the amount of time that
passes since the last system reboot, nor should it be used to
mark an absolute time in the system. Only the difference
between two measurements of
lbolt is significant. It is used in
this way inside the system kernel for timing purposes.
PPGRP Read the process group identification number. This number
determines which processes should receive a
HANGUP or
BREAK signal when detected by a driver.
UPROCP Read the process table token value.
PPID Read process identification number.
PSID Read process session identification number.
TIME Read time in seconds.
UCRED Return a pointer to the caller's credential structure.
value_p A pointer to the data space in which the value of the
parameter is to be copied.
DESCRIPTION
Since the release of the Solaris 2.6 operating environment, the
drv_getparm() function has been replaced by
ddi_get_lbolt(9F),
ddi_get_time(9F), and
ddi_get_pid(9F).
The
drv_getparm() function verifies that
parm corresponds to a kernel
parameter that may be read. If the value of
parm does not correspond to a
parameter or corresponds to a parameter that may not be read,
-1 is
returned. Otherwise, the value of the parameter is stored in the data
space pointed to by
value_p.
The
drv_getparm() function does not explicitly check to see whether the
device has the appropriate context when the function is called and the
function does not check for correct alignment in the data space pointed
to by
value_p. It is the responsibility of the driver writer to use this
function only when it is appropriate to do so and to correctly declare
the data space needed by the driver.
RETURN VALUES
The
drv_getparm() function returns
0 to indicate success,
-1 to indicate
failure. The value stored in the space pointed to by
value_p is the value
of the parameter if
0 is returned, or undefined if
-1 is returned.
-1 is
returned if you specify a value other than
LBOLT,
PPGRP,
PPID,
PSID,
TIME,
UCRED, or
UPROCP. Always check the return code when using this
function.
CONTEXT
The
drv_getparm() function can be called from user context only when
using
PPGRP,
PPID,
PSID,
UCRED, or
UPROCP. It can be called from user,
interrupt, or kernel context when using the
LBOLT or
TIME argument.
SEE ALSO
ddi_get_lbolt(9F),
ddi_get_pid(9F),
ddi_get_time(9F),
buf(9S) Writing Device Drivers November 26, 2017
DRV_GETPARM(9F)