From patchwork Mon Jun 10 05:11:15 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: Sebastian Gottschall X-Patchwork-Id: 10990277 Return-Path: Received: from mail.wl.linuxfoundation.org (pdx-wl-mail.web.codeaurora.org [172.30.200.125]) by pdx-korg-patchwork-2.web.codeaurora.org (Postfix) with ESMTP id A845C13AD for ; Wed, 12 Jun 2019 16:00:09 +0000 (UTC) Received: from mail.wl.linuxfoundation.org (localhost [127.0.0.1]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id 988B428A44 for ; Wed, 12 Jun 2019 16:00:09 +0000 (UTC) Received: by mail.wl.linuxfoundation.org (Postfix, from userid 486) id 8C68828A4C; Wed, 12 Jun 2019 16:00:09 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on pdx-wl-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-5.2 required=2.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,MAILING_LIST_MULTI,RCVD_IN_DNSWL_MED autolearn=ham version=3.3.1 Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.wl.linuxfoundation.org (Postfix) with ESMTPS id 6F82328A46 for ; Wed, 12 Jun 2019 16:00:08 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20170209; h=Sender:Content-Type: Content-Transfer-Encoding:Cc:List-Subscribe:List-Help:List-Post:List-Archive: List-Unsubscribe:List-Id:In-Reply-To:MIME-Version:Date:Message-ID:References: To:From:Subject:Reply-To:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=Ggj7Wf7bCu5Z7wQkWsd/WjG7SNGA4xTjcJUsgxgLnrQ=; b=cdOOnOEDKgS0OfvZekHD/sqj+ x2vFkGCtDnITVHDPnvvOefU5NEwqQAc4RtJWQmO9ux51V904SFnC3uOKS+JczABVe0HAmCiYdopte ZnsLo3f8qQi7CQSFOjrOiTBademkJgIBT7XgTDS5xg45mHUbvhnvrIwIhFEiBOb3K95pwBKGo67he BLLXRUuZK1OOdVV3rhCHcqLNyQXqCCe6Po+V0uPp9KZWyyzGDP6DF1Q18qwP6LpAUSijQ7fHxGYXO 7bgqAFLI1jfQNK0jo8xliMFtXogVoCr3F3Pl8aGLNHNk7PFeS5kre463o8IjRvT2gkNjkSS6F4jon q7OlLsiKw==; Received: from localhost ([127.0.0.1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.92 #3 (Red Hat Linux)) id 1hb5fS-00063a-KO; Wed, 12 Jun 2019 16:00:06 +0000 Received: from smtps.newmedia-net.de ([2a05:a1c0:0:de::167] helo=webmail.newmedia-net.de) by bombadil.infradead.org with esmtps (Exim 4.92 #3 (Red Hat Linux)) id 1haCaW-0005Ah-2V for linux-mediatek@lists.infradead.org; Mon, 10 Jun 2019 05:11:22 +0000 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=newmedia-net.de; s=mikd; h=Content-Transfer-Encoding:Content-Type:In-Reply-To:MIME-Version:Date:Message-ID:References:Cc:To:From:Subject; bh=vHvqO36rgNxEIk194ajJnKV4ToM132hVV+XGxAFMsGg=; b=zVCfIp4chS2BFHy8dYiYHRBCQG94hshNGbr34qw8Yqa7ed+EkbGvLiAF2KhVgdKVGnYlHVyA2nD5K+IxM1gW5DpdEeol9crFT+O+f7x2X8LhXxtAEJ4RmbU4kSJbBezy5AGszDaRTurW6AF3qyHUbtCjDQshBMLrs73ChITkNPw=; Subject: possible fix for broken cmac crypto support From: Sebastian Gottschall To: Lorenzo Bianconi References: <0eea6d21-1de2-abc3-93f4-70ed04dac3df@newmedia-net.de> Message-ID: Date: Mon, 10 Jun 2019 07:11:15 +0200 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:60.0) Gecko/20100101 Thunderbird/60.7.0 MIME-Version: 1.0 In-Reply-To: <0eea6d21-1de2-abc3-93f4-70ed04dac3df@newmedia-net.de> X-Received: from [2003:c9:3f05:3a00:f095:7be4:6d09:fd49] by webmail.newmedia-net.de with esmtpsa (TLSv1:AES128-SHA:128) (Exim 4.72) (envelope-from ) id 1haCab-0007AN-4P; Mon, 10 Jun 2019 07:11:25 +0200 X-Bad-Reply: References and In-Reply-To but no 'Re:' in Subject. X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20190609_221120_557125_FB1C7563 X-CRM114-Status: GOOD ( 18.40 ) X-Mailman-Approved-At: Wed, 12 Jun 2019 09:00:03 -0700 X-BeenThere: linux-mediatek@lists.infradead.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Ryder Lee , linux-wireless , YF Luo , Chih-Min Chen , Linux Kernel Mailing List , Yiwei Chung , linux-mediatek@lists.infradead.org, Sean Wang , Roy Luo , Felix Fietkau Sender: "Linux-mediatek" Errors-To: linux-mediatek-bounces+patchwork-linux-mediatek=patchwork.kernel.org@lists.infradead.org X-Virus-Scanned: ClamAV using ClamSMTP this is no real patch for this mailing list since i havent cloned yet a git tree. take it as a hint this fixes the BUG WARN if SAE encryption is used (mandatory for mesh / 802.11s crypto) that will not fix that mesh is not working (likelly just with other vendors), but it will fix crypto at least Sebastian Am 09.06.2019 um 16:36 schrieb Sebastian Gottschall: > by the way. this big fat kernel warning exists in all operation modes > unless anything else but aes-128 ccmp is used. since the chipset is > capable of doing gcmp etc. as well > it would be nice if this issue can be fixed. otherwise encryption > support can be defined as "broken" for mt7615 > > Am 06.06.2019 um 18:19 schrieb Lorenzo Bianconi: >>> i tested your patch against a qca 9984 chipset using SAE and without >>> encryption. both did not work. the devices are connecting, but no data >>> connection is possible >> Hi Sebastian, >> >> I tested Ryder's patch using mt76x2 as mesh peer and it works fine >> for me. >> Could you please provide some more info? >> >> Regards, >> Lorenzo >> >>> >>> Sebastian >>> >>> Am 03.06.2019 um 08:08 schrieb Ryder Lee: >>>> Enable NL80211_IFTYPE_MESH_POINT and update its path. >>>> >>>> Signed-off-by: Ryder Lee >>>> --- >>>> Changes since v3 - fix a wrong expression >>>> Changes since v2 - remove unused definitions >>>> --- >>>>    drivers/net/wireless/mediatek/mt76/mt7615/init.c | 6 ++++++ >>>>    drivers/net/wireless/mediatek/mt76/mt7615/main.c | 1 + >>>>    drivers/net/wireless/mediatek/mt76/mt7615/mcu.c  | 4 +++- >>>>    drivers/net/wireless/mediatek/mt76/mt7615/mcu.h  | 6 ------ >>>>    4 files changed, 10 insertions(+), 7 deletions(-) >>>> >>>> diff --git a/drivers/net/wireless/mediatek/mt76/mt7615/init.c >>>> b/drivers/net/wireless/mediatek/mt76/mt7615/init.c >>>> index 59f604f3161f..f860af6a42da 100644 >>>> --- a/drivers/net/wireless/mediatek/mt76/mt7615/init.c >>>> +++ b/drivers/net/wireless/mediatek/mt76/mt7615/init.c >>>> @@ -133,6 +133,9 @@ static const struct ieee80211_iface_limit >>>> if_limits[] = { >>>>        { >>>>                .max = MT7615_MAX_INTERFACES, >>>>                .types = BIT(NL80211_IFTYPE_AP) | >>>> +#ifdef CONFIG_MAC80211_MESH >>>> +                      BIT(NL80211_IFTYPE_MESH_POINT) | >>>> +#endif >>>>                         BIT(NL80211_IFTYPE_STATION) >>>>        } >>>>    }; >>>> @@ -195,6 +198,9 @@ int mt7615_register_device(struct mt7615_dev *dev) >>>>        dev->mt76.antenna_mask = 0xf; >>>> >>>>        wiphy->interface_modes = BIT(NL80211_IFTYPE_STATION) | >>>> +#ifdef CONFIG_MAC80211_MESH >>>> + BIT(NL80211_IFTYPE_MESH_POINT) | >>>> +#endif >>>>                                 BIT(NL80211_IFTYPE_AP); >>>> >>>>        ret = mt76_register_device(&dev->mt76, true, mt7615_rates, >>>> diff --git a/drivers/net/wireless/mediatek/mt76/mt7615/main.c >>>> b/drivers/net/wireless/mediatek/mt76/mt7615/main.c >>>> index b0bb7cc12385..585e67fa2728 100644 >>>> --- a/drivers/net/wireless/mediatek/mt76/mt7615/main.c >>>> +++ b/drivers/net/wireless/mediatek/mt76/mt7615/main.c >>>> @@ -37,6 +37,7 @@ static int get_omac_idx(enum nl80211_iftype type, >>>> u32 mask) >>>> >>>>        switch (type) { >>>>        case NL80211_IFTYPE_AP: >>>> +     case NL80211_IFTYPE_MESH_POINT: >>>>                /* ap use hw bssid 0 and ext bssid */ >>>>                if (~mask & BIT(HW_BSSID_0)) >>>>                        return HW_BSSID_0; >>>> diff --git a/drivers/net/wireless/mediatek/mt76/mt7615/mcu.c >>>> b/drivers/net/wireless/mediatek/mt76/mt7615/mcu.c >>>> index 43f70195244c..e82297048449 100644 >>>> --- a/drivers/net/wireless/mediatek/mt76/mt7615/mcu.c >>>> +++ b/drivers/net/wireless/mediatek/mt76/mt7615/mcu.c >>>> @@ -754,6 +754,7 @@ int mt7615_mcu_set_bss_info(struct mt7615_dev >>>> *dev, >>>> >>>>        switch (vif->type) { >>>>        case NL80211_IFTYPE_AP: >>>> +     case NL80211_IFTYPE_MESH_POINT: >>>>                tx_wlan_idx = mvif->sta.wcid.idx; >>>>                conn_type = CONNECTION_INFRA_AP; >>>>                break; >>>> @@ -968,7 +969,7 @@ int mt7615_mcu_add_wtbl(struct mt7615_dev *dev, >>>> struct ieee80211_vif *vif, >>>>                .rx_wtbl = { >>>>                        .tag = cpu_to_le16(WTBL_RX), >>>>                        .len = cpu_to_le16(sizeof(struct wtbl_rx)), >>>> -                     .rca1 = vif->type != NL80211_IFTYPE_AP, >>>> +                     .rca1 = vif->type == NL80211_IFTYPE_STATION, >>>>                        .rca2 = 1, >>>>                        .rv = 1, >>>>                }, >>>> @@ -1042,6 +1043,7 @@ static void sta_rec_convert_vif_type(enum >>>> nl80211_iftype type, u32 *conn_type) >>>>    { >>>>        switch (type) { >>>>        case NL80211_IFTYPE_AP: >>>> +     case NL80211_IFTYPE_MESH_POINT: >>>>                if (conn_type) >>>>                        *conn_type = CONNECTION_INFRA_STA; >>>>                break; >>>> diff --git a/drivers/net/wireless/mediatek/mt76/mt7615/mcu.h >>>> b/drivers/net/wireless/mediatek/mt76/mt7615/mcu.h >>>> index e96efb13fa4d..0915cb735699 100644 >>>> --- a/drivers/net/wireless/mediatek/mt76/mt7615/mcu.h >>>> +++ b/drivers/net/wireless/mediatek/mt76/mt7615/mcu.h >>>> @@ -105,25 +105,19 @@ enum { >>>>    #define STA_TYPE_STA                BIT(0) >>>>    #define STA_TYPE_AP         BIT(1) >>>>    #define STA_TYPE_ADHOC              BIT(2) >>>> -#define STA_TYPE_TDLS                BIT(3) >>>>    #define STA_TYPE_WDS                BIT(4) >>>>    #define STA_TYPE_BC         BIT(5) >>>> >>>>    #define NETWORK_INFRA               BIT(16) >>>>    #define NETWORK_P2P         BIT(17) >>>>    #define NETWORK_IBSS                BIT(18) >>>> -#define NETWORK_MESH         BIT(19) >>>> -#define NETWORK_BOW          BIT(20) >>>>    #define NETWORK_WDS         BIT(21) >>>> >>>>    #define CONNECTION_INFRA_STA        (STA_TYPE_STA | NETWORK_INFRA) >>>>    #define CONNECTION_INFRA_AP (STA_TYPE_AP | NETWORK_INFRA) >>>>    #define CONNECTION_P2P_GC   (STA_TYPE_STA | NETWORK_P2P) >>>>    #define CONNECTION_P2P_GO   (STA_TYPE_AP | NETWORK_P2P) >>>> -#define CONNECTION_MESH_STA  (STA_TYPE_STA | NETWORK_MESH) >>>> -#define CONNECTION_MESH_AP   (STA_TYPE_AP | NETWORK_MESH) >>>>    #define CONNECTION_IBSS_ADHOC       (STA_TYPE_ADHOC | NETWORK_IBSS) >>>> -#define CONNECTION_TDLS              (STA_TYPE_STA | NETWORK_INFRA >>>> | STA_TYPE_TDLS) >>>>    #define CONNECTION_WDS              (STA_TYPE_WDS | NETWORK_WDS) >>>>    #define CONNECTION_INFRA_BC (STA_TYPE_BC | NETWORK_INFRA) >>>> > Index: main.c =================================================================== --- main.c      (revision 4584) +++ main.c      (revision 4585) @@ -180,6 +180,20 @@ static int mt7615_set_key(struct ieee80211_hw *hw,             !(key->flags & IEEE80211_KEY_FLAG_PAIRWISE))                 return -EOPNOTSUPP; +       switch (key->cipher) { +       case WLAN_CIPHER_SUITE_WEP40: +       case WLAN_CIPHER_SUITE_WEP104: +       case WLAN_CIPHER_SUITE_TKIP: +       case WLAN_CIPHER_SUITE_CCMP: +       case WLAN_CIPHER_SUITE_CCMP_256: +       case WLAN_CIPHER_SUITE_GCMP: +       case WLAN_CIPHER_SUITE_GCMP_256: +       case WLAN_CIPHER_SUITE_SMS4: +               break; +       default: +               return -EOPNOTSUPP; +       } +         if (cmd == SET_KEY) {                 key->hw_key_idx = wcid->idx;                 wcid->hw_key_idx = idx;