Callbacks and overwriting capabilities are provided to take influence in various control flows inside the library. More...
Enumerations | |
enum | nl_cb_action { NL_OK, NL_SKIP, NL_STOP } |
Callback actions. More... | |
enum | nl_cb_kind { NL_CB_DEFAULT, NL_CB_VERBOSE, NL_CB_DEBUG, NL_CB_CUSTOM, __NL_CB_KIND_MAX } |
Callback kinds. More... | |
enum | nl_cb_type { NL_CB_VALID, NL_CB_FINISH, NL_CB_OVERRUN, NL_CB_SKIPPED, NL_CB_ACK, NL_CB_MSG_IN, NL_CB_MSG_OUT, NL_CB_INVALID, NL_CB_SEQ_CHECK, NL_CB_SEND_ACK, __NL_CB_TYPE_MAX } |
Callback types. More... | |
Callback Typedefs | |
| |
typedef int(* | nl_recvmsg_msg_cb_t )(struct nl_msg *msg, void *arg) |
nl_recvmsgs() callback for message processing customization | |
typedef int(* | nl_recvmsg_err_cb_t )(struct sockaddr_nl *nla, struct nlmsgerr *nlerr, void *arg) |
nl_recvmsgs() callback for error message processing customization | |
Callback Handle Management | |
| |
struct nl_cb * | nl_cb_alloc (enum nl_cb_kind kind) |
Allocate a new callback handle. | |
struct nl_cb * | nl_cb_clone (struct nl_cb *orig) |
Clone an existing callback handle. | |
struct nl_cb * | nl_cb_get (struct nl_cb *cb) |
void | nl_cb_put (struct nl_cb *cb) |
Callback Setup | |
| |
int | nl_cb_set (struct nl_cb *cb, enum nl_cb_type type, enum nl_cb_kind kind, nl_recvmsg_msg_cb_t func, void *arg) |
Set up a callback. | |
int | nl_cb_set_all (struct nl_cb *cb, enum nl_cb_kind kind, nl_recvmsg_msg_cb_t func, void *arg) |
Set up a all callbacks. | |
int | nl_cb_err (struct nl_cb *cb, enum nl_cb_kind kind, nl_recvmsg_err_cb_t func, void *arg) |
Set up an error callback. | |
Overwriting | |
| |
void | nl_cb_overwrite_recvmsgs (struct nl_cb *cb, int(*func)(struct nl_handle *, struct nl_cb *)) |
Overwrite internal calls to nl_recvmsgs(). | |
void | nl_cb_overwrite_recv (struct nl_cb *cb, int(*func)(struct nl_handle *, struct sockaddr_nl *, unsigned char **, struct ucred **)) |
Overwrite internal calls to nl_recv(). | |
void | nl_cb_overwrite_send (struct nl_cb *cb, int(*func)(struct nl_handle *, struct nl_msg *)) |
Overwrite internal calls to nl_send(). |
All callbacks are packed together in struct nl_cb which is then attached to a netlink socket or passed on to the respective functions directly.
Callbacks can control the flow of the underlying layer by returning the appropriate error codes:
Action ID | Description -----------------+------------------------------------------------------- NL_OK | Proceed with whatever comes next. NL_SKIP | Skip message currently being processed and continue | with next message. NL_STOP | Stop parsing and discard all remaining messages in | this set of messages.
All callbacks are optional and a default action is performed if no application specific implementation is provided:
Callback ID | Default Return Value ------------------+---------------------- NL_CB_VALID | NL_OK NL_CB_FINISH | NL_STOP NL_CB_OVERRUN | NL_STOP NL_CB_SKIPPED | NL_SKIP NL_CB_ACK | NL_STOP NL_CB_MSG_IN | NL_OK NL_CB_MSG_OUT | NL_OK NL_CB_INVALID | NL_STOP NL_CB_SEQ_CHECK | NL_OK NL_CB_SEND_ACK | NL_OK | Error Callback | NL_STOP
In order to simplify typical usages of the library, different sets of default callback implementations exist:
NL_CB_DEFAULT: No additional actions NL_CB_VERBOSE: Automatically print warning and error messages to a file descriptor as appropriate. This is useful for CLI based applications. NL_CB_DEBUG: Print informal debugging information for each message received. This will result in every message beint sent or received to be printed to the screen in a decoded, human-readable format.
// Allocate a callback set and initialize it to the verbose default set struct nl_cb *cb = nl_cb_alloc(NL_CB_VERBOSE); // Modify the set to call my_func() for all valid messages nl_cb_set(cb, NL_CB_VALID, NL_CB_CUSTOM, my_func, NULL); // Set the error message handler to the verbose default implementation // and direct it to print all errors to the given file descriptor. FILE *file = fopen(...); nl_cb_err(cb, NL_CB_VERBOSE, NULL, file);
typedef int(* nl_recvmsg_msg_cb_t)(struct nl_msg *msg, void *arg) |
msg | netlink message being processed | |
arg | argument passwd on through caller |
Definition at line 41 of file handlers.h.
typedef int(* nl_recvmsg_err_cb_t)(struct sockaddr_nl *nla, struct nlmsgerr *nlerr, void *arg) |
nla | netlink address of the peer | |
nlerr | netlink error message being processed | |
arg | argument passed on through caller |
Definition at line 50 of file handlers.h.
enum nl_cb_action |
NL_OK |
Proceed with wathever would come next. |
NL_SKIP |
Skip this message. |
NL_STOP |
Stop parsing altogether and discard remaining messages. |
Definition at line 59 of file handlers.h.
enum nl_cb_kind |
Definition at line 76 of file handlers.h.
00076 { 00077 /** Default handlers (quiet) */ 00078 NL_CB_DEFAULT, 00079 /** Verbose default handlers (error messages printed) */ 00080 NL_CB_VERBOSE, 00081 /** Debug handlers for debugging */ 00082 NL_CB_DEBUG, 00083 /** Customized handler specified by the user */ 00084 NL_CB_CUSTOM, 00085 __NL_CB_KIND_MAX, 00086 };
enum nl_cb_type |
NL_CB_VALID |
Message is valid. |
NL_CB_FINISH |
Last message in a series of multi part messages received. |
NL_CB_OVERRUN |
Report received that data was lost. |
NL_CB_SKIPPED |
Message wants to be skipped. |
NL_CB_ACK |
Message is an acknowledge. |
NL_CB_MSG_IN |
Called for every message received. |
NL_CB_MSG_OUT |
Called for every message sent out except for nl_sendto(). |
NL_CB_INVALID |
Message is malformed and invalid. |
NL_CB_SEQ_CHECK |
Called instead of internal sequence number checking. |
NL_CB_SEND_ACK |
Sending of an acknowledge message has been requested. |
Definition at line 94 of file handlers.h.
00094 { 00095 /** Message is valid */ 00096 NL_CB_VALID, 00097 /** Last message in a series of multi part messages received */ 00098 NL_CB_FINISH, 00099 /** Report received that data was lost */ 00100 NL_CB_OVERRUN, 00101 /** Message wants to be skipped */ 00102 NL_CB_SKIPPED, 00103 /** Message is an acknowledge */ 00104 NL_CB_ACK, 00105 /** Called for every message received */ 00106 NL_CB_MSG_IN, 00107 /** Called for every message sent out except for nl_sendto() */ 00108 NL_CB_MSG_OUT, 00109 /** Message is malformed and invalid */ 00110 NL_CB_INVALID, 00111 /** Called instead of internal sequence number checking */ 00112 NL_CB_SEQ_CHECK, 00113 /** Sending of an acknowledge message has been requested */ 00114 NL_CB_SEND_ACK, 00115 __NL_CB_TYPE_MAX, 00116 };
struct nl_cb* nl_cb_alloc | ( | enum nl_cb_kind | kind | ) | [read] |
kind | callback kind to be used for initialization |
Definition at line 256 of file handlers.c.
References nl_cb_err(), and nl_cb_set().
Referenced by nl_cb_clone(), and nl_handle_alloc().
00257 { 00258 int i; 00259 struct nl_cb *cb; 00260 00261 if (kind < 0 || kind > NL_CB_KIND_MAX) 00262 return NULL; 00263 00264 cb = calloc(1, sizeof(*cb)); 00265 if (!cb) { 00266 nl_errno(ENOMEM); 00267 return NULL; 00268 } 00269 00270 cb->cb_refcnt = 1; 00271 00272 for (i = 0; i <= NL_CB_TYPE_MAX; i++) 00273 nl_cb_set(cb, i, kind, NULL, NULL); 00274 00275 nl_cb_err(cb, kind, NULL, NULL); 00276 00277 return cb; 00278 }
struct nl_cb* nl_cb_clone | ( | struct nl_cb * | orig | ) | [read] |
orig | original callback handle |
Definition at line 286 of file handlers.c.
References nl_cb_alloc(), and NL_CB_DEFAULT.
Referenced by nl_wait_for_ack().
00287 { 00288 struct nl_cb *cb; 00289 00290 cb = nl_cb_alloc(NL_CB_DEFAULT); 00291 if (!cb) 00292 return NULL; 00293 00294 memcpy(cb, orig, sizeof(*orig)); 00295 cb->cb_refcnt = 1; 00296 00297 return cb; 00298 }
int nl_cb_set | ( | struct nl_cb * | cb, | |
enum nl_cb_type | type, | |||
enum nl_cb_kind | kind, | |||
nl_recvmsg_msg_cb_t | func, | |||
void * | arg | |||
) |
cb | callback set | |
type | callback to modify | |
kind | kind of implementation | |
func | callback function (NL_CB_CUSTOM) | |
arg | argument passed to callback |
Definition at line 338 of file handlers.c.
References NL_CB_CUSTOM.
Referenced by nl_cb_alloc(), nl_cb_set_all(), nl_disable_sequence_check(), nl_socket_modify_cb(), and nl_wait_for_ack().
00340 { 00341 if (type < 0 || type > NL_CB_TYPE_MAX) 00342 return nl_error(ERANGE, "Callback type out of range"); 00343 00344 if (kind < 0 || kind > NL_CB_KIND_MAX) 00345 return nl_error(ERANGE, "Callback kind out of range"); 00346 00347 if (kind == NL_CB_CUSTOM) { 00348 cb->cb_set[type] = func; 00349 cb->cb_args[type] = arg; 00350 } else { 00351 cb->cb_set[type] = cb_def[type][kind]; 00352 cb->cb_args[type] = arg; 00353 } 00354 00355 return 0; 00356 }
int nl_cb_set_all | ( | struct nl_cb * | cb, | |
enum nl_cb_kind | kind, | |||
nl_recvmsg_msg_cb_t | func, | |||
void * | arg | |||
) |
cb | callback set | |
kind | kind of callback | |
func | callback function | |
arg | argument to be passwd to callback function |
Definition at line 367 of file handlers.c.
References nl_cb_set().
00369 { 00370 int i, err; 00371 00372 for (i = 0; i <= NL_CB_TYPE_MAX; i++) { 00373 err = nl_cb_set(cb, i, kind, func, arg); 00374 if (err < 0) 00375 return err; 00376 } 00377 00378 return 0; 00379 }
int nl_cb_err | ( | struct nl_cb * | cb, | |
enum nl_cb_kind | kind, | |||
nl_recvmsg_err_cb_t | func, | |||
void * | arg | |||
) |
cb | callback set | |
kind | kind of callback | |
func | callback function | |
arg | argument to be passed to callback function |
Definition at line 388 of file handlers.c.
References NL_CB_CUSTOM.
Referenced by nl_cb_alloc().
00390 { 00391 if (kind < 0 || kind > NL_CB_KIND_MAX) 00392 return nl_error(ERANGE, "Callback kind out of range"); 00393 00394 if (kind == NL_CB_CUSTOM) { 00395 cb->cb_err = func; 00396 cb->cb_err_arg = arg; 00397 } else { 00398 cb->cb_err = cb_err_def[kind]; 00399 cb->cb_err_arg = arg; 00400 } 00401 00402 return 0; 00403 }
void nl_cb_overwrite_recvmsgs | ( | struct nl_cb * | cb, | |
int(*)(struct nl_handle *, struct nl_cb *) | func | |||
) |
cb | callback set | |
func | replacement callback for nl_recvmsgs() |
Definition at line 417 of file handlers.c.
void nl_cb_overwrite_recv | ( | struct nl_cb * | cb, | |
int(*)(struct nl_handle *, struct sockaddr_nl *, unsigned char **, struct ucred **) | func | |||
) |
cb | callback set | |
func | replacement callback for nl_recv() |
Definition at line 428 of file handlers.c.
void nl_cb_overwrite_send | ( | struct nl_cb * | cb, | |
int(*)(struct nl_handle *, struct nl_msg *) | func | |||
) |
cb | callback set | |
func | replacement callback for nl_send() |
Definition at line 440 of file handlers.c.