libnl 3.7.0

Allocation/Freeing

struct rtnl_neightbl * rtnl_neightbl_alloc (void)
 
void rtnl_neightbl_put (struct rtnl_neightbl *neightbl)
 

Neighbour Table Cache Management

int rtnl_neightbl_alloc_cache (struct nl_sock *sk, struct nl_cache **result)
 Build a neighbour table cache including all neighbour tables currently configured in the kernel. More...
 
struct rtnl_neightbl * rtnl_neightbl_get (struct nl_cache *cache, const char *name, int ifindex)
 Lookup neighbour table by name and optional interface index. More...
 

Neighbour Table Modifications

int rtnl_neightbl_build_change_request (struct rtnl_neightbl *old, struct rtnl_neightbl *tmpl, struct nl_msg **result)
 Builds a netlink change request message to change neighbour table attributes. More...
 
int rtnl_neightbl_change (struct nl_sock *sk, struct rtnl_neightbl *old, struct rtnl_neightbl *tmpl)
 Change neighbour table attributes. More...
 

Attribute Modification

void rtnl_neightbl_set_family (struct rtnl_neightbl *ntbl, int family)
 
void rtnl_neightbl_set_gc_interval (struct rtnl_neightbl *ntbl, uint64_t ms)
 
void rtnl_neightbl_set_gc_tresh1 (struct rtnl_neightbl *ntbl, int thresh)
 
void rtnl_neightbl_set_gc_tresh2 (struct rtnl_neightbl *ntbl, int thresh)
 
void rtnl_neightbl_set_gc_tresh3 (struct rtnl_neightbl *ntbl, int thresh)
 
void rtnl_neightbl_set_name (struct rtnl_neightbl *ntbl, const char *name)
 
void rtnl_neightbl_set_dev (struct rtnl_neightbl *ntbl, int ifindex)
 
void rtnl_neightbl_set_queue_len (struct rtnl_neightbl *ntbl, int len)
 Set the queue length for pending requests of a neighbour table to the specified value. More...
 
void rtnl_neightbl_set_proxy_queue_len (struct rtnl_neightbl *ntbl, int len)
 Set the queue length for delay proxy arp requests of a neighbour table to the specified value. More...
 
void rtnl_neightbl_set_app_probes (struct rtnl_neightbl *ntbl, int probes)
 Set the number of application probes of a neighbour table to the specified value. More...
 
void rtnl_neightbl_set_ucast_probes (struct rtnl_neightbl *ntbl, int probes)
 Set the number of unicast probes of a neighbour table to the specified value. More...
 
void rtnl_neightbl_set_mcast_probes (struct rtnl_neightbl *ntbl, int probes)
 Set the number of multicast probes of a neighbour table to the specified value. More...
 
void rtnl_neightbl_set_base_reachable_time (struct rtnl_neightbl *ntbl, uint64_t ms)
 Set the base reachable time of a neighbour table to the specified value. More...
 
void rtnl_neightbl_set_retrans_time (struct rtnl_neightbl *ntbl, uint64_t ms)
 Set the retransmit time of a neighbour table to the specified value. More...
 
void rtnl_neightbl_set_gc_stale_time (struct rtnl_neightbl *ntbl, uint64_t ms)
 Set the gc stale time of a neighbour table to the specified value. More...
 
void rtnl_neightbl_set_delay_probe_time (struct rtnl_neightbl *ntbl, uint64_t ms)
 Set the first probe delay time of a neighbour table to the specified value. More...
 
void rtnl_neightbl_set_anycast_delay (struct rtnl_neightbl *ntbl, uint64_t ms)
 Set the anycast delay of a neighbour table to the specified value. More...
 
void rtnl_neightbl_set_proxy_delay (struct rtnl_neightbl *ntbl, uint64_t ms)
 Set the proxy delay of a neighbour table to the specified value. More...
 
void rtnl_neightbl_set_locktime (struct rtnl_neightbl *ntbl, uint64_t ms)
 Set the locktime of a neighbour table to the specified value. More...
 

Detailed Description

Function Documentation

◆ rtnl_neightbl_alloc()

struct rtnl_neightbl * rtnl_neightbl_alloc ( void  )

Definition at line 363 of file neightbl.c.

◆ rtnl_neightbl_put()

void rtnl_neightbl_put ( struct rtnl_neightbl *  neightbl)

Definition at line 368 of file neightbl.c.

