<div dir="ltr"><div><div><div>Sure, will do.<br></div>Was going to open up some suggestions in that directions.<br><br></div>I also want to look into the part where other modules can build against libnl (instead of libnl-tiny), when libnl selected.<br></div>Not sure how elegant that would become, but I'll look into it.<br><div><br></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Thu, Oct 1, 2015 at 7:33 PM, Rick Farina <span dir="ltr"><<a href="mailto:sidhayn@gmail.com" target="_blank">sidhayn@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">At least aircrack-ng wants genl as well as core.  Please feel free to<br>
fix aircrack-ng to dep properly when you make this change.<br>
<br>
Thanks,<br>
Zero_Chaos (openwrt maintainer of aircrack-ng)<br>
<div><div class="h5"><br>
On 09/23/2015 04:17 AM, Alexandru Ardelean wrote:<br>
> From: Alexandru Ardelean <<a href="mailto:aa@ocedo.com">aa@ocedo.com</a>><br>
><br>
> Some modules may require only libnl-genl, some<br>
> libnl-route and fewer would require libnl-nf.<br>
><br>
> This patch splits the entire libnl package into smaller<br>
> more granular libs that can be installed individually as required.<br>
><br>
> Also added libnl*.so symlinks for convenience.<br>
><br>
> Signed-off-by: Alexandru Ardelean <<a href="mailto:ardeleanalex@gmail.com">ardeleanalex@gmail.com</a>><br>
> ---<br>
>  package/libs/libnl/Makefile | 101 ++++++++++++++++++++++++++++++++++++++------<br>
>  1 file changed, 88 insertions(+), 13 deletions(-)<br>
><br>
> diff --git a/package/libs/libnl/Makefile b/package/libs/libnl/Makefile<br>
> index 995fda2..857bbe2 100644<br>
> --- a/package/libs/libnl/Makefile<br>
> +++ b/package/libs/libnl/Makefile<br>
> @@ -18,16 +18,61 @@ PKG_LICENSE:=LGPL-2.1<br>
><br>
>  include $(INCLUDE_DIR)/<a href="http://package.mk" rel="noreferrer" target="_blank">package.mk</a><br>
><br>
> -define Package/libnl<br>
> +define Package/libnl/default<br>
>    SECTION:=libs<br>
>    CATEGORY:=Libraries<br>
> -  TITLE:=netlink socket library<br>
> -  DEPENDS:=+libpthread<br>
>    URL:=<a href="http://people.suug.ch/~tgr/libnl/" rel="noreferrer" target="_blank">http://people.suug.ch/~tgr/libnl/</a><br>
>  endef<br>
><br>
> +define Package/libnl-core<br>
> +$(call Package/libnl/default)<br>
> +  TITLE:=Core Netlink Library<br>
> +  DEPENDS:=+libpthread<br>
> +endef<br>
> +<br>
> +define Package/libnl-genl<br>
> +$(call Package/libnl/default)<br>
> +  TITLE:=Generic Netlink Library<br>
> +  DEPENDS:=+libnl-core<br>
> +endef<br>
> +<br>
> +define Package/libnl-route<br>
> +$(call Package/libnl/default)<br>
> +  TITLE:=Routing Netlink Library<br>
> +  DEPENDS:=+libnl-core<br>
> +endef<br>
> +<br>
> +define Package/libnl-nf<br>
> +$(call Package/libnl/default)<br>
> +  TITLE:=Netfilter Netlink Library<br>
> +  DEPENDS:=+libnl-route<br>
> +endef<br>
> +<br>
> +define Package/libnl<br>
> +$(call Package/libnl/default)<br>
> +  TITLE:=Full Netlink Library<br>
> +  DEPENDS:=+libnl-genl +libnl-route +libnl-nf<br>
> +endef<br>
> +<br>
> +define Package/libnl-core/description<br>
> + Common code for all netlink libraries<br>
> +endef<br>
> +<br>
> +define Package/libnl-genl/description<br>
> + Generic Netlink Library Functions<br>
> +endef<br>
> +<br>
> +define Package/libnl-route/description<br>
> + Routing Netlink Library Functions<br>
> +endef<br>
> +<br>
> +define Package/libnl-nf/description<br>
> + Netfilter Netlink Library Functions<br>
> +endef<br>
> +<br>
>  define Package/libnl/description<br>
> - This package contains a library for applications dealing with netlink sockets<br>
> + Socket handling, connection management, sending and receiving of data,<br>
> + message construction and parsing, object caching system, etc.<br>
>  endef<br>
><br>
>  TARGET_CFLAGS += -ffunction-sections $(FPIC)<br>
> @@ -40,18 +85,48 @@ define Build/Compile<br>
>  endef<br>
><br>
>  define Build/InstallDev<br>
> -     $(INSTALL_DIR) $(1)<br>
> -     $(CP) $(PKG_INSTALL_DIR)/* $(1)/<br>
> -     mkdir -p $(1)/usr/include/libnl<br>
> -     $(CP) $(PKG_BUILD_DIR)/include/linux $(1)/usr/include/libnl/<br>
> +     $(INSTALL_DIR) $(1)/usr/include/libnl $(1)/usr/lib/pkgconfig<br>
> +     $(CP) $(PKG_INSTALL_DIR)/usr/include/libnl3/* $(1)/usr/include/libnl/<br>
> +     $(CP) $(PKG_INSTALL_DIR)/usr/lib/* $(1)/usr/lib<br>
> +     $(CP) $(PKG_INSTALL_DIR)/usr/lib/pkgconfig/*.pc $(1)/usr/lib/pkgconfig<br>
> +<br>
> +     # Copy symlinks<br>
> +     $(CP) $(PKG_INSTALL_DIR)/usr/lib/libnl-3.so $(1)/usr/lib/libnl.so<br>
> +     $(CP) $(PKG_INSTALL_DIR)/usr/lib/libnl-genl-3.so $(1)/usr/lib/libnl-genl.so<br>
> +     $(CP) $(PKG_INSTALL_DIR)/usr/lib/libnl-nf-3.so $(1)/usr/lib/libnl-nf.so<br>
> +     $(CP) $(PKG_INSTALL_DIR)/usr/lib/libnl-route-3.so $(1)/usr/lib/libnl-route.so<br>
>  endef<br>
><br>
> -define Package/libnl/install<br>
> +define Package/libnl-core/install<br>
> +     $(INSTALL_DIR) $(1)/usr/lib<br>
> +     $(CP) $(PKG_INSTALL_DIR)/usr/lib/libnl-3.so* $(1)/usr/lib/<br>
> +     $(CP) $(PKG_INSTALL_DIR)/usr/lib/libnl-3.so $(1)/usr/lib/libnl.so<br>
> +endef<br>
> +<br>
> +define Package/libnl-genl/install<br>
>       $(INSTALL_DIR) $(1)/usr/lib<br>
> -     $(CP) $(PKG_INSTALL_DIR)/usr/lib/libnl-route-3.so.* $(1)/usr/lib/<br>
> -     $(CP) $(PKG_INSTALL_DIR)/usr/lib/libnl-genl-3.so.* $(1)/usr/lib/<br>
> -     $(CP) $(PKG_INSTALL_DIR)/usr/lib/libnl-nf-3.so.* $(1)/usr/lib/<br>
> -     $(CP) $(PKG_INSTALL_DIR)/usr/lib/libnl-3.so.* $(1)/usr/lib/<br>
> +     $(CP) $(PKG_INSTALL_DIR)/usr/lib/libnl-genl-3.so* $(1)/usr/lib/<br>
> +     $(CP) $(PKG_INSTALL_DIR)/usr/lib/libnl-genl-3.so $(1)/usr/lib/libnl-genl.so<br>
> +endef<br>
> +<br>
> +define Package/libnl-route/install<br>
> +     $(INSTALL_DIR) $(1)/usr/lib<br>
> +     $(CP) $(PKG_INSTALL_DIR)/usr/lib/libnl-route-3.so* $(1)/usr/lib/<br>
> +     $(CP) $(PKG_INSTALL_DIR)/usr/lib/libnl-route-3.so $(1)/usr/lib/libnl-route.so<br>
> +endef<br>
> +<br>
> +define Package/libnl-nf/install<br>
> +     $(INSTALL_DIR) $(1)/usr/lib<br>
> +     $(CP) $(PKG_INSTALL_DIR)/usr/lib/libnl-nf-3.so* $(1)/usr/lib/<br>
> +     $(CP) $(PKG_INSTALL_DIR)/usr/lib/libnl-nf-3.so $(1)/usr/lib/libnl-nf.so<br>
> +endef<br>
> +<br>
> +define Package/libnl/install<br>
> +     :<br>
>  endef<br>
><br>
> +$(eval $(call BuildPackage,libnl-core))<br>
> +$(eval $(call BuildPackage,libnl-genl))<br>
> +$(eval $(call BuildPackage,libnl-route))<br>
> +$(eval $(call BuildPackage,libnl-nf))<br>
>  $(eval $(call BuildPackage,libnl))<br>
><br>
</div></div>_______________________________________________<br>
openwrt-devel mailing list<br>
<a href="mailto:openwrt-devel@lists.openwrt.org">openwrt-devel@lists.openwrt.org</a><br>
<a href="https://lists.openwrt.org/cgi-bin/mailman/listinfo/openwrt-devel" rel="noreferrer" target="_blank">https://lists.openwrt.org/cgi-bin/mailman/listinfo/openwrt-devel</a><br>
</blockquote></div><br></div>