platform_system_core/libnl_2
Frank Maker c28b79a6c2 libnl: nl_socket_alloc() Bugfix
Clear memory and allow kernel to set local socket pid

Change-Id: I274156fa7bcf8d2fe78f719fb2eb32d963682931
2011-07-06 22:15:34 -07:00
..
genl Cleanroom libnl_2 library 2011-06-28 13:28:02 -07:00
include Cleanroom libnl_2 library 2011-06-28 13:28:02 -07:00
.gitignore Cleanroom libnl_2 library 2011-06-28 13:28:02 -07:00
Android.mk Cleanroom libnl_2 library 2011-06-28 13:28:02 -07:00
README Cleanroom libnl_2 library 2011-06-28 13:28:02 -07:00
attr.c BUGFIX: libnl_2 2011-06-30 17:39:54 -07:00
cache.c Cleanroom libnl_2 library 2011-06-28 13:28:02 -07:00
handlers.c Cleanroom libnl_2 library 2011-06-28 13:28:02 -07:00
msg.c Cleanroom libnl_2 library 2011-06-28 13:28:02 -07:00
netlink.c Cleanroom libnl_2 library 2011-06-28 13:28:02 -07:00
object.c Cleanroom libnl_2 library 2011-06-28 13:28:02 -07:00
socket.c libnl: nl_socket_alloc() Bugfix 2011-07-06 22:15:34 -07:00

README

Netlink Protocol Format (RFC3549)
+-----------------+-+-------------------+-+
|Netlink Message  |P| Generic Netlink   |P|
|    Header       |A|  Message Header   |A|
|(struct nlmsghdr)|D|(struct genlmsghdr)|D|
+-----------------+-+-------------------+-+
+-----------------+-+-----------------+-+-----------------+-+-----------------+-+---+
|Netlink Attribute|P|Netlink Attribute|P|Netlink Attribute|P|Netlink Attribute|P|...|
|    #0 Header    |A|   #0 Payload    |A|   #1 Header     |A|   #1 Payload    |A|   |
| (struct nlattr) |D|     (void)      |D| (struct nlattr) |D|     (void)      |D|   |
+-----------------+-+-----------------+-+-----------------+-+-----------------+-+---+

* Each netlink message consists of a bitstream with a netlink header.
* After this header a second header *can* be used specific to the netlink
  family in use. This library was tested using the generic netlink
  protocol defined by struct genlmsghdr to support nl80211.
* After the header(s) netlink attributes can be appended to the message
  which hold can hold basic types such as unsigned integers and strings.
* All data structures in this implementation are byte-aligned (Currently 4 bytes).
* Acknowledgements (ACKs) are sent as NLMSG_ERROR netlink message types (0x2) and
  have an error value of 0.

KNOWN BUGS
* NOT THREAD SAFE!!!
* nla_parse - does not use nla_policy argument
* nl_recvmsgs - does not support nl_cb_overwrite_recv()
* nl_recv - sets/unsets async. flag
* genl_ctrl_alloc_cache - netlink send/recv funcs should be used

REFERENCES
* nl80211.h
* netlink_types.h
* $LINUX_KERNEL/net/wireless/nl80211.c
* http://www.infradead.org/~tgr/libnl/doc-3.0/index.html
* http://www.netfilter.org/projects/libmnl/doxygen/index.html