Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp2978089pxj; Mon, 10 May 2021 15:30:41 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwc4QqHSUFPq8ET2TSTkJUB8jctFLrElV5NsOrt+jG1zOEuQ7x+GeEtQHLUHFxxKYuupHQ+ X-Received: by 2002:a17:906:b6c5:: with SMTP id ec5mr28306314ejb.290.1620685840836; Mon, 10 May 2021 15:30:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620685840; cv=none; d=google.com; s=arc-20160816; b=P3VUvwFtDvmJ1GCaecK45UcSuYDkmXe9fjmGA5/Wct3cyEFJsYDK1A5oa41M73QOMH MY8RxlqevKI+OZmQRHqKyEHUt5ciGH03JRNv20KO/Atm2imAwiZvJpW8eveQyM6ZXjcK X7hGd1InxAeM2NsHukqiIgVnCmkw+HXHMJTr/Nq5eneDCGWwfuEO+fyZenSY+S9WP7Nm 7njShdq9+P7gFqzcVZNfxpwg0liTVHmP7rdzO4amGtF3MjiLya74p0oIgbnTOE7RTdD8 WZPJ6nwBzd4gyFWKnOvNhFIux6LoX8qLS90AgDUEeNm5oOO92cnt4wIPajP3ffWVeNeA 8aGA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=DbJhI0dDox8bqqcTIAbYbGxUF4U0IO2sHzQlFyqoZZI=; b=ZrGwMIieSSBlutf66fEM2sE9UxuB/jrGQfH/fYIlsFyFxYleldhFp0FhpsPr4J19WZ Qe11C6mO7buDDkfqboN27ynuaa61H+qIct7MjUKo7I9QfJRIwoJLUJ5sUW0ztuuTZeqr kcKSJJORLRWTaYgpEaE51SuPiLRiRuHGoX7Ed/nEeXa2yNcjKxfxAtnlkKSdZqUTozZ/ MCVzuS1lROa2yqVkcxW1tSUHtpZhHzKfuhxTX0hEnyUhQMw0lhUHvBydQD2BWDzU1tUv whnyigCtAbUDPkl1LQv5AchPk8oKQdd3bMxxLh2SY+igB4dB3eNX6/EUFnpxX27y7zKx t+qA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=QxKZsppJ; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id b1si16523159ejb.714.2021.05.10.15.30.17; Mon, 10 May 2021 15:30:40 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=QxKZsppJ; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231213AbhEJWat (ORCPT + 99 others); Mon, 10 May 2021 18:30:49 -0400 Received: from mail.kernel.org ([198.145.29.99]:42972 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231193AbhEJWar (ORCPT ); Mon, 10 May 2021 18:30:47 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 1AE3461581; Mon, 10 May 2021 22:29:40 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1620685782; bh=DgBcdPbRRR8zN5iiw5yCAfQFzH88KzMTBDKTGSx4Dq8=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=QxKZsppJJOE/0z6uU3kTnKCydKPmkaQS3NtMgqEJgZT4ZOisp2i3y1c3uSsCpnh4j 0kr8cfZt7lQBpU8ulBUWYRwI+6dJZf6llUvI/XpqjGHjM56UN0sKiDsdtnwZikO2h2 0bywJjvkxze460NyVBSY4GE88fDh/wt2DgzM9TP0CEUUOtL6yqQTdKozZN/gQMAq5u mI+s+L4VSIMXQPZn+4dddHKAbD7u3SoqJwaSbKi9ewZeqCnH86XlXuOWmrmD9wXKLC BRXz/npBZHX7boATHJ6AN1K3ppzCoHYpdF03xgCz3X1iF70s1fcqLLAhvp+gMy7jGv 88S8kJhqXt87g== From: Lorenzo Bianconi To: nbd@nbd.name Cc: linux-wireless@vger.kernel.org, lorenzo.bianconi@redhat.com, sean.wang@mediatek.com Subject: [PATCH 2/5] mt76: mt7663s: rely on pm reference counting Date: Tue, 11 May 2021 00:29:21 +0200 Message-Id: <92d33014a577389dfceb54f09af0e548085f2c07.1620685619.git.lorenzo@kernel.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: References: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org As already done for mt7921 and mt7663e, rely on pm reference counting in drv/fw_own Signed-off-by: Lorenzo Bianconi --- .../wireless/mediatek/mt76/mt7615/sdio_mcu.c | 36 +++++++++++-------- 1 file changed, 22 insertions(+), 14 deletions(-) diff --git a/drivers/net/wireless/mediatek/mt76/mt7615/sdio_mcu.c b/drivers/net/wireless/mediatek/mt76/mt7615/sdio_mcu.c index d1be78b0711c..6c23c6dbf1c6 100644 --- a/drivers/net/wireless/mediatek/mt76/mt7615/sdio_mcu.c +++ b/drivers/net/wireless/mediatek/mt76/mt7615/sdio_mcu.c @@ -55,6 +55,7 @@ static int __mt7663s_mcu_drv_pmctrl(struct mt7615_dev *dev) { struct sdio_func *func = dev->mt76.sdio.func; struct mt76_phy *mphy = &dev->mt76.phy; + struct mt76_connac_pm *pm = &dev->pm; u32 status; int ret; @@ -64,39 +65,44 @@ static int __mt7663s_mcu_drv_pmctrl(struct mt7615_dev *dev) ret = readx_poll_timeout(mt7663s_read_pcr, dev, status, status & WHLPCR_IS_DRIVER_OWN, 2000, 1000000); - if (ret < 0) { + if (ret < 0) dev_err(dev->mt76.dev, "Cannot get ownership from device"); - set_bit(MT76_STATE_PM, &mphy->state); - sdio_release_host(func); - - return ret; - } + else + clear_bit(MT76_STATE_PM, &mphy->state); sdio_release_host(func); - dev->pm.last_activity = jiffies; + pm->last_activity = jiffies; - return 0; + return ret; } static int mt7663s_mcu_drv_pmctrl(struct mt7615_dev *dev) { struct mt76_phy *mphy = &dev->mt76.phy; + int ret = 0; - if (test_and_clear_bit(MT76_STATE_PM, &mphy->state)) - return __mt7663s_mcu_drv_pmctrl(dev); + mutex_lock(&dev->pm.mutex); - return 0; + if (test_bit(MT76_STATE_PM, &mphy->state)) + ret = __mt7663s_mcu_drv_pmctrl(dev); + + mutex_unlock(&dev->pm.mutex); + + return ret; } static int mt7663s_mcu_fw_pmctrl(struct mt7615_dev *dev) { struct sdio_func *func = dev->mt76.sdio.func; struct mt76_phy *mphy = &dev->mt76.phy; + struct mt76_connac_pm *pm = &dev->pm; + int ret = 0; u32 status; - int ret; - if (test_and_set_bit(MT76_STATE_PM, &mphy->state)) - return 0; + mutex_lock(&pm->mutex); + + if (mt76_connac_skip_fw_pmctrl(mphy, pm)) + goto out; sdio_claim_host(func); @@ -110,6 +116,8 @@ static int mt7663s_mcu_fw_pmctrl(struct mt7615_dev *dev) } sdio_release_host(func); +out: + mutex_unlock(&pm->mutex); return ret; } -- 2.31.1