| 
|  | cfgmgr_set_status(9r)Contents |  
        cfgmgr_set_status - General: Reports failure to the cfgmgr
       framework
       int cfgmgr_set_status(
               char *driver_name );
       Specifies the name of the device driver for which you want
       to  report  an  associated  failure. This name is a string
       that matches the string you specified for  the  entry_name
       item  in the /etc/sysconfigtab database. Typically, thirdparty
 driver writers specify the driver name (followed  by
       a  colon)  in  the  sysconfigtab file fragment, which gets
       appended to  the  /etc/sysconfigtab  database  during  the
       driver product installation.
       The cfgmgr_set_status routine reports to the cfgmgr framework
 that a failure has occurred during static  configuration.
   If  the  specified  device driver is in the static
       configuration state, it does not know that the  configuration
  operation  is  complete  until all register callback
       requests (routines) have  successfully  completed.  Therefore,
  a device driver calls cfgmgr_set_status to report a
       possible failure during static configuration to the cfgmgr
       framework.
       Specifically,  cfgmgr_set_status  performs  the  following
       failure operations: Adjusts the  state  of  the  specified
       device  driver  Unconfigures  the  specified device driver
       from the cfgmgr framework
       The cfgmgr_set_status routine calls  the  device  driver's
       configure routine at its CFG_OP_UNCONFIGURE entry point as
       part of these failure operations. The code associated with
       the  CFG_OP_UNCONFIGURE  entry  point  is  responsible for
       determining how to deallocate any allocated resources during
 these failure operations.
       The cfgmgr_set_status routine does not notify the operator
       of a configuration failure. Part of  the  code  associated
       with  the  CFG_OP_UNCONFIGURE entry point could include an
       error logging operation to record the fact that a  failure
       has occurred. The reason for doing this is that the cfgmgr
       framework's task is to accomplish the  unconfigure  operation
 of a statically configured device driver.
       You  call  the  cfgmgr_set_status  routine  in  the device
       driver's callback routine when  the  static  configuration
       operation fails.  You register a callback routine by calling
 the register_callback routine.
       Upon successful completion, cfgmgr_set_status returns  the
       value  ESUCCESS.  This  success  value indicates that cfgmgr_set_status
 adjusted the state of the device driver and
       caused  the  cfgmgr  framework  to unconfigure the driver.
       Otherwise, cfgmgr_set_status returns one of the  following
       error  constants  defined  in /usr/sys/include/sys/sysconfig.h
 and /usr/sys/include/sys/errno.h: The device  driver
       that  you  specified  in the driver_name argument does not
       exist. In this case, cfgmgr_set_status cannot  adjust  the
       state  and  unconfigure  the  device  driver.   The device
       driver that you specified in the driver_name argument  was
       not  statically  configured.   The  device driver that you
       specified in the driver_name argument is not in the static
       configuration state.
       See Writing Device Drivers: Tutorial for a code example of
       the cfgmgr_set_status interface.
       Routines: cfgmgr_get_state(9r), register_callback(9r)
                                            cfgmgr_set_status(9r)
[ Back ] |