logo

oasis

Own branch of Oasis Linux (upstream: <https://git.sr.ht/~mcf/oasis/>) git clone https://anongit.hacktivis.me/git/oasis.git
commit: 264e137e0225b8c9e8b411c26da02447f5d71dd3
parent 72dda36a33790544660fbc7aa05d47a349d53c95
Author: Michael Forney <mforney@mforney.org>
Date:   Mon, 24 Jun 2019 17:10:29 -0700

iproute2: Fix get_link_kind when linked statically

Diffstat:

Apkg/iproute2/patch/0012-ip-Fix-get_link_kind-when-linked-statically.patch124+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Mpkg/iproute2/ver2+-
2 files changed, 125 insertions(+), 1 deletion(-)

diff --git a/pkg/iproute2/patch/0012-ip-Fix-get_link_kind-when-linked-statically.patch b/pkg/iproute2/patch/0012-ip-Fix-get_link_kind-when-linked-statically.patch @@ -0,0 +1,124 @@ +From cced9508238bd4ea087986ad683661cd7f27df27 Mon Sep 17 00:00:00 2001 +From: Michael Forney <mforney@mforney.org> +Date: Mon, 24 Jun 2019 16:03:55 -0700 +Subject: [PATCH] ip: Fix get_link_kind when linked statically + +--- + ip/iplink.c | 95 ++++++++++++++++++++++++++++++++++++++++++++++++----- + 1 file changed, 86 insertions(+), 9 deletions(-) + +diff --git a/ip/iplink.c b/ip/iplink.c +index 3e86ec5a..27a33591 100644 +--- a/ip/iplink.c ++++ b/ip/iplink.c +@@ -149,21 +149,98 @@ struct link_util *get_link_kind(const char *id) + char buf[256]; + struct link_util *l; + ++ if (linkutil_list == NULL) { ++ // <sed -n 's/^\(struct link_util .*_link_util\) = {/ extern \1;/p' ip/*.c ++ extern struct link_util bond_link_util; ++ extern struct link_util bond_slave_link_util; ++ extern struct link_util bridge_link_util; ++ extern struct link_util bridge_slave_link_util; ++ extern struct link_util can_link_util; ++ extern struct link_util dummy_link_util; ++ extern struct link_util geneve_link_util; ++ extern struct link_util hsr_link_util; ++ extern struct link_util ifb_link_util; ++ extern struct link_util ipoib_link_util; ++ extern struct link_util ipvlan_link_util; ++ extern struct link_util ipvtap_link_util; ++ extern struct link_util macvlan_link_util; ++ extern struct link_util macvtap_link_util; ++ extern struct link_util netdevsim_link_util; ++ extern struct link_util nlmon_link_util; ++ extern struct link_util rmnet_link_util; ++ extern struct link_util team_link_util; ++ extern struct link_util vcan_link_util; ++ extern struct link_util vlan_link_util; ++ extern struct link_util vrf_link_util; ++ extern struct link_util vrf_slave_link_util; ++ extern struct link_util vxcan_link_util; ++ extern struct link_util vxlan_link_util; ++ extern struct link_util macsec_link_util; ++ extern struct link_util tun_link_util; ++ extern struct link_util gre_link_util; ++ extern struct link_util gretap_link_util; ++ extern struct link_util erspan_link_util; ++ extern struct link_util ip6gre_link_util; ++ extern struct link_util ip6gretap_link_util; ++ extern struct link_util ip6erspan_link_util; ++ extern struct link_util ip6tnl_link_util; ++ extern struct link_util ipip_link_util; ++ extern struct link_util sit_link_util; ++ extern struct link_util veth_link_util; ++ extern struct link_util vti_link_util; ++ extern struct link_util vti6_link_util; ++ extern struct link_util xfrm_link_util; ++ ++ // <sed -n 's/^struct link_util \(.*_link_util\) = {/ \1.next = linkutil_list, linkutil_list = \&\1;/p' ip/*.c ++ bond_link_util.next = linkutil_list, linkutil_list = &bond_link_util; ++ bond_slave_link_util.next = linkutil_list, linkutil_list = &bond_slave_link_util; ++ bridge_link_util.next = linkutil_list, linkutil_list = &bridge_link_util; ++ bridge_slave_link_util.next = linkutil_list, linkutil_list = &bridge_slave_link_util; ++ can_link_util.next = linkutil_list, linkutil_list = &can_link_util; ++ dummy_link_util.next = linkutil_list, linkutil_list = &dummy_link_util; ++ geneve_link_util.next = linkutil_list, linkutil_list = &geneve_link_util; ++ hsr_link_util.next = linkutil_list, linkutil_list = &hsr_link_util; ++ ifb_link_util.next = linkutil_list, linkutil_list = &ifb_link_util; ++ ipoib_link_util.next = linkutil_list, linkutil_list = &ipoib_link_util; ++ ipvlan_link_util.next = linkutil_list, linkutil_list = &ipvlan_link_util; ++ ipvtap_link_util.next = linkutil_list, linkutil_list = &ipvtap_link_util; ++ macvlan_link_util.next = linkutil_list, linkutil_list = &macvlan_link_util; ++ macvtap_link_util.next = linkutil_list, linkutil_list = &macvtap_link_util; ++ netdevsim_link_util.next = linkutil_list, linkutil_list = &netdevsim_link_util; ++ nlmon_link_util.next = linkutil_list, linkutil_list = &nlmon_link_util; ++ rmnet_link_util.next = linkutil_list, linkutil_list = &rmnet_link_util; ++ team_link_util.next = linkutil_list, linkutil_list = &team_link_util; ++ vcan_link_util.next = linkutil_list, linkutil_list = &vcan_link_util; ++ vlan_link_util.next = linkutil_list, linkutil_list = &vlan_link_util; ++ vrf_link_util.next = linkutil_list, linkutil_list = &vrf_link_util; ++ vrf_slave_link_util.next = linkutil_list, linkutil_list = &vrf_slave_link_util; ++ vxcan_link_util.next = linkutil_list, linkutil_list = &vxcan_link_util; ++ vxlan_link_util.next = linkutil_list, linkutil_list = &vxlan_link_util; ++ macsec_link_util.next = linkutil_list, linkutil_list = &macsec_link_util; ++ tun_link_util.next = linkutil_list, linkutil_list = &tun_link_util; ++ gre_link_util.next = linkutil_list, linkutil_list = &gre_link_util; ++ gretap_link_util.next = linkutil_list, linkutil_list = &gretap_link_util; ++ erspan_link_util.next = linkutil_list, linkutil_list = &erspan_link_util; ++ ip6gre_link_util.next = linkutil_list, linkutil_list = &ip6gre_link_util; ++ ip6gretap_link_util.next = linkutil_list, linkutil_list = &ip6gretap_link_util; ++ ip6erspan_link_util.next = linkutil_list, linkutil_list = &ip6erspan_link_util; ++ ip6tnl_link_util.next = linkutil_list, linkutil_list = &ip6tnl_link_util; ++ ipip_link_util.next = linkutil_list, linkutil_list = &ipip_link_util; ++ sit_link_util.next = linkutil_list, linkutil_list = &sit_link_util; ++ veth_link_util.next = linkutil_list, linkutil_list = &veth_link_util; ++ vti_link_util.next = linkutil_list, linkutil_list = &vti_link_util; ++ vti6_link_util.next = linkutil_list, linkutil_list = &vti6_link_util; ++ xfrm_link_util.next = linkutil_list, linkutil_list = &xfrm_link_util; ++ } ++ + for (l = linkutil_list; l; l = l->next) + if (strcmp(l->id, id) == 0) + return l; + + snprintf(buf, sizeof(buf), LIBDIR "/ip/link_%s.so", id); + dlh = dlopen(buf, RTLD_LAZY); +- if (dlh == NULL) { +- /* look in current binary, only open once */ +- dlh = BODY; +- if (dlh == NULL) { +- dlh = BODY = dlopen(NULL, RTLD_LAZY); +- if (dlh == NULL) +- return NULL; +- } +- } ++ if (dlh == NULL) ++ return NULL; + + snprintf(buf, sizeof(buf), "%s_link_util", id); + l = dlsym(dlh, buf); +-- +2.22.0 + diff --git a/pkg/iproute2/ver b/pkg/iproute2/ver @@ -1 +1 @@ -5.1.0 r1 +5.1.0 r2