◆ rtnl_neightbl_alloc_cache()

int rtnl_neightbl_alloc_cache ( struct nl_sock *  sk,
struct nl_cache **  result 
)

Build a neighbour table cache including all neighbour tables currently configured in the kernel.

Parameters
skNetlink socket.
resultPointer to store resulting cache.

Allocates a new neighbour table cache, initializes it properly and updates it to include all neighbour tables currently configured in the kernel.

Returns
0 on success or a negative error code.

Definition at line 391 of file neightbl.c.

References nl_cache_alloc_and_fill().

+ Here is the call graph for this function:

◆ rtnl_neightbl_get()

struct rtnl_neightbl * rtnl_neightbl_get ( struct nl_cache *  cache,
const char *  name,
int  ifindex 
)

Lookup neighbour table by name and optional interface index.

Parameters
cacheneighbour table cache
namename of table
ifindexoptional interface index

Looks up the neighbour table matching the specified name and optionally the specified ifindex to retrieve device specific parameter sets.

Returns
ptr to neighbour table inside the cache or NULL if no match was found.

Definition at line 409 of file neightbl.c.

References nl_object_get().

+ Here is the call graph for this function:

◆ rtnl_neightbl_build_change_request()

int rtnl_neightbl_build_change_request ( struct rtnl_neightbl *  old,
struct rtnl_neightbl *  tmpl,
struct nl_msg **  result 
)

Builds a netlink change request message to change neighbour table attributes.

Parameters
oldneighbour table to change
tmpltemplate with requested changes
resultPointer to store resulting message.

Builds a new netlink message requesting a change of neighbour table attributes. The netlink message header isn't fully equipped with all relevant fields and must be sent out via nl_send_auto_complete() or supplemented as needed. old must point to a neighbour table currently configured in the kernel and tmpl must contain the attributes to be changed set via rtnl_neightbl_set_* functions.

Returns
0 on success or a negative error code.

Definition at line 452 of file neightbl.c.

References nla_put_nested(), NLA_PUT_STRING, NLA_PUT_U32, NLA_PUT_U64, nlmsg_alloc(), nlmsg_alloc_simple(), nlmsg_append(), and nlmsg_free().

Referenced by rtnl_neightbl_change().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ rtnl_neightbl_change()

int rtnl_neightbl_change ( struct nl_sock *  sk,
struct rtnl_neightbl *  old,
struct rtnl_neightbl *  tmpl 
)

Change neighbour table attributes.

Parameters
skNetlink socket.
oldneighbour table to be changed
tmpltemplate with requested changes

Builds a new netlink message by calling rtnl_neightbl_build_change_request(), sends the request to the kernel and waits for the next ACK to be received, i.e. blocks until the request has been processed.

Returns
0 on success or a negative error code

Definition at line 566 of file neightbl.c.

References nl_send_auto_complete(), nlmsg_free(), and rtnl_neightbl_build_change_request().

+ Here is the call graph for this function:

◆ rtnl_neightbl_set_family()

void rtnl_neightbl_set_family ( struct rtnl_neightbl *  ntbl,
int  family 
)

Definition at line 590 of file neightbl.c.

◆ rtnl_neightbl_set_gc_interval()

void rtnl_neightbl_set_gc_interval ( struct rtnl_neightbl *  ntbl,
uint64_t  ms 
)

Definition at line 596 of file neightbl.c.

◆ rtnl_neightbl_set_gc_tresh1()

void rtnl_neightbl_set_gc_tresh1 ( struct rtnl_neightbl *  ntbl,
int  thresh 
)

Definition at line 602 of file neightbl.c.

◆ rtnl_neightbl_set_gc_tresh2()

void rtnl_neightbl_set_gc_tresh2 ( struct rtnl_neightbl *  ntbl,
int  thresh 
)

Definition at line 608 of file neightbl.c.

◆ rtnl_neightbl_set_gc_tresh3()

void rtnl_neightbl_set_gc_tresh3 ( struct rtnl_neightbl *  ntbl,
int  thresh 
)

Definition at line 614 of file neightbl.c.

◆ rtnl_neightbl_set_name()

void rtnl_neightbl_set_name ( struct rtnl_neightbl *  ntbl,
const char *  name 
)

Definition at line 620 of file neightbl.c.

◆ rtnl_neightbl_set_dev()

