Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp21571968ybl; Mon, 6 Jan 2020 07:11:39 -0800 (PST) X-Google-Smtp-Source: APXvYqwgnpVQSnMD5rPw91la+XbFouO1ZQODOKfMP7oYI5Xx/ZZNCdS74JmwI56WDGiGWhubUkEO X-Received: by 2002:aca:ed57:: with SMTP id l84mr5793275oih.8.1578323499025; Mon, 06 Jan 2020 07:11:39 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1578323499; cv=none; d=google.com; s=arc-20160816; b=G7zd03nsVUNrqHTrxtB6CazrHI1+urVGqCd3i33wzRzftlNgJfXrSx7N2b6wg5Oyma ELmgVBnEwsnyp+IUx1anMMECQt206c+vtDXmlKfKVqjRsV6z4NhKagDcB66wg8bClZ9U G1D44pxqJ4xh7TL9JNBQtIJPFN4n5wGCHChYccHjXBt4F0Rr6UzzbgvD2OnOOxfw8mk2 IavDNhvNO469JboTL2lLRzSg8YglbjyYBOZPGkwzKZcRAgMCaezeqnAT3TZq98vHwdg8 +6/s/GJwVAM6lTv1Y4uPsaTysB/6Em73kubvXoxqOU6uvYszWLy++qPlql1zma3+SNXL 5Fhg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=c79pn9WrB+KPBesRz7670hkMyAFsQ7YCQTTW6lrb5OA=; b=vyGrtqzYwd79yGTlWXxHq6ahZZrYAw1YmhdkBUDINhbKVrut0X9oszdUFjMJEcsxxI 7km6HUbWrP7uOubcBLOwDTQ1PMnUefnqjv5yu1CVzkmcZi2tqqB33Rdd2l5YcQGcG16r IWVtysn4JQCpC0SSNpBkH8SWLOLq9Xa4cNggRkh6feUMAljVxwf2c90A/GiTDhsjjWIC oYAfQtO1j0f8VxDiDfimuIN5dcNVTcyj8/R4A0yWAyYvD8bWKRl5+QHbJSrZfW31if5I r8mM9tbzpm7tHij4Wq+sH5Ypw65lT6QRnKoDXuI0s2G5mM1elHoysOEql00bU4JxVhQL U5Zw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-wireless-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v3si31373421oif.122.2020.01.06.07.11.28; Mon, 06 Jan 2020 07:11:39 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-wireless-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-wireless-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726510AbgAFPKc (ORCPT + 99 others); Mon, 6 Jan 2020 10:10:32 -0500 Received: from smail.rz.tu-ilmenau.de ([141.24.186.67]:41875 "EHLO smail.rz.tu-ilmenau.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726427AbgAFPKb (ORCPT ); Mon, 6 Jan 2020 10:10:31 -0500 Received: from localhost.localdomain (unknown [141.24.207.101]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smail.rz.tu-ilmenau.de (Postfix) with ESMTPSA id DC43258006C; Mon, 6 Jan 2020 16:10:29 +0100 (CET) From: Markus Theil To: johannes@sipsolutions.net Cc: linux-wireless@vger.kernel.org, Markus Theil Subject: [PATCH 1/4] iw: event: handle interface add/del Date: Mon, 6 Jan 2020 16:10:21 +0100 Message-Id: <20200106151024.124315-2-markus.theil@tu-ilmenau.de> X-Mailer: git-send-email 2.24.1 In-Reply-To: <20200106151024.124315-1-markus.theil@tu-ilmenau.de> References: <20200106151024.124315-1-markus.theil@tu-ilmenau.de> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-wireless-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org Signed-off-by: Markus Theil --- event.c | 28 +++++++++++++++++++++++----- 1 file changed, 23 insertions(+), 5 deletions(-) diff --git a/event.c b/event.c index 2a12ca6..baeafae 100644 --- a/event.c +++ b/event.c @@ -668,9 +668,22 @@ static void parse_new_peer_candidate(struct nlattr **attrs) printf("\n"); } -static void parse_set_interface(struct nlattr **attrs) +static void parse_recv_interface(struct nlattr **attrs, int command) { - printf("set interface"); + switch (command) { + case NL80211_CMD_NEW_INTERFACE: + printf("new interface"); + break; + case NL80211_CMD_DEL_INTERFACE: + printf("del interface"); + break; + case NL80211_CMD_SET_INTERFACE: + printf("set interface"); + break; + default: + printf("unknown interface command (%i) received\n", command); + return; + } if (attrs[NL80211_ATTR_IFTYPE]) { printf(" type "); @@ -787,8 +800,11 @@ static int print_event(struct nl_msg *msg, void *arg) genlmsg_attrlen(gnlh, 0), NULL); if (tb[NL80211_ATTR_IFINDEX] && tb[NL80211_ATTR_WIPHY]) { - if_indextoname(nla_get_u32(tb[NL80211_ATTR_IFINDEX]), ifname); - printf("%s (phy #%d): ", ifname, nla_get_u32(tb[NL80211_ATTR_WIPHY])); + /* if_indextoname may fails on delete interface/wiphy event */ + if(if_indextoname(nla_get_u32(tb[NL80211_ATTR_IFINDEX]), ifname)) + printf("%s (phy #%d): ", ifname, nla_get_u32(tb[NL80211_ATTR_WIPHY])); + else + printf("phy #%d: ", nla_get_u32(tb[NL80211_ATTR_WIPHY])); } else if (tb[NL80211_ATTR_WDEV] && tb[NL80211_ATTR_WIPHY]) { printf("wdev 0x%llx (phy #%d): ", (unsigned long long)nla_get_u64(tb[NL80211_ATTR_WDEV]), @@ -1095,8 +1111,10 @@ static int print_event(struct nl_msg *msg, void *arg) case NL80211_CMD_NEW_PEER_CANDIDATE: parse_new_peer_candidate(tb); break; + case NL80211_CMD_NEW_INTERFACE: case NL80211_CMD_SET_INTERFACE: - parse_set_interface(tb); + case NL80211_CMD_DEL_INTERFACE: + parse_recv_interface(tb, gnlh->cmd); break; case NL80211_CMD_STA_OPMODE_CHANGED: parse_sta_opmode_changed(tb); -- 2.24.1