arp.h revision 7c478bd95313f5f23a4c958a745db2134aa03244
/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License, Version 1.0 only
* (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
*/
/*
* Copyright 1992,1997-2003 Sun Microsystems, Inc. All rights reserved.
* Use is subject to license terms.
*/
/* Copyright (c) 1990 Mentat Inc. */
#ifndef _INET_ARP_H
#define _INET_ARP_H
#pragma ident "%Z%%M% %I% %E% SMI"
#ifdef __cplusplus
extern "C" {
#endif
#define ARP_REQUEST 1
#define ARP_RESPONSE 2
#define RARP_REQUEST 3
#define RARP_RESPONSE 4
#define CMD_IN_PROGRESS 0x10000
/*
* The following ARP commands are private, and not part of a supported
* interface. They are subject to change without notice in any release.
*/
/*
* This is not an ARP command per se, it is used to interface between
* ARP and IP during close.
*/
/*
* The following ACE flags are private, and not part of a supported
* interface. They are subject to change without notice in any release.
*/
#define ACE_F_PERMANENT 0x1
#define ACE_F_PUBLISH 0x2
#define ACE_F_DYING 0x4
#define ACE_F_RESOLVED 0x8
/* Using bit mask extraction from target address */
#define ACE_F_MAPPING 0x10
/* ARP Cmd Table entry */
typedef struct arct_s {
int arct_min_len;
int arct_priv_req; /* Privilege required for this cmd */
const char *arct_txt;
} arct_t;
/* ARP Command Structures */
/* arc_t - Common command overlay */
typedef struct ar_cmd_s {
} arc_t;
/*
* The following ARP command structures are private, and not
* part of a supported interface. They are subject to change
* without notice in any release.
*/
/*
* NOTE: when using area_t for an AR_ENTRY_SQUERY, the area_hw_addr_offset
* field isn't what you might think. See comments in ip_multi.c where
* the routine ill_create_squery() is called, and also in the routine
* itself, to see how this field is used *only* when the area_t holds
* an AR_ENTRY_SQUERY.
*/
typedef struct ar_entry_add_s {
} area_t;
typedef struct ar_entry_delete_s {
} ared_t;
typedef struct ar_entry_query_s {
/* # ofquests to buffer; 0: default */
} areq_t;
/*
* Structure used with AR_ENTRY_LLAQUERY to map from the link_addr
* (in Neighbor Discovery option format excluding the option type and
* length) to a hardware address.
* The response has the same format as for an AR_ENTRY_SQUERY - an M_CTL with
* arel_hw_addr updated.
* An IPv6 address will be passed in AR_ENTRY_LLAQUERY so that atmip
* can send it in AR_CLIENT_NOTIFY messages.
*/
typedef struct ar_entry_llaquery_s {
} arel_t;
typedef struct ar_mapping_add_s {
/* Offset were we start placing */
/* the mask&proto_addr */
} arma_t;
/* Structure used to notify clients of interesting conditions. */
typedef struct ar_client_notify_s {
} arcn_t;
/* Client Notification Codes */
/*
* The following Client Notification codes are private, and not
* part of a supported interface. They are subject to change
* without notice in any release.
*/
#define AR_CN_BOGON 1
#define AR_CN_ANNOUNCE 2
/* ARP Header */
typedef struct arh_s {
} arh_t;
#ifdef __cplusplus
}
#endif
#endif /* _INET_ARP_H */