/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License (the "License").
* You may not use this file except in compliance with the License.
*
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
* See the License for the specific language governing permissions
* and limitations under the License.
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
* If applicable, add the following below this CDDL HEADER, with the
* fields enclosed by brackets "[]" replaced with your own identifying
* information: Portions Copyright [yyyy] [name of copyright owner]
*
* CDDL HEADER END
*/
/*
*/
#ifndef _IPADM_IPMGMT_H
#define _IPADM_IPMGMT_H
#ifdef __cplusplus
extern "C" {
#endif
#include <fcntl.h>
#include <door.h>
#include <libipadm.h>
#include <inet/tunables.h>
/*
* Function declarations and data structures shared by libipadm.so and
* the IP management daemon.
*/
/* Authorization required to configure network interfaces */
/*
*/
/*
* For more information on these definitions please refer to the top of
* ipadm_persist.c. These are the name of the nvpairs which hold the
* respective values. All nvpairs private to ipadm have names that begin
* with "_". Note below that 'prefixlen' is an address property and therefore
* not a private nvpair name.
*/
/*
* All protocol properties that are private to ipadm are stored in the
* ipadm datastore with "__" as prefix. This is to ensure there
* is no collision of namespace between ipadm private nvpair names and
* the private protocol property names.
*/
/* data-store operations */
typedef enum {
/*
* callback arg used by db_wfunc_t that writes to DB. The contents to be
* written to DB are captured in `dbw_nvl'.
*/
typedef struct ipadm_dbwrite_cbarg_s {
/*
* door related function declarations and data structures.
*/
/* The door file for the ipmgmt (ip-interface management) daemon */
/* door call command type */
typedef enum {
/*
* Note: We need to keep the size of the structure the same on amd64 and i386
* for all door_call arguments and door_return structures.
*/
/* door_call argument */
typedef struct ipmgmt_arg {
} ipmgmt_arg_t;
/* IPMGMT_CMD_{SETPROP|GETPROP|RESETPROP} door_call argument */
typedef struct ipmgmt_prop_arg_s {
/*
* ia_flags used in ipmgmt_prop_arg_t.
* - APPEND updates the multi-valued property entry with a new value
* - REDUCE updates the multi-valued property entry by removing a value
*/
/* IPMGMT_CMD_GETIF door_call argument structure */
typedef struct ipmgmt_getif_arg_s {
/* IPMGMT_CMD_RESETIF, IPMGMT_CMD_SETIF door_call argument structure */
typedef struct ipmgmt_if_arg_s {
/* IPMGMT_CMD_INITIF door_call argument structure */
typedef struct ipmgmt_initif_arg_s {
/* packed nvl follows */
/* IPMGMT_CMD_SETADDR door_call argument */
typedef struct ipmgmt_setaddr_arg_s {
/* packed nvl follows */
/* IPMGMT_CMD_GETADDR door_call argument */
typedef struct ipmgmt_getaddr_arg_s {
/* IPMGMT_CMD_RESETADDR door_call argument */
typedef struct ipmgmt_addr_arg_s {
/*
* IPMGMT_CMD_{ADDROBJ_ADD|ADDROBJ_LOOKUPADD|LIFNUM2ADDROBJ|
* ADDROBJ2LIFNUM} door_call argument.
*/
typedef struct ipmgmt_aobjop_arg_s {
/*
* - ACTIVE updates the running configuration
* - PERSIST updates the permanent data store
* - INIT indicates that operation being performed is under init
* context
*/
/* door call return value */
typedef struct ipmgmt_retval_s {
/* IPMGMT_CMD_GETADDR door_return value */
typedef struct ipmgmt_get_rval_s {
/* packed nvl follows */
/* IPMGMT_CMD_GETPROP door_return value */
typedef struct ipmgmt_getprop_rval_s {
/* IPMGMT_CMD_GETIF door_return value */
typedef struct ipmgmt_getif_rval_s {
/* IPMGMT_CMD_{LOOKUPADD|LIFNUM2ADDROBJ|ADDROBJ2LIFNUM} door_return value */
typedef struct ipmgmt_aobjop_rval_s {
/* DB walk callback functions */
/* zone related functions */
/*
* callback function to persist an interface in ipmgmtd data store
*/
/*
*/
#ifdef __cplusplus
}
#endif
#endif /* _IPADM_IPMGMT_H */