DRV_PRIV(9F) Kernel Functions for Drivers DRV_PRIV(9F)

NAME


drv_priv - determine driver privilege

SYNOPSIS


#include <sys/types.h>
#include <sys/cred.h>
#include <sys/ddi.h>


int drv_priv(cred_t *cr);


INTERFACE LEVEL


Architecture independent level 1 (DDI/DKI).

PARAMETERS


cr
Pointer to the user credential structure.


DESCRIPTION


The drv_priv() function provides a general interface to the system
privilege policy. It determines whether the credentials supplied by the
user credential structure pointed to by cr identify a process that has
the {PRIV_SYS_DEVICES} privilege asserted in its effective set. This
function should be used only when file access modes, special minor device
numbers, and the device policy (see privileges(7), add_drv(8)) are
insufficient to provide protection for the requested driver function. It
is intended to replace all calls to suser() and any explicit checks for
effective user ID = 0 in driver code.

RETURN VALUES


This routine returns 0 if it succeeds, EPERM if it fails.

CONTEXT


The drv_priv() function can be called from user, interrupt, or kernel
context.

SEE ALSO


privileges(7), add_drv(8), update_drv(8)


Writing Device Drivers

January 16, 2006 DRV_PRIV(9F)