]> git.proxmox.com Git - mirror_frr.git/blame - zebra/kernel_netlink.h
Merge pull request #8643 from icosahedral/master
[mirror_frr.git] / zebra / kernel_netlink.h
CommitLineData
1fdc9eae 1/* Declarations and definitions for kernel interaction over netlink
2 * Copyright (C) 2016 Cumulus Networks, Inc.
3 *
4 * This file is part of GNU Zebra.
5 *
6 * GNU Zebra is free software; you can redistribute it and/or modify it
7 * under the terms of the GNU General Public License as published by the
8 * Free Software Foundation; either version 2, or (at your option) any
9 * later version.
10 *
11 * GNU Zebra is distributed in the hope that it will be useful, but
12 * WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * General Public License for more details.
15 *
896014f4
DL
16 * You should have received a copy of the GNU General Public License along
17 * with this program; see the file COPYING; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
1fdc9eae 19 */
20
21#ifndef _ZEBRA_KERNEL_NETLINK_H
22#define _ZEBRA_KERNEL_NETLINK_H
23
51e94aa7
EDP
24#ifdef __cplusplus
25extern "C" {
26#endif
27
1fdc9eae 28#ifdef HAVE_NETLINK
29
9ed7517b 30#define NL_RCV_PKT_BUF_SIZE 32768
1fdc9eae 31#define NL_PKT_BUF_SIZE 8192
32
312a6bee
JU
33/*
34 * nl_attr_put - add an attribute to the Netlink message.
35 *
36 * Returns true if the attribute could be added to the message (fits into the
37 * buffer), otherwise false is returned.
38 */
39extern bool nl_attr_put(struct nlmsghdr *n, unsigned int maxlen, int type,
40 const void *data, unsigned int alen);
41extern bool nl_attr_put16(struct nlmsghdr *n, unsigned int maxlen, int type,
42 uint16_t data);
43extern bool nl_attr_put32(struct nlmsghdr *n, unsigned int maxlen, int type,
44 uint32_t data);
45
46/*
47 * nl_attr_nest - start an attribute nest.
48 *
49 * Returns a valid pointer to the beginning of the nest if the attribute
50 * describing the nest could be added to the message (fits into the buffer),
51 * otherwise NULL is returned.
52 */
53extern struct rtattr *nl_attr_nest(struct nlmsghdr *n, unsigned int maxlen,
54 int type);
55
56/*
57 * nl_attr_nest_end - finalize nesting of attributes.
58 *
59 * Updates the length field of the attribute header to include the appeneded
60 * attributes. Returns a total length of the Netlink message.
61 */
62extern int nl_attr_nest_end(struct nlmsghdr *n, struct rtattr *nest);
63
64/*
65 * nl_attr_rtnh - append a rtnexthop record to the Netlink message.
66 *
67 * Returns a valid pointer to the rtnexthop struct if it could be added to
68 * the message (fits into the buffer), otherwise NULL is returned.
69 */
70extern struct rtnexthop *nl_attr_rtnh(struct nlmsghdr *n, unsigned int maxlen);
71
72/*
73 * nl_attr_rtnh_end - finalize adding a rtnexthop record.
74 *
75 * Updates the length field of the rtnexthop to include the appeneded
76 * attributes.
77 */
78extern void nl_attr_rtnh_end(struct nlmsghdr *n, struct rtnexthop *rtnh);
79
d62a17ae 80extern void netlink_parse_rtattr(struct rtattr **tb, int max,
81 struct rtattr *rta, int len);
4bcdb608
NA
82extern void netlink_parse_rtattr_flags(struct rtattr **tb, int max,
83 struct rtattr *rta, int len,
84 unsigned short flags);
87da6a60
SW
85extern void netlink_parse_rtattr_nested(struct rtattr **tb, int max,
86 struct rtattr *rta);
d62a17ae 87extern const char *nl_msg_type_to_str(uint16_t msg_type);
d7c0a89a
QY
88extern const char *nl_rtproto_to_str(uint8_t rtproto);
89extern const char *nl_family_to_str(uint8_t family);
90extern const char *nl_rttype_to_str(uint8_t rttype);
1fdc9eae 91
2414abd3 92extern int netlink_parse_info(int (*filter)(struct nlmsghdr *, ns_id_t, int),
7cdb1a84 93 const struct nlsock *nl,
8b962e77 94 const struct zebra_dplane_info *dp_info,
d62a17ae 95 int count, int startup);
2414abd3
DS
96extern int netlink_talk_filter(struct nlmsghdr *h, ns_id_t ns, int startup);
97extern int netlink_talk(int (*filter)(struct nlmsghdr *, ns_id_t, int startup),
d62a17ae 98 struct nlmsghdr *n, struct nlsock *nl,
99 struct zebra_ns *zns, int startup);
fd3f8e52 100extern int netlink_request(struct nlsock *nl, void *req);
1fdc9eae 101
e63c7622
JU
102enum netlink_msg_status {
103 FRR_NETLINK_SUCCESS,
104 FRR_NETLINK_ERROR,
105 FRR_NETLINK_QUEUED,
106};
107
108struct nl_batch;
109
110/*
111 * netlink_batch_add_msg - add message to the netlink batch using dplane
112 * context object.
113 *
114 * @ctx: Dataplane context
115 * @msg_encoder: A function that encodes dplane context object into
116 * netlink message. Should take dplane context object,
117 * pointer to a buffer and buffer's length as parameters
118 * and should return -1 on error, 0 on buffer overflow or
119 * size of the encoded message.
f6feb48b
JU
120 * @ignore_res: Whether the result of this message should be ignored.
121 * This should be used in some 'update' cases where we
122 * need to send two messages for one context object.
e63c7622
JU
123 *
124 * Return: Status of the message.
125 */
126extern enum netlink_msg_status netlink_batch_add_msg(
127 struct nl_batch *bth, struct zebra_dplane_ctx *ctx,
128 ssize_t (*msg_encoder)(struct zebra_dplane_ctx *, void *, size_t),
f6feb48b 129 bool ignore_res);
e63c7622 130
531c92b8
JU
131/*
132 * Vty/cli apis
133 */
134extern int netlink_config_write_helper(struct vty *vty);
135
136/*
137 * Configure size of the batch buffer and sending threshold. If 'unset', reset
138 * to default value.
139 */
140extern void netlink_set_batch_buffer_size(uint32_t size, uint32_t threshold,
141 bool set);
e63c7622 142
1fdc9eae 143#endif /* HAVE_NETLINK */
144
51e94aa7
EDP
145#ifdef __cplusplus
146}
147#endif
148
1fdc9eae 149#endif /* _ZEBRA_KERNEL_NETLINK_H */