void rtnl_neightbl_set_dev ( struct rtnl_neightbl *  ntbl,
int  ifindex 
)

Definition at line 626 of file neightbl.c.

◆ rtnl_neightbl_set_queue_len()

void rtnl_neightbl_set_queue_len ( struct rtnl_neightbl *  ntbl,
int  len 
)

Set the queue length for pending requests of a neighbour table to the specified value.

Parameters
ntblneighbour table to change
lennew queue len

Definition at line 638 of file neightbl.c.

◆ rtnl_neightbl_set_proxy_queue_len()

void rtnl_neightbl_set_proxy_queue_len ( struct rtnl_neightbl *  ntbl,
int  len 
)

Set the queue length for delay proxy arp requests of a neighbour table to the specified value.

Parameters
ntblneighbour table to change
lennew queue len

Definition at line 650 of file neightbl.c.

◆ rtnl_neightbl_set_app_probes()

void rtnl_neightbl_set_app_probes ( struct rtnl_neightbl *  ntbl,
int  probes 
)

Set the number of application probes of a neighbour table to the specified value.

Parameters
ntblneighbour table to change
probesnew probes value

Definition at line 662 of file neightbl.c.

◆ rtnl_neightbl_set_ucast_probes()

void rtnl_neightbl_set_ucast_probes ( struct rtnl_neightbl *  ntbl,
int  probes 
)

Set the number of unicast probes of a neighbour table to the specified value.

Parameters
ntblneighbour table to change
probesnew probes value

Definition at line 674 of file neightbl.c.

◆ rtnl_neightbl_set_mcast_probes()

void rtnl_neightbl_set_mcast_probes ( struct rtnl_neightbl *  ntbl,
int  probes 
)

Set the number of multicast probes of a neighbour table to the specified value.

Parameters
ntblneighbour table to change
probesnew probes value

Definition at line 686 of file neightbl.c.

◆ rtnl_neightbl_set_base_reachable_time()

void rtnl_neightbl_set_base_reachable_time ( struct rtnl_neightbl *  ntbl,
uint64_t  ms 
)

Set the base reachable time of a neighbour table to the specified value.

Parameters
ntblneighbour table to change
msnew base reachable time in milliseconds

Definition at line 698 of file neightbl.c.

◆ rtnl_neightbl_set_retrans_time()

void rtnl_neightbl_set_retrans_time ( struct rtnl_neightbl *  ntbl,
uint64_t  ms 
)

Set the retransmit time of a neighbour table to the specified value.

Parameters
ntblneighbour table to change
msnew retransmit time

Definition at line 711 of file neightbl.c.

◆ rtnl_neightbl_set_gc_stale_time()

void rtnl_neightbl_set_gc_stale_time ( struct rtnl_neightbl *  ntbl,
uint64_t  ms 
)

Set the gc stale time of a neighbour table to the specified value.

Parameters
ntblneighbour table to change
msnew gc stale time in milliseconds

Definition at line 723 of file neightbl.c.

◆ rtnl_neightbl_set_delay_probe_time()

void rtnl_neightbl_set_delay_probe_time ( struct rtnl_neightbl *  ntbl,
uint64_t  ms 
)

Set the first probe delay time of a neighbour table to the specified value.

Parameters
ntblneighbour table to change
msnew first probe delay time in milliseconds

Definition at line 735 of file neightbl.c.

◆ rtnl_neightbl_set_anycast_delay()

void rtnl_neightbl_set_anycast_delay ( struct rtnl_neightbl *  ntbl,
uint64_t  ms 
)

Set the anycast delay of a neighbour table to the specified value.

Parameters
ntblneighbour table to change
msnew anycast delay in milliseconds

Definition at line 747 of file neightbl.c.

◆ rtnl_neightbl_set_proxy_delay()

void rtnl_neightbl_set_proxy_delay ( struct rtnl_neightbl *  ntbl,
uint64_t  ms 
)

Set the proxy delay of a neighbour table to the specified value.

Parameters
ntblneighbour table to change
msnew proxy delay in milliseconds

Definition at line 759 of file neightbl.c.

◆ rtnl_neightbl_set_locktime()

void rtnl_neightbl_set_locktime ( struct rtnl_neightbl *  ntbl,
uint64_t  ms 
)

Set the locktime of a neighbour table to the specified value.

Parameters
ntblneighbour table to change
msnew locktime in milliseconds

Definition at line 771 of file neightbl.c.