From mboxrd@z Thu Jan 1 00:00:00 1970 From: Roopa Prabhu Subject: Re: [PATCH iproute2] ip link: Show devices by link type Date: Wed, 03 Dec 2014 06:40:10 -0800 Message-ID: <547F20CA.4060501@cumulusnetworks.com> References: <1417370335-15772-1-git-send-email-vadim4j@gmail.com> <547E5F90.2060105@cumulusnetworks.com> <20141203011305.GA5945@angus-think.lan> Mime-Version: 1.0 Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit Cc: netdev@vger.kernel.org To: vadim4j@gmail.com Return-path: Received: from ext3.cumulusnetworks.com ([198.211.106.187]:51043 "EHLO ext3.cumulusnetworks.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750707AbaLCOkZ (ORCPT ); Wed, 3 Dec 2014 09:40:25 -0500 In-Reply-To: <20141203011305.GA5945@angus-think.lan> Sender: netdev-owner@vger.kernel.org List-ID: On 12/2/14, 5:13 PM, vadim4j@gmail.com wrote: > On Tue, Dec 02, 2014 at 04:55:44PM -0800, Roopa Prabhu wrote: >>> int master; >>> + char *link_kind; >> The name can be just "kind", given all the others dont use the link prefix >>> } filter; > OK > >>> + if (filter.link_kind && tb[IFLA_LINKINFO]) { >>> + char *link_kind = parse_link_kind(tb[IFLA_LINKINFO]); >>> + if (strcmp(link_kind, filter.link_kind)) { >>> + return -1; >>> + } >> you can skip the braces >>> + } else if (filter.link_kind) >> you have if (filter.link_kind) twice, you can use a single if without the >> else. >>> + return -1; >>> + > I need to skip interfaces which has not IFLA_LINKINFO attribute, > w/o "else if(...)" I get bridges with normal ether devices: > > bash# ip link show type bridge > > 1: lo: mtu 65536 qdisc noqueue state UNKNOWN mode DEFAULT group default > link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 > 2: enp0s25: mtu 1500 qdisc pfifo_fast state DOWN mode DEFAULT group default qlen 1000 > link/ether XX:XX:XX:XX:XX:XX brd ff:ff:ff:ff:ff:ff > 5: br0: mtu 1500 qdisc noop state DOWN mode DEFAULT group default > link/ether 6e:02:f9:17:7f:10 brd ff:ff:ff:ff:ff:ff > > but expected result should be only bridges. I was just saying, it could be: if (filter.link_kind) { if (tb[IFLA_LINKINFO]) { char *kind = parse_link_kind(tb[IFLA_LINKINFO]); if (strcmp(kind, filter.kind)) return -1; } else { return -1; } }