1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
|
/*
* Copyright (c) 2011 Gaetano Catalli.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at:
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef RTBSD_H
#define RTBSD_H 1
#include "list.h"
/*
* A digested version of a message received from a PF_ROUTE socket which
* indicates that a network device has been created or destroyed or changed.
*/
struct rtbsd_change {
/* Copied from struct if_msghdr. */
int msg_type; /* e.g. XXX. */
/* Copied from struct if_msghdr. */
int if_index; /* Index of network device. */
char if_name[IF_NAMESIZE]; /* Name of network device. */
int master_ifindex; /* Ifindex of datapath master (0 if none). */
};
/*
* Function called to report that a netdev has changed. 'change' describes the
* specific change. It may be null if the buffer of change information
* overflowed, in which case the function must assume that every device may
* have changed. 'aux' is as specified in the call to
* rtbsd_notifier_register().
*/
typedef void rtbsd_notify_func(const struct rtbsd_change *, void *aux);
struct rtbsd_notifier {
struct list node;
rtbsd_notify_func *cb;
void *aux;
};
int rtbsd_notifier_register(struct rtbsd_notifier *,
rtbsd_notify_func *, void *aux);
void rtbsd_notifier_unregister(struct rtbsd_notifier *);
void rtbsd_notifier_run(void);
void rtbsd_notifier_wait(void);
#endif /* rtbsd.h */
|