Index Index for
Section 9r
Index Alphabetical
listing for C
Bottom of page Bottom of
page

cfg_reconfigure(9r)

NAME

cfg_reconfigure - General: Reconfigures the attribute values for a kernel subsystem

SYNOPSIS

#include <sys/sysconfig.h> ); cfg_status_t cfg_reconfigure( char *subsys, cfg_attr_t *attributes, uint nattributes );

ARGUMENTS

subsys Specifies the name of the subsystem to be reconfigured. attributes Specifies the name of the array containing a list of attribute names and their new values. The array must have (nattributes + 1) cfg_attr_t structures, with the attribute name of the last one being set to a null string. nattributes Specifies the number of attributes whose values you are changing.

DESCRIPTION

The cfg_reconfigure( ) routine is used to modify attribute values for a subsystem. The modifications made by this routine take effect immediately because they are made to the in-memory copy of the subsystem. Neither the kernel nor the subsystem stores a copy of the modifications, so if the system is rebooted or the subsystem is unconfigured, the modifications are lost. When the subsystem is again configured into the kernel, the value of its attributes are retrieved from the /etc/sysconfigtab database and the subsystem code. To make permanent changes to attribute values, store the new attribute values in the /etc/sysconfigtab database. See the sysconfigtab(4) reference page for information about the database. When your application calls the cfg_reconfigure( ) routine, it passes a list of attribute names and values. The application passes this information in an array of structures of type cfg_attr_t. For information about this structure, see the cfg_subsys_reconfig(3) reference page.

RETURN VALUES

This routine returns 32-bit values composed of subsystem status and framework status segments. The upper 16 bits is the subsystem status (CFG_STATUS_SUBSYS) and the lower 16 bits is the frame status (CFG_STATUS_FRAME). The return values are organized as follows: [Upper subsystem 16 bits][Lower framework 16 bits] The subsystem status is returned by the subsystem's configure routine and can be any error in errno.h. The framework status is returned by the configuration framework and the possible values are defined in <sys/sysconfig.h> as CFG_FRAME_Exxx. A successful operation has ESUCCESS (0) returned in both status segments. See the cfg_errno(9r) and errno(2) reference pages for more details about error numbers and status.

EXAMPLE

A subsystem may be reconfigured using the cfg_reconfigure kernel routine as follows: cfg_attr_t attributes[2]; cfg_status_t retval; int i; int nattributes; /*****************************************************/ /* Initialize attribute names for the request */ strcpy (attributes[0].name, "maxmounts"); attributes[0].type = CFG_ATTR_INTTYPE; attributes[0].attr.num.val = 30; nattributes = 1; attributes[1].name[0] = '\0'; /***************************************************/ /* Call the cfg_reconfigure() routine */ retval = cfg_reconfigure("lvm", attributes, nattributes); if (retval != CFG_SUCCESS) print_error (retval); else { for (i=0; i<1; i++) { printf("%s:", attributes[i].name); if (attributes[i].status != CFG_ATTR_SUCCESS) { switch (attributes[i].status){ case CFG_ATTR_EEXISTS: printf("unknown attribute\n"); break; case CFG_ATTR_EOP: printf("attribute does not allow this operation\n"); break; . . . default: printf("unknown error\n"); break; } } else printf(" successfully reconfigured\n"); } }

SEE ALSO

Routines: cfg_subsys_reconfig(3), cfg_configure(9r), cfg_errno(9r), cfg_query(9r), cfg_subsysop(9r), cfg_unconfigure(9r) Other: errno(2), sysconfigtab(4)

Index Index for
Section 9r
Index Alphabetical
listing for C
Top of page Top of
page