mirror of
https://gitee.com/openharmony/third_party_libnl
synced 2024-11-27 12:10:25 +00:00
45cbfb9d11
It would be desirable not to include kernel headers in our public libnl3 headers. As a test, remove all those includes, and fix compilation by explicitly including the kernel headers where needed. In some cases, that requires forward declaration for kernel structures, as we use them as part of our own headers. Realistically, we cannot drop those includes as it probalby breaks compilation for users that expect to get a certain kernel header when including a libnl3 header. So, this will not be done and the includes will be restored in the next commit. Do this step to show how it would be and to verify that we could build with such a change. The reason not to do this is backward compatibility (at compile-time).
31 lines
546 B
C
31 lines
546 B
C
#include <netlink/netlink.h>
|
|
#include <netlink/route/link.h>
|
|
|
|
#include <linux/netlink.h>
|
|
|
|
int main(int argc, char *argv[])
|
|
{
|
|
struct rtnl_link *link;
|
|
struct nl_sock *sk;
|
|
int err;
|
|
|
|
sk = nl_socket_alloc();
|
|
if ((err = nl_connect(sk, NETLINK_ROUTE)) < 0) {
|
|
nl_perror(err, "Unable to connect socket");
|
|
return err;
|
|
}
|
|
|
|
link = rtnl_link_alloc();
|
|
rtnl_link_set_name(link, "my_bond");
|
|
|
|
if ((err = rtnl_link_delete(sk, link)) < 0) {
|
|
nl_perror(err, "Unable to delete link");
|
|
return err;
|
|
}
|
|
|
|
rtnl_link_put(link);
|
|
nl_close(sk);
|
|
|
|
return 0;
|
|
}
|