From patchwork Wed Dec 23 15:39:01 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: =?utf-8?b?SsOpcsO0bWUgUG91aWxsZXI=?= X-Patchwork-Id: 11988455 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-16.7 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH,MAILING_LIST_MULTI, MENTIONS_GIT_HOSTING,MSGID_FROM_MTA_HEADER,SPF_HELO_NONE,SPF_PASS, URIBL_BLOCKED,USER_AGENT_GIT autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id C1B03C43381 for ; Wed, 23 Dec 2020 15:40:40 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id A7AFF233FB for ; Wed, 23 Dec 2020 15:40:40 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728012AbgLWPke (ORCPT ); Wed, 23 Dec 2020 10:40:34 -0500 Received: from mail-mw2nam12on2068.outbound.protection.outlook.com ([40.107.244.68]:31200 "EHLO NAM12-MW2-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1727207AbgLWPkd (ORCPT ); Wed, 23 Dec 2020 10:40:33 -0500 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=LEQ5+AwyU4EHTX3ASROSvZvdX6eVpnGJrEGpprEmvQdY+Eti9dF3HsdBQeCjHNV/9dBQkpETBjeG0gzKmA/l1taDU5DSsUb0QoNgIBvno296sM3+EmH4M7bkQrd6yGsx7v4lJQ1pFAKTCaiuu2VhclwIKB3Jy0AAYFzHNjdv/ITMuyDhuf4mVOXS0HbmAHG0yycdci2GirC6RKzkPy7Fj4ogWweXRErgFApIyLN2gtm5n6dgiN79/HHHerz3/V78C8fwBhfYPO79fJnwohMT5mxo+oZbUZR2DTiFZCLvhVrKTYHTV3RNZrYAxMNfeAB+wZlcrBfVF9PBExf8pC1Etw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=WD3dCTRfGtgEK3azB1MzZj5EjgMD/gjv3Xfh3qKE+6o=; b=bkoWncz52CQblbnxxwr7ijOPynyWyZR+4echkVx1ay6OFO23rloPmG/4o3iU2h74vgfBs8sBk0EjAHWz5HFSvWzleobw9j2vXTzKeOErhWjC78p+oMgoG2xtgrn50GvFDbZTUzXrV+oR6bNLOiEZUD2Ee5cELH8H063vcAF6hnudyLg0nhfIOj4xytpGcS3U7OKBLT85IJU1oDZlchM9AYhmyjkhpJ1I753iHxcmbuIgZowOuMfKjibZhnzAmSWUtLW/9jVqFw7n0GEW/ojEOO1zcnxUyrZo2YK6v6TOFmCY4oIqqPjLNpOSnfcq1hG0FE17OJx8Ss1WkUSpQrjSIg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=silabs.com; dmarc=pass action=none header.from=silabs.com; dkim=pass header.d=silabs.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=silabs.onmicrosoft.com; s=selector2-silabs-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=WD3dCTRfGtgEK3azB1MzZj5EjgMD/gjv3Xfh3qKE+6o=; b=RlMoyyJGIYue/WoxlUSKUQb2OPcorlnGGexsf5Poj2mlnZa6Z96hVtEa0cLtPqHhq6mRoUdtH2iaRiIvUVxzW8xveA0bkfAcgFyjdcebZ/Xh4m0Un29gM11y75Pkn/eOGaXnQIAqHnJSi+x6mL7q2KZvN/4QPvJC59wzqGJzABY= Authentication-Results: vger.kernel.org; dkim=none (message not signed) header.d=none;vger.kernel.org; dmarc=none action=none header.from=silabs.com; Received: from SN6PR11MB2718.namprd11.prod.outlook.com (2603:10b6:805:63::18) by SN6PR11MB2815.namprd11.prod.outlook.com (2603:10b6:805:62::13) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3676.25; Wed, 23 Dec 2020 15:39:43 +0000 Received: from SN6PR11MB2718.namprd11.prod.outlook.com ([fe80::a989:f850:6736:97ca]) by SN6PR11MB2718.namprd11.prod.outlook.com ([fe80::a989:f850:6736:97ca%5]) with mapi id 15.20.3700.026; Wed, 23 Dec 2020 15:39:43 +0000 From: Jerome Pouiller To: linux-wireless@vger.kernel.org, netdev@vger.kernel.org Cc: devel@driverdev.osuosl.org, linux-kernel@vger.kernel.org, Greg Kroah-Hartman , Kalle Valo , "David S . Miller" , devicetree@vger.kernel.org, Rob Herring , linux-mmc@vger.kernel.org, =?utf-8?q?Pali_Roh=C3=A1r?= , Ulf Hansson , =?utf-8?b?SsOpcsO0bWUgUG91aWxsZXI=?= Subject: [PATCH v4 00/24] wfx: get out from the staging area Date: Wed, 23 Dec 2020 16:39:01 +0100 Message-Id: <20201223153925.73742-1-Jerome.Pouiller@silabs.com> X-Mailer: git-send-email 2.29.2 X-Originating-IP: [82.67.86.106] X-ClientProxiedBy: SA0PR12CA0024.namprd12.prod.outlook.com (2603:10b6:806:6f::29) To SN6PR11MB2718.namprd11.prod.outlook.com (2603:10b6:805:63::18) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from pc-42.silabs.com (82.67.86.106) by SA0PR12CA0024.namprd12.prod.outlook.com (2603:10b6:806:6f::29) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3700.27 via Frontend Transport; Wed, 23 Dec 2020 15:39:41 +0000 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 04d3e975-f58f-4926-c5a1-08d8a758f80e X-MS-TrafficTypeDiagnostic: SN6PR11MB2815: X-MS-Exchange-Transport-Forked: True X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:3044; X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: +gf3Xfhmz4LxG53/Zvzh1HFbVEkIY7GAag7XeXgCGqmXXwM3yNi1jHxEDDtgjDq8SqbE9+4uZ0EaOfme2rwTXmOUz/sNU59knTcsLXUaW6CA/pODK2FnsymhWd2MXDGcOFsKXzvCTCz0Rog6pNNYUEjHghmcaMIygfxYYB6e3OZA1W3NJ9VANuDv5xBoAud8O5KjeISaiS245MZ8+avpilFN5dSTelSBZiiZqx2pO1LFFMDo7mmM+MLpT3F452GfN/kS307BXJMW5sMQO6LHz9JDTuaMvtxRQZwMTllPdTpDU7wKdZLbevdZ0pZki6CfXV7oPjl9wY06exArfZKFUHcvrZzgtdDvLjSlIjZ1Vv7CTEq9gGVk7Rvy00akKWUg3U77YD1Ea6Tn5uhRLLZJJF4hvsvuHhA5KwtBvbVZpG/tlfMmFzFeJg/k6SS7SaeMvmGESyKReP4AO0wBYKno5Q== X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:SN6PR11MB2718.namprd11.prod.outlook.com;PTR:;CAT:NONE;SFS:(396003)(136003)(366004)(376002)(39850400004)(346002)(66574015)(478600001)(83380400001)(966005)(8676002)(186003)(2906002)(8936002)(26005)(52116002)(107886003)(16526019)(7696005)(66946007)(7416002)(6486002)(956004)(2616005)(54906003)(66476007)(316002)(4326008)(6666004)(36756003)(5660300002)(1076003)(86362001)(66556008);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData: =?utf-8?q?BNuzQS5E5SPJb7v2lKYVI548Rkc3of?= =?utf-8?q?SgnAgJP5j6yCP+5pKa80tROvIXXFyV6aXz8gxIM36ijQRixfKq6qTfoX/ttCgsTqU?= =?utf-8?q?nwCOmA8d7BqAGRfNV6SuyOeIwW9xZrH8yW5+DUO5j67OPQsoTRy7FlesGlvw67J2e?= =?utf-8?q?4iOdLT9gYnc5mhquz8M16s9vxf8VKXtHSWWK6IacbhtV+MHVhpV2I6oSm+4c+eLSY?= =?utf-8?q?wYp61x8ZH5tgh4lkiUNGBgEOQ1mVSDYgygPu1L5WJW8jo7tPz7LaTUFmMwb3/RIWO?= =?utf-8?q?txCrxyENfZBLs8zDCTEv6d3T3bpfOz1ugiDtjPXcKE3r7l4RvLSDLSArP4vtNyitZ?= =?utf-8?q?oigq+VCqf2+CCy9tYXebDz76kOKGG66nKbvM9ZdAnETsGfye3HtuxxhDQWqV7STYn?= =?utf-8?q?pONgcQ6gmJpBwj1Jpm24Im6pDSm0RR4xolX55pUkTgvaDju4z50n/f+vgZ5tK1U+I?= =?utf-8?q?06xTLgQVeL5g/3xqLWR5m3fvo1ZsuDVMOh8oH1aqPgjNW7rAtC5+2j9gs6LLE05zV?= =?utf-8?q?63/F73vpNnvWimrwSj1WTk2UMlBcGNwWI7RkWa+WmQLymIMgvQHBcp9Jv8BZ2XmmB?= =?utf-8?q?oJ0VJYkaPN6ky0DdslvqqCeMrFKEllnTDKG6IE2EAJz7tNoJIc/K2GgOLHnCXC+Sh?= =?utf-8?q?9IXSSkm0tP7wiPND4oWzDtHnf+Rn8QuVnWPvMGqdKN7gBce4rQL4TdR7MTS+I2hkr?= =?utf-8?q?dNY3Z1QLutrDNR0HLwG07RhYrM5HJXZ6Dnqm+/DSravfColAq2MWJ4bVDN7bTqBth?= =?utf-8?q?z70JPgOFmn3Q1W6YDdhqWEV6QZlKbQl4LNvIUDuBdrEJMx6yQhcuTxzoZ89RN76bR?= =?utf-8?q?OoKpYhkvlAsEMPMbr0QQdScJFifhDAccFzio/Z0Pvs7Q5iZP1L2MnLNNmQoPPJp4r?= =?utf-8?q?N7Q5BRQ4lmcW4hkJlUdth0SuHgXIdhB5VC4f4WIjfOrODEpOjYuTHU8Jx5WKfwi4L?= =?utf-8?q?BOKpDSD8SnjCbdEjylA?= X-OriginatorOrg: silabs.com X-MS-Exchange-CrossTenant-AuthSource: SN6PR11MB2718.namprd11.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 23 Dec 2020 15:39:43.2833 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 54dbd822-5231-4b20-944d-6f4abcd541fb X-MS-Exchange-CrossTenant-Network-Message-Id: 04d3e975-f58f-4926-c5a1-08d8a758f80e X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: 0HUN2OHE8iJWVm7bvQUaYo3uNJQ4TeNdYa8iR9ELs4aFUE9+BITpAOTDvuKqLROBXROYlI3wjGinGQJLQEMRkw== X-MS-Exchange-Transport-CrossTenantHeadersStamped: SN6PR11MB2815 Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org From: Jérôme Pouiller I think the wfx driver is now mature enough to be accepted in the drivers/net/wireless directory. The firmware associated with this driver is available here[1]. It is not yet available in linux-firmware, but I am working on the PR. [1]: https://github.com/SiliconLabs/wfx-firmware As requested by Kalle[2], I send one file per patch. At the end, all the patches (or at least the patches 3 to 24) will be squashed (therefore, I didn't bother to write real commit messages). [2]: https://lore.kernel.org/lkml/87ft6p2n0h.fsf@codeaurora.org/ Here is a diagram of the global architecture that may help to understand the code: ,------------------------------------. | mac80211 | `------------------------------------' ,------------+-----------+-----------. | sta | | | | scan | | | | main | | | +------------+ data_tx | | | key | | data_rx | | hif_tx_mib | queue | | | hif_tx | | | | hif_rx | | | | hif_api_* | | | +------------+-----------+-----------+--------. | bh | fwio | +------------------------------------+--------+ | hwio | +---------------------------------------------+ | bus_sdio | | bus_spi | `---------------------------------------------' ,---------------------------------------------. | spi / sdio | `---------------------------------------------' Roughly, I have sent the files from the bottom to the top. Below the differences with the files from drivers/staging/wfx/: v4: - Rebase on last staging tree - Add 'additionalProperties: false' to the DT specification (I have made that change blindly because I am able to reproduce the Rob's error) (Rob) - Replace C++ comments with Ansi C comments (Kalle) - Check that existing Ansi C comments comply with net/ "compact" style - Drop one obsolete comment - Remove comments after '#endif' in header files - Remove macro redefinitions in hif_api_general.h (Kalle) - Replace compiletime_assert() with BUILD_BUG_ON_MSG() (Kalle) - Rename ieee80211_is_action_back() (Kalle) - Add a comment explaining how the PDS isent to the device (Kalle) - Add a comment about case where CONFIG_MMC==m in the Makefile (Kalle) - Fix irrelevant comment about CONFIG_VMAP_STACK (Kalle) - Talk about the unreliable SDIO Vendor ID in the Kconfig help (Kalle) - Mention the firmware status in the cover letter (Kalle) - Fix misaligned function arguments in key.c v3: - dt-bindings: Rename config-file property (Rob) - dt-bindings: No additional properties are allowed (spi-max-frequency is already listed) (Rob) - dt-bindings: Remove references for mac-address properties (Rob) - Rebase on staging/staging-next v2: - dt-bindings: Improve device description and add link to the datasheet (Rob) - dt-bindings: Add blank lines between each DT property (Rob) - dt-bindings: Explicitly mention mac-address and local-mac-address and add references to ethernet-controller.yaml (Rob) - dt-bindings: "config-file" is not for development/debug (Rob) - dt-bindings: Remove description of "spi-max-frequency" (Rob) - dt-bindings: Use "folded scalar" syntax instead of escaping the colons - bus_sdio.c: A compatible node in the DT is now mandatory to probe the device. Also change documentation of dt-bindings accordingly (Pali, Ulf) - bus_sdio.c: Move SDIO IDs to sdio_ids.h (Pali) - bh.c: Import patch "staging: wfx: fix test on return value of gpiod_get_value()" (Nathan) - data_tx.c: Import patch "staging: wfx: fix use of uninitialized pointer" - sta.c: Import patch "staging: wfx: make a const array static, makes object smaller" (Colin) v1: - Drop the function name in the warning message (Kalle) - Replace goto by return in wfx_send_pdata_pds() (Kalle, Dan) - Improve error label in wfx_send_pdata_pds() (Kalle) Jérôme Pouiller (24): mmc: sdio: add SDIO IDs for Silabs WF200 chip dt-bindings: introduce silabs,wfx.yaml wfx: add Makefile/Kconfig wfx: add wfx.h wfx: add main.c/main.h wfx: add bus.h wfx: add bus_spi.c wfx: add bus_sdio.c wfx: add hwio.c/hwio.h wfx: add fwio.c/fwio.h wfx: add bh.c/bh.h wfx: add hif_api_*.h wfx: add hif_tx*.c/hif_tx*.h wfx: add key.c/key.h wfx: add hif_rx.c/hif_rx.h wfx: add data_rx.c/data_rx.h wfx: add queue.c/queue.h wfx: add data_tx.c/data_tx.h wfx: add sta.c/sta.h wfx: add scan.c/scan.h wfx: add debug.c/debug.h wfx: add traces.h wfx: remove from the staging area wfx: get out from the staging area .../bindings/net/wireless/silabs,wfx.yaml | 68 +++++++++------- MAINTAINERS | 3 +- drivers/net/wireless/Kconfig | 1 + drivers/net/wireless/Makefile | 1 + drivers/net/wireless/silabs/Kconfig | 18 +++++ drivers/net/wireless/silabs/Makefile | 3 + .../wireless/silabs}/wfx/Kconfig | 4 + .../wireless/silabs}/wfx/Makefile | 1 + .../{staging => net/wireless/silabs}/wfx/bh.c | 31 ++++---- .../{staging => net/wireless/silabs}/wfx/bh.h | 2 +- .../wireless/silabs}/wfx/bus.h | 0 .../wireless/silabs}/wfx/bus_sdio.c | 23 ++---- .../wireless/silabs}/wfx/bus_spi.c | 18 ++--- .../wireless/silabs}/wfx/data_rx.c | 5 +- .../wireless/silabs}/wfx/data_rx.h | 2 +- .../wireless/silabs}/wfx/data_tx.c | 65 +++++++++------- .../wireless/silabs}/wfx/data_tx.h | 4 +- .../wireless/silabs}/wfx/debug.c | 12 +-- .../wireless/silabs}/wfx/debug.h | 2 +- .../wireless/silabs}/wfx/fwio.c | 26 +++---- .../wireless/silabs}/wfx/fwio.h | 2 +- .../wireless/silabs}/wfx/hif_api_cmd.h | 12 +-- .../wireless/silabs}/wfx/hif_api_general.h | 23 +++--- .../wireless/silabs}/wfx/hif_api_mib.h | 2 +- .../wireless/silabs}/wfx/hif_rx.c | 17 ++-- .../wireless/silabs}/wfx/hif_rx.h | 0 .../wireless/silabs}/wfx/hif_tx.c | 32 ++++---- .../wireless/silabs}/wfx/hif_tx.h | 0 .../wireless/silabs}/wfx/hif_tx_mib.c | 4 +- .../wireless/silabs}/wfx/hif_tx_mib.h | 0 .../wireless/silabs}/wfx/hwio.c | 18 +---- .../wireless/silabs}/wfx/hwio.h | 22 +++--- .../wireless/silabs}/wfx/key.c | 30 +++---- .../wireless/silabs}/wfx/key.h | 2 +- .../wireless/silabs}/wfx/main.c | 37 ++++++--- .../wireless/silabs}/wfx/main.h | 3 +- .../wireless/silabs}/wfx/queue.c | 27 ++++--- .../wireless/silabs}/wfx/queue.h | 4 +- .../wireless/silabs}/wfx/scan.c | 3 +- .../wireless/silabs}/wfx/scan.h | 2 +- .../wireless/silabs}/wfx/sta.c | 78 ++++++++++--------- .../wireless/silabs}/wfx/sta.h | 8 +- .../wireless/silabs}/wfx/traces.h | 2 +- .../wireless/silabs}/wfx/wfx.h | 4 +- drivers/staging/Kconfig | 2 - drivers/staging/Makefile | 1 - drivers/staging/wfx/TODO | 6 -- include/linux/mmc/sdio_ids.h | 7 ++ 48 files changed, 339 insertions(+), 298 deletions(-) rename {drivers/staging/wfx/Documentation => Documentation}/devicetree/bindings/net/wireless/silabs,wfx.yaml (71%) create mode 100644 drivers/net/wireless/silabs/Kconfig create mode 100644 drivers/net/wireless/silabs/Makefile rename drivers/{staging => net/wireless/silabs}/wfx/Kconfig (65%) rename drivers/{staging => net/wireless/silabs}/wfx/Makefile (85%) rename drivers/{staging => net/wireless/silabs}/wfx/bh.c (93%) rename drivers/{staging => net/wireless/silabs}/wfx/bh.h (97%) rename drivers/{staging => net/wireless/silabs}/wfx/bus.h (100%) rename drivers/{staging => net/wireless/silabs}/wfx/bus_sdio.c (89%) rename drivers/{staging => net/wireless/silabs}/wfx/bus_spi.c (94%) rename drivers/{staging => net/wireless/silabs}/wfx/data_rx.c (95%) rename drivers/{staging => net/wireless/silabs}/wfx/data_rx.h (93%) rename drivers/{staging => net/wireless/silabs}/wfx/data_tx.c (91%) rename drivers/{staging => net/wireless/silabs}/wfx/data_tx.h (94%) rename drivers/{staging => net/wireless/silabs}/wfx/debug.c (96%) rename drivers/{staging => net/wireless/silabs}/wfx/debug.h (94%) rename drivers/{staging => net/wireless/silabs}/wfx/fwio.c (95%) rename drivers/{staging => net/wireless/silabs}/wfx/fwio.h (91%) rename drivers/{staging => net/wireless/silabs}/wfx/hif_api_cmd.h (97%) rename drivers/{staging => net/wireless/silabs}/wfx/hif_api_general.h (93%) rename drivers/{staging => net/wireless/silabs}/wfx/hif_api_mib.h (99%) rename drivers/{staging => net/wireless/silabs}/wfx/hif_rx.c (96%) rename drivers/{staging => net/wireless/silabs}/wfx/hif_rx.h (100%) rename drivers/{staging => net/wireless/silabs}/wfx/hif_tx.c (95%) rename drivers/{staging => net/wireless/silabs}/wfx/hif_tx.h (100%) rename drivers/{staging => net/wireless/silabs}/wfx/hif_tx_mib.c (98%) rename drivers/{staging => net/wireless/silabs}/wfx/hif_tx_mib.h (100%) rename drivers/{staging => net/wireless/silabs}/wfx/hwio.c (93%) rename drivers/{staging => net/wireless/silabs}/wfx/hwio.h (77%) rename drivers/{staging => net/wireless/silabs}/wfx/key.c (91%) rename drivers/{staging => net/wireless/silabs}/wfx/key.h (94%) rename drivers/{staging => net/wireless/silabs}/wfx/main.c (92%) rename drivers/{staging => net/wireless/silabs}/wfx/main.h (94%) rename drivers/{staging => net/wireless/silabs}/wfx/queue.c (92%) rename drivers/{staging => net/wireless/silabs}/wfx/queue.h (94%) rename drivers/{staging => net/wireless/silabs}/wfx/scan.c (98%) rename drivers/{staging => net/wireless/silabs}/wfx/scan.h (95%) rename drivers/{staging => net/wireless/silabs}/wfx/sta.c (91%) rename drivers/{staging => net/wireless/silabs}/wfx/sta.h (97%) rename drivers/{staging => net/wireless/silabs}/wfx/traces.h (99%) rename drivers/{staging => net/wireless/silabs}/wfx/wfx.h (97%) delete mode 100644 drivers/staging/wfx/TODO