summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorThomas Graf <tgr@deb.localdomain>2008-01-14 15:46:17 (GMT)
committerThomas Graf <tgr@deb.localdomain>2008-01-14 15:46:17 (GMT)
commit75a26f3fc5a306e39f5244ee24e69936c4b5146d (patch)
tree62a0984f34df2cd002f3efdb8e369a634f34a09a
parentdbefb734d37208547e2d09f6bedd88b962f0a2bc (diff)
downloadlibnl-75a26f3fc5a306e39f5244ee24e69936c4b5146d.zip
libnl-75a26f3fc5a306e39f5244ee24e69936c4b5146d.tar.gz
libnl-75a26f3fc5a306e39f5244ee24e69936c4b5146d.tar.bz2
Improve message/attribute construction documentation and add nlmsg_expand()
-rw-r--r--include/netlink/msg.h2
-rw-r--r--lib/attr.c18
-rw-r--r--lib/msg.c65
3 files changed, 61 insertions, 24 deletions
diff --git a/include/netlink/msg.h b/include/netlink/msg.h
index 5d0ecd2..732e66f 100644
--- a/include/netlink/msg.h
+++ b/include/netlink/msg.h
@@ -81,6 +81,7 @@ extern struct nl_msg * nlmsg_inherit(struct nlmsghdr *);
extern struct nl_msg * nlmsg_convert(struct nlmsghdr *);
extern void * nlmsg_reserve(struct nl_msg *, size_t, int);
extern int nlmsg_append(struct nl_msg *, void *, size_t, int);
+extern int nlmsg_expand(struct nl_msg *, size_t);
extern struct nlmsghdr * nlmsg_put(struct nl_msg *, uint32_t, uint32_t,
int, int, int);
@@ -90,6 +91,7 @@ extern void nlmsg_free(struct nl_msg *);
/* attribute modification */
extern void nlmsg_set_proto(struct nl_msg *, int);
extern int nlmsg_get_proto(struct nl_msg *);
+extern size_t nlmsg_get_max_size(struct nl_msg *);
extern void nlmsg_set_src(struct nl_msg *, struct sockaddr_nl *);
extern struct sockaddr_nl *nlmsg_get_src(struct nl_msg *);
extern void nlmsg_set_dst(struct nl_msg *, struct sockaddr_nl *);
diff --git a/lib/attr.c b/lib/attr.c
index 8d9fdfa..8568d32 100644
--- a/lib/attr.c
+++ b/lib/attr.c
@@ -64,15 +64,13 @@
* @code
* int param1 = 10;
* char *param2 = "parameter text";
- * struct nlmsghdr hdr = {
- * .nlmsg_type = MY_ACTION,
- * };
- * struct nl_msg *m = nlmsg_build(&hdr);
- * nla_put_u32(m, 1, param1);
- * nla_put_string(m, 2, param2);
+ *
+ * struct nl_msg *msg = nlmsg_alloc();
+ * nla_put_u32(msg, 1, param1);
+ * nla_put_string(msg, 2, param2);
*
- * nl_send_auto_complete(handle, nl_msg_get(m));
- * nlmsg_free(m);
+ * nl_send_auto_complete(handle, nl_msg_get(msg));
+ * nlmsg_free(msg);
* @endcode
*
* @par 2) Constructing nested attributes
@@ -80,14 +78,14 @@
* struct nl_msg * nested_config(void)
* {
* int a = 5, int b = 10;
- * struct nl_msg *n = nlmsg_build(NULL);
+ * struct nl_msg *n = nlmsg_alloc();
* nla_put_u32(n, 10, a);
* nla_put_u32(n, 20, b);
* return n;
* }
*
* ...
- * struct nl_msg *m = nlmsg_build(&hdr);
+ * struct nl_msg *m = nlmsg_alloc();
* struct nl_msg *nest = nested_config();
* nla_put_nested(m, 1, nest);
*
diff --git a/lib/msg.c b/lib/msg.c
index 80b689f..3d4fbc6 100644
--- a/lib/msg.c
+++ b/lib/msg.c
@@ -93,10 +93,15 @@
* +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
* @endcode
*
- * @par 1) Creating a new netlink message
+ * @par Example
* @code
- * // Netlink messages can be allocated in various ways, you may
- * // allocate an empty netlink message by using nlmsg_alloc():
+ * // Various methods exist to create/allocate a new netlink
+ * // message.
+ * //
+ * // nlmsg_alloc() will allocate an empty netlink message with
+ * // a maximum payload size which defaults to the page size of
+ * // the system. This default size can be modified using the
+ * // function nlmsg_set_default_size().
* struct nl_msg *msg = nlmsg_alloc();
*
* // Very often, the message type and message flags are known
@@ -104,7 +109,7 @@
* struct nl_msg *msg = nlmsg_alloc_simple(MY_TYPE, MY_FLAGS);
*
* // Alternatively an existing netlink message header can be used
- * // to inherit header values from:
+ * // to inherit the header values:
* struct nlmsghdr hdr = {
* .nlmsg_type = MY_TYPE,
* .nlmsg_flags = MY_FLAGS,
@@ -112,15 +117,12 @@
* struct nl_msg *msg = nlmsg_inherit(&hdr);
*
* // Last but not least, netlink messages received from netlink sockets
- * // can be converted into nl_msg objects using nlmsg_convert():
+ * // can be converted into nl_msg objects using nlmsg_convert(). This
+ * // will create a message with a maximum payload size which equals the
+ * // length of the existing netlink message, therefore no more data can
+ * // be appened without calling nlmsg_expand() first.
* struct nl_msg *msg = nlmsg_convert(nlh_from_nl_sock);
*
- * // The header can later be retrieved with nlmsg_hdr() and changed again:
- * nlmsg_hdr(msg)->nlmsg_flags |= YET_ANOTHER_FLAG;
- * @endcode
- *
- * @par 2) Appending data to the message
- * @code
* // Payload may be added to the message via nlmsg_append(). The fourth
* // parameter specifies the number of alignment bytes the data should
* // be padding with at the end. Common values are 0 to disable it or
@@ -131,10 +133,9 @@
* // the actual copying to a later point, nlmsg_reserve() can be used
* // for this purpose:
* void *data = nlmsg_reserve(msg, sizeof(mydata), NLMSG_ALIGNTO);
- * @endcode
*
- * @par 3) Cleaning up message construction
- * @code
+ * // Attributes may be added using the attributes interface.
+ *
* // After successful use of the message, the memory must be freed
* // using nlmsg_free()
* nlmsg_free(msg);
@@ -560,6 +561,37 @@ int nlmsg_append(struct nl_msg *n, void *data, size_t len, int pad)
}
/**
+ * Expand maximum payload size of a netlink message
+ * @arg n Netlink message.
+ * @arg newlen New maximum payload size.
+ *
+ * Reallocates the payload section of a netlink message and increases
+ * the maximum payload size of the message.
+ *
+ * @note Any pointers pointing to old payload block will be stale and
+ * need to be refetched. Therfore, do not expand while constructing
+ * nested attributes or while reserved data blocks are held.
+ *
+ * @return 0 on success or a negative error code.
+ */
+int nlmsg_expand(struct nl_msg *n, size_t newlen)
+{
+ void *tmp;
+
+ if (newlen <= n->nm_size)
+ return nl_errno(EINVAL);
+
+ tmp = realloc(n->nm_nlh, newlen);
+ if (tmp == NULL)
+ return nl_errno(ENOMEM);
+
+ n->nm_nlh = tmp;
+ n->nm_size = newlen;
+
+ return 0;
+}
+
+/**
* Add a netlink message header to a netlink message
* @arg n netlink message
* @arg pid netlink process id or NL_AUTO_PID
@@ -648,6 +680,11 @@ int nlmsg_get_proto(struct nl_msg *msg)
return msg->nm_protocol;
}
+size_t nlmsg_get_max_size(struct nl_msg *msg)
+{
+ return msg->nm_size;
+}
+
void nlmsg_set_src(struct nl_msg *msg, struct sockaddr_nl *addr)
{
memcpy(&msg->nm_src, addr, sizeof(*addr));