From patchwork Tue May 5 12:37:50 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: 215724 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=-9.7 required=3.0 tests=DKIM_SIGNED,DKIM_VALID, HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH,MAILING_LIST_MULTI, MSGID_FROM_MTA_HEADER, SIGNED_OFF_BY, SPF_HELO_NONE, SPF_PASS, URIBL_BLOCKED, USER_AGENT_GIT autolearn=ham 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 70D5BC47258 for ; Tue, 5 May 2020 12:38:54 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 39B5F20735 for ; Tue, 5 May 2020 12:38:54 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (1024-bit key) header.d=silabs.onmicrosoft.com header.i=@silabs.onmicrosoft.com header.b="I+O6OaWr" Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729145AbgEEMix (ORCPT ); Tue, 5 May 2020 08:38:53 -0400 Received: from mail-eopbgr680041.outbound.protection.outlook.com ([40.107.68.41]:21169 "EHLO NAM04-BN3-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1729115AbgEEMit (ORCPT ); Tue, 5 May 2020 08:38:49 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=etgiWBhro+wph3OPL7GQU72jCaRqNP2xFwF9kYjCsYMozpmqYkK7wIMTu0fJbQZRGhRBgK4D4/xQbQniy5flt7dAZBTUX7IXaXY21xBKuaD1ntcz0fzMtNOJHIJ5NYkl1PmceyO7zUNvW2ibDqKWDbqpZyxe0y2vECpCwQ7XcTXqWzYC52DcyRh9ogWG0+LPrmoe/CkDvHNTDsOh/MOQ269mVDSopKQjlj7RfR5YTZSdCs4EZK7aZhWc0tnTbYkWxpswPA57tdh9TeeC4ur5C32R5xkx9610Vml6wHBapfo3g1C57Zp8tP70xr5ahWuHlm3/bRD0xhrM6qDyGP2j8g== 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=4GBNkwWw5Z5Rrd13zcIw/+v6k11pKV8yRE+roAUh8OA=; b=Ae4BSRe5ef/xTE2PSqmgLbBJMtaoh295GPcNB1LLj7oVYTQ4ygal3m9A2asGdI52sZKC091Q01hK7tvAivIPCCGJAAJGcBmliYri6xd7HR0P4YwIuA3yjIHipV0illGOSWrseoruWeMZf6jqcC+KS2/nQK9NAV4zOwwssBXU9vsgQ3b8AjdGSO0CvLDwfJTEXo5wU60lIo9mniNjrpx4NFst5RI4eTgr2k2e73Lyahfsd2P7cEdnyjc1IuzIodV75chKj6dSZEn0icIfGCskaJUQNi0YrfIP9/e8+h/xAVmI89/k38iE5pXEPrio9UxsnL51jYbb/Are84zgq4QhCw== 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=4GBNkwWw5Z5Rrd13zcIw/+v6k11pKV8yRE+roAUh8OA=; b=I+O6OaWrnkAm/3oqGhja7Y/op97u0V8pECLNeHPi4YudhpmeEXthq9pnnYrrs3jPFHbDzfesRXwDrciU/NmssQMXPnM/SMbtNddKQMsSf+4IGh5TyGTU3r4rfZyQ4pDTXyi2TgyJSKnQPRzG0QXg6tbvaMJSWSCTBvMflKfLfQY= Authentication-Results: driverdev.osuosl.org; dkim=none (message not signed) header.d=none; driverdev.osuosl.org; dmarc=none action=none header.from=silabs.com; Received: from MWHPR11MB1775.namprd11.prod.outlook.com (2603:10b6:300:10e::14) by MWHPR11MB1824.namprd11.prod.outlook.com (2603:10b6:300:110::13) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.2958.19; Tue, 5 May 2020 12:38:29 +0000 Received: from MWHPR11MB1775.namprd11.prod.outlook.com ([fe80::81d5:b62b:3770:ffbe]) by MWHPR11MB1775.namprd11.prod.outlook.com ([fe80::81d5:b62b:3770:ffbe%10]) with mapi id 15.20.2958.030; Tue, 5 May 2020 12:38:29 +0000 From: Jerome Pouiller To: devel@driverdev.osuosl.org, linux-wireless@vger.kernel.org Cc: netdev@vger.kernel.org, linux-kernel@vger.kernel.org, Greg Kroah-Hartman , Kalle Valo , "David S . Miller" , =?utf-8?b?SsOpcsO0bWUgUG91aWxsZXI=?= Subject: [PATCH 08/15] staging: wfx: poll IRQ during init Date: Tue, 5 May 2020 14:37:50 +0200 Message-Id: <20200505123757.39506-9-Jerome.Pouiller@silabs.com> X-Mailer: git-send-email 2.26.1 In-Reply-To: <20200505123757.39506-1-Jerome.Pouiller@silabs.com> References: <20200505123757.39506-1-Jerome.Pouiller@silabs.com> X-ClientProxiedBy: PR3P189CA0022.EURP189.PROD.OUTLOOK.COM (2603:10a6:102:52::27) To MWHPR11MB1775.namprd11.prod.outlook.com (2603:10b6:300:10e::14) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from pc-42.home (2a01:e35:2435:66a0:1265:30ff:fefd:6e7f) by PR3P189CA0022.EURP189.PROD.OUTLOOK.COM (2603:10a6:102:52::27) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.2958.20 via Frontend Transport; Tue, 5 May 2020 12:38:27 +0000 X-Mailer: git-send-email 2.26.1 X-Originating-IP: [2a01:e35:2435:66a0:1265:30ff:fefd:6e7f] X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: a3a155c8-c047-4d54-0166-08d7f0f1365d X-MS-TrafficTypeDiagnostic: MWHPR11MB1824: X-MS-Exchange-Transport-Forked: True X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:7691; X-Forefront-PRVS: 0394259C80 X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: 4iipnSn1CoMXDyCKQvRv1RP3NnjYX/8jJD6uq8Kx/fXW8dMY1YOAo8ZfTgMCz94x0t2W9lC3vrRmQkRLzL5iP5ZeVQCdHpOQVy5An4kItAb31W5I9BWTUKmlYRxK+5ikGjZ7t+dWO7Ft8EV5r54E7ou2TSj+haSbJ7pH6dvQDLsGeh4koDiMSfHNkPLVVI1r2h+L8u423MEZ6GLrRXBWFxUr0w0r8g71SfAbMLCfxvk8TRJQHF+2mMRL2eQwO6N5w3KMp7S0AvBBQa00RQA4nTJmp+gcWA5Vz7gp+fQXzlDc5meoK/xqO0wWBqxEkBJIQSYPRpoL5y4/Mx3VN4athgzaGIsBMTRLruOdhZEvJV+8qFFn8f3NV6/g17lj3ewymMbDMXnY5DiwKaVi4N1m8B+5epvaq9Y1AxWOXmvhPddm/E1QW223UEEBuAEjvF1YnKnp70KEbuWLS4apMllf5MpIExwJio8J6PM5JQsDJi1ULkTWHLOD74G5VdUOpWMjaNngv8kOQirU2/wzeE+4+w== X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:MWHPR11MB1775.namprd11.prod.outlook.com; PTR:; CAT:NONE; SFTY:; SFS:(136003)(396003)(39850400004)(366004)(376002)(346002)(33430700001)(86362001)(6666004)(107886003)(8886007)(1076003)(6512007)(6486002)(66574012)(36756003)(5660300002)(2906002)(66476007)(6506007)(16526019)(186003)(52116002)(66946007)(66556008)(54906003)(2616005)(4326008)(8936002)(8676002)(316002)(33440700001)(478600001); DIR:OUT; SFP:1101; X-MS-Exchange-AntiSpam-MessageData: N2vCM2cnG5r18aMZEGxDh8x8bYwJFa7H2qmzjtqOz1AZCbTna9CG49kU/TMphkF98gQ8Fh9+ufSZpi7dQWtKWkOG1RIU7r87I+xKHLHGhHEKOxw3NIYN55DCsgDzmK7MK7Aqc+xjfKwis5vy1EL/onZImKSx9gDHHFLpqgqllLBfX1UwyazithzPza8jKUKR660C3h9dcFfU/bKRT6Y101O+c4qfHe/URbsT1ecvix4MizSmDxKRQPFzomjeSpRS01sGvu+6JVpLVwCYZbKvVZfy3qLuQCETvFUp5N+4Ln+Z4TIO0DgEZYnv9N4DKIBVClW7ceeleIpOWmY/3wuFSkmZFga4UUM9/GXnyYBgPgEdtmK5wYhbT3KmQsJcSG3/r5/PyangNCRt2J2bU5mdtTlhi8XtY347kOIAH2n/YY/QnB/V9h+rNQqAByrmiMtt5AztQLNdj8gMnIZ/uIgbDHoyG9Mi6xETj8urlM69bZeKd6ZdEfYxK4I0VM135K7qcYWqfKART8HSyoirxTfdRyydu2oEIqz2GYBG+1jRucLPvssKBF3w3Eo3y9u+wM4JZRTR3TxcksZu8MAZnLPmiT1ZZFt25u/clYIKmtBkl470YtLyP3UX3sYEl8GQ585HXo5LdNZG+Ymtz9Quah1T1vRGlYEVhl5GyTlMKCBE2q8Pwjgc0GqByzQtYSwL1LjvA+VjulLMIioiD2FLpMQjesReO4jwxdt46W4PkJ5X295gbG4T30K48MoxnMBZaJ6RhLlDyMXpWEH08Oeoglq/6xkG/yCyh2XT1zWzAPsL3TZQw2MRdzeGKPOH0NKDrfFumfZakf/ArR7EmuiRyGZtj+N7CjBE2gZtcs1Zn6wSyys= X-OriginatorOrg: silabs.com X-MS-Exchange-CrossTenant-Network-Message-Id: a3a155c8-c047-4d54-0166-08d7f0f1365d X-MS-Exchange-CrossTenant-OriginalArrivalTime: 05 May 2020 12:38:29.0512 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 54dbd822-5231-4b20-944d-6f4abcd541fb X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: eK8Bbfcd8Po+Aq1vEKEJPeVYrVtvnuA1ga3yx5rr+VtnAf/9Xg75tZpEWgIXuj8Bx9M2/Z9VlwKK/+3fHm4MAw== X-MS-Exchange-Transport-CrossTenantHeadersStamped: MWHPR11MB1824 Sender: linux-wireless-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org From: Jérôme Pouiller When the chip starts in SDIO mode, the external IRQ (aka Out-Of-Band IRQ) cannot be used before to configure it. Therefore, the first exchanges with the chip have to be done without the OOB IRQ. This patch allow to poll the data until the OOB IRQ is correctly setup. In order to keep the code simpler, this patch also poll data even if OOB IRQ is not used. Signed-off-by: Jérôme Pouiller --- drivers/staging/wfx/bh.c | 1 + drivers/staging/wfx/bus.h | 2 ++ drivers/staging/wfx/bus_sdio.c | 17 +++++++---------- drivers/staging/wfx/bus_spi.c | 16 +++++++++++++--- drivers/staging/wfx/hif_tx.c | 3 +++ drivers/staging/wfx/main.c | 28 ++++++++++++++++++++-------- drivers/staging/wfx/wfx.h | 1 + 7 files changed, 47 insertions(+), 21 deletions(-) diff --git a/drivers/staging/wfx/bh.c b/drivers/staging/wfx/bh.c index d3e7eed89c38..2572fbcf1a33 100644 --- a/drivers/staging/wfx/bh.c +++ b/drivers/staging/wfx/bh.c @@ -320,6 +320,7 @@ void wfx_bh_poll_irq(struct wfx_dev *wdev) ktime_t now, start; u32 reg; + WARN(!wdev->poll_irq, "unexpected IRQ polling can mask IRQ"); start = ktime_get(); for (;;) { control_reg_read(wdev, ®); diff --git a/drivers/staging/wfx/bus.h b/drivers/staging/wfx/bus.h index 62d6ecabe4cb..0370b6c59863 100644 --- a/drivers/staging/wfx/bus.h +++ b/drivers/staging/wfx/bus.h @@ -25,6 +25,8 @@ struct hwbus_ops { void *dst, size_t count); int (*copy_to_io)(void *bus_priv, unsigned int addr, const void *src, size_t count); + int (*irq_subscribe)(void *bus_priv); + int (*irq_unsubscribe)(void *bus_priv); void (*lock)(void *bus_priv); void (*unlock)(void *bus_priv); size_t (*align_size)(void *bus_priv, size_t size); diff --git a/drivers/staging/wfx/bus_sdio.c b/drivers/staging/wfx/bus_sdio.c index 2f782120e438..6afde2349289 100644 --- a/drivers/staging/wfx/bus_sdio.c +++ b/drivers/staging/wfx/bus_sdio.c @@ -106,8 +106,9 @@ static irqreturn_t wfx_sdio_irq_handler_ext(int irq, void *priv) return IRQ_HANDLED; } -static int wfx_sdio_irq_subscribe(struct wfx_sdio_priv *bus) +static int wfx_sdio_irq_subscribe(void *priv) { + struct wfx_sdio_priv *bus = priv; u32 flags; int ret; u8 cccr; @@ -134,8 +135,9 @@ static int wfx_sdio_irq_subscribe(struct wfx_sdio_priv *bus) "wfx", bus); } -static int wfx_sdio_irq_unsubscribe(struct wfx_sdio_priv *bus) +static int wfx_sdio_irq_unsubscribe(void *priv) { + struct wfx_sdio_priv *bus = priv; int ret; if (bus->of_irq) @@ -156,6 +158,8 @@ static size_t wfx_sdio_align_size(void *priv, size_t size) static const struct hwbus_ops wfx_sdio_hwbus_ops = { .copy_from_io = wfx_sdio_copy_from_io, .copy_to_io = wfx_sdio_copy_to_io, + .irq_subscribe = wfx_sdio_irq_subscribe, + .irq_unsubscribe = wfx_sdio_irq_unsubscribe, .lock = wfx_sdio_lock, .unlock = wfx_sdio_unlock, .align_size = wfx_sdio_align_size, @@ -212,18 +216,12 @@ static int wfx_sdio_probe(struct sdio_func *func, goto err1; } - ret = wfx_sdio_irq_subscribe(bus); - if (ret) - goto err1; - ret = wfx_probe(bus->core); if (ret) - goto err2; + goto err1; return 0; -err2: - wfx_sdio_irq_unsubscribe(bus); err1: sdio_claim_host(func); sdio_disable_func(func); @@ -237,7 +235,6 @@ static void wfx_sdio_remove(struct sdio_func *func) struct wfx_sdio_priv *bus = sdio_get_drvdata(func); wfx_release(bus->core); - wfx_sdio_irq_unsubscribe(bus); sdio_claim_host(func); sdio_disable_func(func); sdio_release_host(func); diff --git a/drivers/staging/wfx/bus_spi.c b/drivers/staging/wfx/bus_spi.c index 00613d046c3f..e8da61fb096b 100644 --- a/drivers/staging/wfx/bus_spi.c +++ b/drivers/staging/wfx/bus_spi.c @@ -12,6 +12,7 @@ #include #include #include +#include #include #include "bus.h" @@ -143,8 +144,9 @@ static irqreturn_t wfx_spi_irq_handler(int irq, void *priv) return IRQ_HANDLED; } -static int wfx_spi_irq_subscribe(struct wfx_spi_priv *bus) +static int wfx_spi_irq_subscribe(void *priv) { + struct wfx_spi_priv *bus = priv; u32 flags; flags = irq_get_trigger_type(bus->func->irq); @@ -156,6 +158,14 @@ static int wfx_spi_irq_subscribe(struct wfx_spi_priv *bus) "wfx", bus); } +static int wfx_spi_irq_unsubscribe(void *priv) +{ + struct wfx_spi_priv *bus = priv; + + devm_free_irq(&bus->func->dev, bus->func->irq, bus); + return 0; +} + static size_t wfx_spi_align_size(void *priv, size_t size) { // Most of SPI controllers avoid DMA if buffer size is not 32bit aligned @@ -165,6 +175,8 @@ static size_t wfx_spi_align_size(void *priv, size_t size) static const struct hwbus_ops wfx_spi_hwbus_ops = { .copy_from_io = wfx_spi_copy_from_io, .copy_to_io = wfx_spi_copy_to_io, + .irq_subscribe = wfx_spi_irq_subscribe, + .irq_unsubscribe = wfx_spi_irq_unsubscribe, .lock = wfx_spi_lock, .unlock = wfx_spi_unlock, .align_size = wfx_spi_align_size, @@ -216,8 +228,6 @@ static int wfx_spi_probe(struct spi_device *func) if (!bus->core) return -EIO; - wfx_spi_irq_subscribe(bus); - return wfx_probe(bus->core); } diff --git a/drivers/staging/wfx/hif_tx.c b/drivers/staging/wfx/hif_tx.c index e8f3c5f9ce7b..511ef874a6d9 100644 --- a/drivers/staging/wfx/hif_tx.c +++ b/drivers/staging/wfx/hif_tx.c @@ -82,6 +82,9 @@ int wfx_cmd_send(struct wfx_dev *wdev, struct hif_msg *request, void *reply, if (async) return 0; + if (wdev->poll_irq) + wfx_bh_poll_irq(wdev); + ret = wait_for_completion_timeout(&wdev->hif_cmd.done, 1 * HZ); if (!ret) { dev_err(wdev->dev, "chip is abnormally long to answer\n"); diff --git a/drivers/staging/wfx/main.c b/drivers/staging/wfx/main.c index 5d0754b55429..623a9fc31153 100644 --- a/drivers/staging/wfx/main.c +++ b/drivers/staging/wfx/main.c @@ -363,22 +363,24 @@ int wfx_probe(struct wfx_dev *wdev) // prevent bh() to touch it. gpio_saved = wdev->pdata.gpio_wakeup; wdev->pdata.gpio_wakeup = NULL; + wdev->poll_irq = true; wfx_bh_register(wdev); err = wfx_init_device(wdev); if (err) - goto err1; + goto err0; + wfx_bh_poll_irq(wdev); err = wait_for_completion_timeout(&wdev->firmware_ready, 1 * HZ); if (err <= 0) { if (err == 0) { - dev_err(wdev->dev, "timeout while waiting for startup indication. IRQ configuration error?\n"); + dev_err(wdev->dev, "timeout while waiting for startup indication\n"); err = -ETIMEDOUT; } else if (err == -ERESTARTSYS) { dev_info(wdev->dev, "probe interrupted by user\n"); } - goto err1; + goto err0; } // FIXME: fill wiphy::hw_version @@ -400,14 +402,14 @@ int wfx_probe(struct wfx_dev *wdev) "unsupported firmware API version (expect 1 while firmware returns %d)\n", wdev->hw_caps.api_version_major); err = -ENOTSUPP; - goto err1; + goto err0; } err = wfx_sl_init(wdev); if (err && wdev->hw_caps.capabilities.link_mode == SEC_LINK_ENFORCED) { dev_err(wdev->dev, "chip require secure_link, but can't negociate it\n"); - goto err1; + goto err0; } if (wdev->hw_caps.regul_sel_mode_info.region_sel_mode) { @@ -420,7 +422,16 @@ int wfx_probe(struct wfx_dev *wdev) wdev->pdata.file_pds); err = wfx_send_pdata_pds(wdev); if (err < 0) - goto err1; + goto err0; + + wdev->poll_irq = false; + err = wdev->hwbus_ops->irq_subscribe(wdev->hwbus_priv); + if (err) + goto err0; + + err = hif_use_multi_tx_conf(wdev, true); + if (err) + dev_err(wdev->dev, "misconfigured IRQ?\n"); wdev->pdata.gpio_wakeup = gpio_saved; if (wdev->pdata.gpio_wakeup) { @@ -435,8 +446,6 @@ int wfx_probe(struct wfx_dev *wdev) hif_set_operational_mode(wdev, HIF_OP_POWER_MODE_DOZE); } - hif_use_multi_tx_conf(wdev, true); - for (i = 0; i < ARRAY_SIZE(wdev->addresses); i++) { eth_zero_addr(wdev->addresses[i].addr); macaddr = of_get_mac_address(wdev->dev->of_node); @@ -470,6 +479,8 @@ int wfx_probe(struct wfx_dev *wdev) err2: ieee80211_unregister_hw(wdev->hw); err1: + wdev->hwbus_ops->irq_unsubscribe(wdev->hwbus_priv); +err0: wfx_bh_unregister(wdev); return err; } @@ -478,6 +489,7 @@ void wfx_release(struct wfx_dev *wdev) { ieee80211_unregister_hw(wdev->hw); hif_shutdown(wdev); + wdev->hwbus_ops->irq_unsubscribe(wdev->hwbus_priv); wfx_bh_unregister(wdev); wfx_sl_deinit(wdev); } diff --git a/drivers/staging/wfx/wfx.h b/drivers/staging/wfx/wfx.h index 09bbb5da4f06..4eb7762142fc 100644 --- a/drivers/staging/wfx/wfx.h +++ b/drivers/staging/wfx/wfx.h @@ -46,6 +46,7 @@ struct wfx_dev { struct wfx_hif hif; struct sl_context sl; struct delayed_work cooling_timeout_work; + bool poll_irq; bool chip_frozen; struct mutex conf_mutex;