From patchwork Thu May 16 13:28:27 2013 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Arend van Spriel X-Patchwork-Id: 244313 Return-Path: X-Original-To: patchwork-incoming@ozlabs.org Delivered-To: patchwork-incoming@ozlabs.org Received: from maxx.maxx.shmoo.com (maxx.shmoo.com [205.134.188.171]) (using TLSv1 with cipher DHE-RSA-AES256-SHA (256/256 bits)) (Client CN "maxx.shmoo.com", Issuer "CA Cert Signing Authority" (not verified)) by ozlabs.org (Postfix) with ESMTPS id 978652C0160 for ; Thu, 16 May 2013 23:32:30 +1000 (EST) Received: from localhost (localhost [127.0.0.1]) by maxx.maxx.shmoo.com (Postfix) with ESMTP id D75779D205; Thu, 16 May 2013 09:31:32 -0400 (EDT) X-Virus-Scanned: amavisd-new at maxx.shmoo.com Received: from maxx.maxx.shmoo.com ([127.0.0.1]) by localhost (maxx.shmoo.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id KJN-hCaIo6zi; Thu, 16 May 2013 09:31:32 -0400 (EDT) Received: from maxx.shmoo.com (localhost [127.0.0.1]) by maxx.maxx.shmoo.com (Postfix) with ESMTP id 0C2B99D250; Thu, 16 May 2013 09:29:19 -0400 (EDT) X-Original-To: mailman-post+hostap@maxx.shmoo.com Delivered-To: mailman-post+hostap@maxx.shmoo.com Received: from localhost (localhost [127.0.0.1]) by maxx.maxx.shmoo.com (Postfix) with ESMTP id 8522D9D250 for ; Thu, 16 May 2013 09:29:18 -0400 (EDT) X-Virus-Scanned: amavisd-new at maxx.shmoo.com Received: from maxx.maxx.shmoo.com ([127.0.0.1]) by localhost (maxx.shmoo.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id Zf1QBdWbyAQj for ; Thu, 16 May 2013 09:29:13 -0400 (EDT) Received: from mms1.broadcom.com (mms1.broadcom.com [216.31.210.17]) by maxx.maxx.shmoo.com (Postfix) with ESMTP id 30FF89D205 for ; Thu, 16 May 2013 09:28:51 -0400 (EDT) Received: from [10.9.208.57] by mms1.broadcom.com with ESMTP (Broadcom SMTP Relay (Email Firewall v6.5)); Thu, 16 May 2013 06:25:09 -0700 X-Server-Uuid: 06151B78-6688-425E-9DE2-57CB27892261 Received: from IRVEXCHSMTP1.corp.ad.broadcom.com (10.9.207.51) by IRVEXCHCAS08.corp.ad.broadcom.com (10.9.208.57) with Microsoft SMTP Server (TLS) id 14.1.438.0; Thu, 16 May 2013 06:28:43 -0700 Received: from mail-sj1-12.sj.broadcom.com (10.10.10.20) by IRVEXCHSMTP1.corp.ad.broadcom.com (10.9.207.51) with Microsoft SMTP Server id 14.1.438.0; Thu, 16 May 2013 06:28:43 -0700 Received: from arend-ubuntu-1 (unknown [10.176.68.33]) by mail-sj1-12.sj.broadcom.com (Postfix) with ESMTP id C5BBA207DB; Thu, 16 May 2013 06:28:40 -0700 (PDT) Received: from arend by arend-ubuntu-1 with local (Exim 4.80) ( envelope-from ) id 1UcyEZ-0008Oo-G9; Thu, 16 May 2013 15:28:39 +0200 From: "Arend van Spriel" To: "Jouni Malinen" Subject: [PATCH 12/20] driver: nl80211: remove P2P Device interface upon .deinit() Date: Thu, 16 May 2013 15:28:27 +0200 Message-ID: <1368710915-32176-13-git-send-email-arend@broadcom.com> X-Mailer: git-send-email 1.7.10.4 In-Reply-To: <1368710915-32176-1-git-send-email-arend@broadcom.com> References: <1368710915-32176-1-git-send-email-arend@broadcom.com> MIME-Version: 1.0 X-WSS-ID: 7D8A01BF31W20416631-01-01 Cc: hostap@lists.shmoo.com X-BeenThere: hostap@lists.shmoo.com X-Mailman-Version: 2.1.11 Precedence: list List-Id: HostAP Project List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: hostap-bounces@lists.shmoo.com Errors-To: hostap-bounces@lists.shmoo.com The .deinit() closes netlink for P2P Device. Before doing that remove the P2P Device interface that was created by wpa_s. Signed-hostap: Arend van Spriel --- src/drivers/driver_nl80211.c | 41 ++++++++++++++++++++++++++++++++++------- 1 file changed, 34 insertions(+), 7 deletions(-) diff --git a/src/drivers/driver_nl80211.c b/src/drivers/driver_nl80211.c index afdb098..a8d288f 100644 --- a/src/drivers/driver_nl80211.c +++ b/src/drivers/driver_nl80211.c @@ -3735,25 +3735,51 @@ static void wpa_driver_nl80211_send_rfkill(void *eloop_ctx, void *timeout_ctx) wpa_supplicant_event(timeout_ctx, EVENT_INTERFACE_DISABLED, NULL); } -static int nl80211_start_p2pdev(struct i802_bss *bss) +static void nl80211_del_p2pdev(struct i802_bss *bss) { struct wpa_driver_nl80211_data *drv = bss->drv; struct nl_msg *msg; - int ret = -1; + int ret; + + msg = nlmsg_alloc(); + if (!msg) + return; - wpa_printf(MSG_DEBUG, "nl80211: start p2p device %s (%" PRIx64 ")", - bss->ifname, bss->wdev_id); + nl80211_cmd(drv, msg, 0, NL80211_CMD_DEL_INTERFACE); + NLA_PUT_U64(msg, NL80211_ATTR_WDEV, bss->wdev_id); + + ret = send_and_recv_msgs(drv, msg, NULL, NULL); + msg = NULL; + + wpa_printf(MSG_DEBUG, "nl80211: delete p2p device %s (%" PRIx64 "): %s", + bss->ifname, bss->wdev_id, strerror(ret)); +nla_put_failure: + nlmsg_free(msg); + return; +} + +static int nl80211_set_p2pdev(struct i802_bss *bss, int start) +{ + struct wpa_driver_nl80211_data *drv = bss->drv; + struct nl_msg *msg; + int ret = -1; msg = nlmsg_alloc(); if (!msg) return -1; - nl80211_cmd(drv, msg, 0, NL80211_CMD_START_P2P_DEVICE); + if (start) + nl80211_cmd(drv, msg, 0, NL80211_CMD_START_P2P_DEVICE); + else + nl80211_cmd(drv, msg, 0, NL80211_CMD_STOP_P2P_DEVICE); NLA_PUT_U64(msg, NL80211_ATTR_WDEV, bss->wdev_id); ret = send_and_recv_msgs(drv, msg, NULL, NULL); msg = NULL; + wpa_printf(MSG_DEBUG, "nl80211: %s p2p device %s (%" PRIx64 "): %s", + start ? "start" : "stop", bss->ifname, bss->wdev_id, + strerror(ret)); nla_put_failure: nlmsg_free(msg); return ret; @@ -3819,7 +3845,7 @@ wpa_driver_nl80211_finish_drv_init(struct wpa_driver_nl80211_data *drv) return -1; if (nlmode == NL80211_IFTYPE_P2P_DEVICE) { - int ret = nl80211_start_p2pdev(bss); + int ret = nl80211_set_p2pdev(bss, 1); if (ret < 0) wpa_printf(MSG_ERROR, "nl80211: could not start P2P device"); return ret; @@ -3942,7 +3968,8 @@ static void wpa_driver_nl80211_deinit(struct i802_bss *bss) (void)i802_set_iface_flags(bss, 0); wpa_driver_nl80211_set_mode(bss, NL80211_IFTYPE_STATION); nl80211_mgmt_unsubscribe(bss, "deinit"); - + if (nl80211_get_ifmode(bss) == NL80211_IFTYPE_P2P_DEVICE) + nl80211_del_p2pdev(bss); nl_cb_put(drv->nl_cb); nl80211_destroy_bss(&drv->first_bss);