Received: by 2002:ab2:3141:0:b0:1ed:23cc:44d1 with SMTP id i1csp1586253lqg; Sun, 3 Mar 2024 18:16:27 -0800 (PST) X-Forwarded-Encrypted: i=3; AJvYcCUTsFOCHnicP3t7J6zSSwxc47TYFGoCA2d46lqCnyBR2qUKsAgvliaeElzGS4WWSrwmWOokvun0LGAf4kAI95FXPRl5vAFuC4cKRODSAA== X-Google-Smtp-Source: AGHT+IHW8BqrNuFVxBjefWD3gzwn7bmA069b7G7Ih+YF/glAtA1Af/knCzg7BAAhDquJd0IctmI5 X-Received: by 2002:a05:622a:1714:b0:42e:e19a:b916 with SMTP id h20-20020a05622a171400b0042ee19ab916mr6351927qtk.48.1709518587182; Sun, 03 Mar 2024 18:16:27 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1709518587; cv=pass; d=google.com; s=arc-20160816; b=P9dqvlCplM8SgGMYiyxs4+WD5QlwXYTQwxFAGvSfLTc+Ocaq51Gd65mx48pBYlmQOY syPtY3bfC/pBOMf2/TBlYHxskYFaNDUg0/pRpoGz1oQpZtBBKuHYJpGTTzsmd0A1TkQW JQk50IBm+m1wugL6vmmOLJ9EvurbtbeC9BN+k3K7mDtSQ3rwJ4c9SSmxK+7m6qCeJJ5z 9XADgZxVc+dqMxSb7M1c/7BsubdwqSd+h2bD1CHyidpXtvDTRgTtwowTC4YFFJmyy6Dx rur1KfLKzY01NmA7sTo6/Q/0YFMOg7G7QwUxnq2HghR7+hegGNIVj7PktaClY81u81Jj BtEw== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:message-id:date:subject:cc:to :from:dkim-signature; bh=IEkjLHcIDAEYrIcns+rLM6UYkx48F5Vc4irWsWUqbxg=; fh=HUZY1mAwsL2RV4ebiSFRpiMBK5XT8gtCNRH/y4zO0W8=; b=ApGCjB4doDumxZBIBkBCu1IxpKxqXFjP5BJpVD+pv1GqPU9LgXEvOsBqfXqdDMRJnh 0x+DebJPUz0ytDf6aQOVcHbgoSlwzn817WpSn2gRIhxjJkBnog/XRKrk5CMTRmest1F4 oV3BFiuZdH1SQURCpivA02l7bQ15IwBB6j44gXoHy23Js4zCwn2NCownwDRuBTLpIPu1 OTiO/ysBlVyOd6c08/W1sQS4p0PPi8KhbZgxu+KwLvde+peo01VUcGWlTIDF8LoGvIWM vcMlbTRXHEugzN9RE+savwhrkFf3BsUwkeKy/lfVMlty/Ka6vwIICY1UXvN5lOmp2GXw mkVQ==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b=Z8s+4ou2; arc=pass (i=1 spf=pass spfdomain=quicinc.com dkim=pass dkdomain=quicinc.com dmarc=pass fromdomain=quicinc.com); spf=pass (google.com: domain of linux-wireless+bounces-4324-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-wireless+bounces-4324-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [147.75.199.223]) by mx.google.com with ESMTPS id t6-20020a05622a148600b0042ef1c1b11csi1329799qtx.725.2024.03.03.18.16.27 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 03 Mar 2024 18:16:27 -0800 (PST) Received-SPF: pass (google.com: domain of linux-wireless+bounces-4324-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) client-ip=147.75.199.223; Authentication-Results: mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b=Z8s+4ou2; arc=pass (i=1 spf=pass spfdomain=quicinc.com dkim=pass dkdomain=quicinc.com dmarc=pass fromdomain=quicinc.com); spf=pass (google.com: domain of linux-wireless+bounces-4324-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-wireless+bounces-4324-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ny.mirrors.kernel.org (Postfix) with ESMTPS id 8E56D1C20967 for ; Mon, 4 Mar 2024 02:16:26 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 623641378; Mon, 4 Mar 2024 02:16:24 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=quicinc.com header.i=@quicinc.com header.b="Z8s+4ou2" X-Original-To: linux-wireless@vger.kernel.org Received: from mx0a-0031df01.pphosted.com (mx0a-0031df01.pphosted.com [205.220.168.131]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id B4FB3138A; Mon, 4 Mar 2024 02:16:22 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=205.220.168.131 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709518584; cv=none; b=kMsYmCwyN9DWAn8R7FnKB8aCcTF/lqTgj+C7k/2lMy5YHEoX7LVhnTFF8bqyMnBuZ+Ou8CGuD3EMZI/PLbaSa2GlcRwIyYOBFDsJV6u+v1WmmskmvK0Ej7C8821cgKmvxIe32VzinQrfbvVR2uD5KvE50PyL8dr9F0CfEigOuho= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709518584; c=relaxed/simple; bh=dVHOJ1NZ1o4CP7M5Dp7giS+tCwG4U0htdrsKA/1j3fg=; h=From:To:CC:Subject:Date:Message-ID:MIME-Version:Content-Type; b=Jc8OiH+XjLnc4y/fj5UzGNkyqB8M6W2QEeUZY5z9DuvlJ7m9dPSDU5RMPSh7suYdY/yuw131AFTNtphqDUPXaJI+JTBzIM1WjYjSDyajdKGBNzoEjpj8/YhbmTyANE+R8rJWAZWIka9Jj1zEUN6TJPLd+Q70hL0fnOPuyy4I1O8= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=quicinc.com; spf=pass smtp.mailfrom=quicinc.com; dkim=pass (2048-bit key) header.d=quicinc.com header.i=@quicinc.com header.b=Z8s+4ou2; arc=none smtp.client-ip=205.220.168.131 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=quicinc.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=quicinc.com Received: from pps.filterd (m0279865.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.17.1.24/8.17.1.24) with ESMTP id 4242FcI3013875; Mon, 4 Mar 2024 02:16:12 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=quicinc.com; h= from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding:content-type; s=qcppdkim1; bh=IEkjLHc IDAEYrIcns+rLM6UYkx48F5Vc4irWsWUqbxg=; b=Z8s+4ou2kUOaei1mvQSJSeX dwd/1ik+fy7C42Fj/wN5hwgeukM90i6x9/tlQ0F7Qy+LWhxR8uWi+VoTRyOSL3Pd lgtWoFjWet72nUCI9KKhFDF1pCEc4qqApsOaVHbIsK/hhGo1KOJHiOb2lOg93CEE txtELYiLpAP5sSkfuG7rJJkG4Uk/UrE/ZGkH8vM1E5MCqahAhsU32osx5Hitjvp4 1obwWrTWydEex+cffFGnRuKhnQ0fDfuyu4ysmEr3zQ0kGLs/P4PGeOGi38HYRLBu TRW/xjWQcyTZ+MO+k/Zq2ZiZtso6jXdBip+3kA2fqxFzTKddX7DyDKW3mAJnt/g= = Received: from nalasppmta02.qualcomm.com (Global_NAT1.qualcomm.com [129.46.96.20]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 3wku2wtfq1-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 04 Mar 2024 02:16:11 +0000 (GMT) Received: from nalasex01a.na.qualcomm.com (nalasex01a.na.qualcomm.com [10.47.209.196]) by NALASPPMTA02.qualcomm.com (8.17.1.5/8.17.1.5) with ESMTPS id 4242GBRF027040 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 4 Mar 2024 02:16:11 GMT Received: from bqiang-SFF.qca.qualcomm.com (10.80.80.8) by nalasex01a.na.qualcomm.com (10.47.209.196) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.1118.40; Sun, 3 Mar 2024 18:16:08 -0800 From: Baochen Qiang To: , CC: , , , , , , , , Subject: [PATCH v5 0/3] wifi: ath11k: hibernation support Date: Mon, 4 Mar 2024 10:15:51 +0800 Message-ID: <20240304021554.77782-1-quic_bqiang@quicinc.com> X-Mailer: git-send-email 2.25.1 Precedence: bulk X-Mailing-List: linux-wireless@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain X-ClientProxiedBy: nasanex01a.na.qualcomm.com (10.52.223.231) To nalasex01a.na.qualcomm.com (10.47.209.196) X-QCInternal: smtphost X-Proofpoint-Virus-Version: vendor=nai engine=6200 definitions=5800 signatures=585085 X-Proofpoint-ORIG-GUID: 4SaTY10VuWFyojET9qOLh8wx2wd5OXb6 X-Proofpoint-GUID: 4SaTY10VuWFyojET9qOLh8wx2wd5OXb6 X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.272,Aquarius:18.0.1011,Hydra:6.0.619,FMLib:17.11.176.26 definitions=2024-03-04_01,2024-03-01_03,2023-05-22_02 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 priorityscore=1501 impostorscore=0 mlxscore=0 spamscore=0 mlxlogscore=999 clxscore=1015 phishscore=0 suspectscore=0 adultscore=0 malwarescore=0 lowpriorityscore=0 bulkscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.19.0-2402120000 definitions=main-2403040015 Currently in ath11k we keep the firmware running on the WLAN device when the network interface (wlan0) is down. The problem is that this will break hibernation, obviously the firmware can't be running after the whole system is powered off. To power down the ath11k firmware for suspend/hibernation some changes both in MHI subsystem and ath11k are needed. This patchset fixes a longstanding bug report about broken hibernation support: https://bugzilla.kernel.org/show_bug.cgi?id=214649 There already is an RFC version which has been tested by multiple users with positive results: https://patchwork.kernel.org/project/linux-wireless/cover/20231127162022.518834-1-kvalo@kernel.org/ Basically the RFC version adds two APIs to MHI stack: with the first one ath11k is able to keep MHI devices when going to suspend/hibernation, getting us rid of the probe deferral issue when resume back. while with the second one ath11k could manually prepare/unprepare MHI channels by itself, which is needed because QRTR doesn't probe those channels automatically in this case. Mani, the MHI maintainer, firstly doesn't like that version and insists that an MHI device should be destroyed when suspend/hibernation, according to his understanding on device driver model. See https://lore.kernel.org/mhi/20231127162022.518834-1-kvalo@kernel.org/ After a long discussion Mani thought we might need a new PM callback with which ath11k is able to wait until kernel unblocks device probe and thus MHI channels get probed. So we came to the kernel PM list and there Mani realized that his understanding is not correct so he finally agrees to keep MHI device during suspend/hibernation. See https://lore.kernel.org/all/21cd2098-97e1-4947-a5bb-a97582902ead@quicinc.com/ Mani also pointed out that an MHI controller driver (ath11k here) should not touch MHI channels directly because those channels are managed by the corresponding MHI client driver (QRTR here). To address this, we come up with this version. Compared with that RFC version, this version adds PM callbacks in QRTR module: suspend callback unprepares MHI channels during suspend and resume callback prepares those channels during resume. In this way ath11k doesn't need to do unprepare/prepare work by itself so those two APIs added in RFC version are removed now. The power down/up procedure requires a specific sequence in which PM callbacks of wiphy, ath11k and QRTR are called, this is achieved by exploiting the child-father relationship between their device struct, and also the PM framework which separates whole suspend/resume process into several stages. Details in patch [3/3]. v5: - remove Kalle's s-o-b tag in patch 1/3 per Mani. v4: - resend v3 as v4 to CC netdev folks. No changes in patches themselves. v3: - skip QRTR suspend/resume if MHI device is found to be in suspend state. v2: - add comment on why destroying the device is optional in mhi_pm_disable_transition(). - rename mhi_power_down_no_destroy() as mhi_power_down_keep_dev(). - refine API description of mhi_power_down() and mhi_power_down_keep_dev(). - add/remove __maybe_unused to QRTR PM callbacks. - remove '#ifdef CONFIG_PM'. - refine commit log of patch 1/3 and 2/3. Baochen Qiang (3): bus: mhi: host: add mhi_power_down_keep_dev() net: qrtr: support suspend/hibernation wifi: ath11k: support hibernation drivers/bus/mhi/host/internal.h | 4 +- drivers/bus/mhi/host/pm.c | 42 ++++++++-- drivers/net/wireless/ath/ath11k/ahb.c | 6 +- drivers/net/wireless/ath/ath11k/core.c | 105 +++++++++++++++++-------- drivers/net/wireless/ath/ath11k/core.h | 6 +- drivers/net/wireless/ath/ath11k/hif.h | 14 +++- drivers/net/wireless/ath/ath11k/mhi.c | 12 ++- drivers/net/wireless/ath/ath11k/mhi.h | 5 +- drivers/net/wireless/ath/ath11k/pci.c | 44 +++++++++-- drivers/net/wireless/ath/ath11k/qmi.c | 2 +- include/linux/mhi.h | 18 ++++- net/qrtr/mhi.c | 46 +++++++++++ 12 files changed, 244 insertions(+), 60 deletions(-) base-commit: 48294c8a226d82c687b52b2eb90a075bbfbcb884 -- 2.25.1