Received: by 2002:a05:7208:9594:b0:7e:5202:c8b4 with SMTP id gs20csp92780rbb; Fri, 23 Feb 2024 12:59:04 -0800 (PST) X-Forwarded-Encrypted: i=3; AJvYcCW6FIgBiYZu9jo64YVj9VNgqIqQlIWBDOpRbfM5gDRwlrdq5qJJCFgjnj21ypNozZR1rCcWeV/MjaHFCHeK4jhf6pN6UKp+/9MtEdJpgA== X-Google-Smtp-Source: AGHT+IEmajCpQNjecu2bj+EPb9Tnkp0lRZuMugrpWJRxbKklt8fBoskV39REwF10M+ghXwYwv805 X-Received: by 2002:aa7:c657:0:b0:565:9b18:8af5 with SMTP id z23-20020aa7c657000000b005659b188af5mr148733edr.39.1708721944500; Fri, 23 Feb 2024 12:59:04 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1708721944; cv=pass; d=google.com; s=arc-20160816; b=ytO1XPmxsyqYkh5fF7s0v1Q5o2l9ynjMOtXPZ6sk8pi6vRKXKbtI/eFkAaH6ZgFXmd IT/SxKOLMav4hYnjEUbUqPu5vL/bz0HfatIXV4ZGFUKyTY8u8bH79lbvVETCqaLdnBuG 5VtAq2ciCnCCaLANLFYHioqwLnNbZWh4Pdps8CVhzpZ7qzP7zS4Pyc8ljLbmMr1VPpq6 s+JP/qf6EEM4NQKRkEM8x7bsB0AEsu9DNDoHVLigm8Ctr3c6LaSAbdgae97+MUrEuuTb 0aQ6h425Q9uMOsybuJIeKFUXdkECJwTW0cFWQ89TXXjDieWP31aIgWZfMp2sPzSxkhyL zeHg== 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=mEfA30g+miqBBDyaTNTpyrnINadjyhMNPThrvCJiaOA=; fh=UOtCQvdtLRjYu4lpt5Tw8oOZkSAAXsqpAt775wBcPRQ=; b=pSbkj9L1Wv3iCf5Bs62rKoX4G2sL6VyRnMFxIloghh6Qdh5Yc28TKlZGKtLU/cthgv xOPge0riUp2KvlAXnCGIyDS3DWs0+PHq52QAA1hH4xRY6Tqz1M1XFwQyIfyWvQYMXHrq t8sm7+wcburuXROUG3aND7g2QuQov+xh7NRCEGd/3gop3Uraax5hyJ55xv3l4scyw4OE oFD/COSu5HsAVaw1XG3JV8GUdIPJQWtzZL4hmpe9+IX9eHO0Bxw6JaDiad9RQ0MIRhKF vFvZN3JKvATkQ3gCB6P+15VAoV3KzgEuUESbFCNkIElwXmwi04b7Sp6hFYpUBN5JKaMP zEcw==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=SKJO1XJA; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-79152-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:4601:e00::3 as permitted sender) smtp.mailfrom="linux-kernel+bounces-79152-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from am.mirrors.kernel.org (am.mirrors.kernel.org. [2604:1380:4601:e00::3]) by mx.google.com with ESMTPS id f14-20020a0564021e8e00b00564aa52677dsi4172138edf.342.2024.02.23.12.59.04 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 23 Feb 2024 12:59:04 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-79152-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:4601:e00::3 as permitted sender) client-ip=2604:1380:4601:e00::3; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=SKJO1XJA; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-79152-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:4601:e00::3 as permitted sender) smtp.mailfrom="linux-kernel+bounces-79152-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org 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 am.mirrors.kernel.org (Postfix) with ESMTPS id 1A8EE1F23E29 for ; Fri, 23 Feb 2024 20:59:04 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 434B8146E96; Fri, 23 Feb 2024 20:58:56 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="SKJO1XJA" Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (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 6A5EE12A16D; Fri, 23 Feb 2024 20:58:54 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1708721935; cv=none; b=qJI0VPNHy2CvIsu6fKiQwt9yW13t6uvvGJWLsPbAUcR2QsH8E6c1v3nTnE/1n3cHGxhkQ0ZirmYrBPLtpL0tRe2Aguu16vy6uCvgaG5D5Z+kjBZPYWQJSWK0WwPUfOXyma+hN4Cmn5FW/k2tDicaE5Dnj/u+s1inanuH49ARX6g= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1708721935; c=relaxed/simple; bh=ZnhJxh0/iM55/Ih9OWsBqkos+7Gz6O4NkpMi/NZLabM=; h=From:To:Cc:Subject:Date:Message-Id:MIME-Version; b=LP2ZaF0YlpIwkFr++ni/9sSjqG5AOlJmwfQaIXBpCOlrKEfdTo2GyBKY2dEHL/haHJ5PLaqs3ADerMbQbQrMvY5Zigf+d7axPDuDsv4zDEhlCQyWsCZL1VWzJRXbqePtaSt503ygctliKBaBY6/1T6Rkwq2VQT+N+f+yx+TsPfg= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=SKJO1XJA; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPSA id AAF24C433F1; Fri, 23 Feb 2024 20:58:54 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1708721934; bh=ZnhJxh0/iM55/Ih9OWsBqkos+7Gz6O4NkpMi/NZLabM=; h=From:To:Cc:Subject:Date:From; b=SKJO1XJAV3byIfprXimylg/0/cOa72YkVcW2E/j5DAtRQ+zhgVF1vWvSv+xxbwVLB InNYbiDaV89suN0QAjcUd/UltBHwWQPunJ6Pi7N9gyIXrxIDx7jjP38ZSIqzEAuSZh ukS7vWy+ohfhN66QthEMg2EsyGGwdO5E9pB7V8dIC2WbgA8ydnzsNREJUg5Erj6SMG pkPw4aOoxy9KPhMm9oZ1DLkBAWm5jPo7r8d0bVPfRF5OJ2Rkdc50s+HcMYvnwYUeaX PJQ8eWqOHfHynQKi3beH5yNloYu1EdTJoJbgxDLD6mv7w2MuAkBzi/z4YLPPBSlTGZ f4AEkzlhgVazQ== From: Bjorn Helgaas To: linux-pci@vger.kernel.org Cc: linux-kernel@vger.kernel.org, Mika Westerberg , "David E . Box" , =?UTF-8?q?Ilpo=20J=C3=A4rvinen?= , "Rafael J . Wysocki" , Tasev Nikola , Mark Enriquez , Thomas Witt , Werner Sembach , Vidya Sagar , Kai-Heng Feng , Kuppuswamy Sathyanarayanan , Ricky Wu , Mario Limonciello , Bjorn Helgaas Subject: [PATCH v7 0/5] PCI/ASPM: Save/restore L1 PM Substates for suspend/resume Date: Fri, 23 Feb 2024 14:58:46 -0600 Message-Id: <20240223205851.114931-1-helgaas@kernel.org> X-Mailer: git-send-email 2.34.1 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit From: Bjorn Helgaas This is some rework of David's series to preserve ASPM L1 substate configuration across suspend/resume. We've had several attempts to make this work: (unlabeled): https://lore.kernel.org/r/20240128233212.1139663-1-david.e.box@linux.intel.com v5: https://lore.kernel.org/r/20231221011250.191599-1-david.e.box@linux.intel.com v4: https://lore.kernel.org/all/20231002070044.2299644-1-mika.westerberg@linux.intel.com/ v3: https://lore.kernel.org/linux-pci/20230925074636.2893747-1-mika.westerberg@linux.intel.com/ v2: https://lore.kernel.org/linux-pci/20230911073352.3472918-1-mika.westerberg@linux.intel.com/ v1: https://lore.kernel.org/linux-pci/20230627062442.54008-1-mika.westerberg@linux.intel.com/ The most recent posting is the unlabeled one mentioned above, and I'm calling it v6 and this rework v7. Changes since the unlabeled v6: - Rename pci_save_aspm_state() to pci_save_aspm_l1ss_state() (this is the reason for opening this again, because Vidya's patch [1] had to do some incidental renaming). - Rename pcie_restore_aspm_l1ss() to pci_restore_aspm_l1ss_state() to match. - Move the PCI_EXP_LNKCTL_ASPMC from pci_restore_aspm_state() to pci_restore_pcie_state() so both writes are in the same place. - Rename pci_aspm_get_l1ss() to pci_configure_aspm_l1ss() and add the save_buffer there as well. - Split [1/5] into two patches: move pci_configure_ltr() and pci_bridge_reconfigure_ltr() to aspm.c, and build aspm.c unconditionally. - Squash [2/5] and [3/5] since [2/5] didn't add any functionality itself so they seem like a single logical change. [1] https://lore.kernel.org/r/20230125133830.20620-1-vidyas@nvidia.com David E. Box (5): PCI/ASPM: Move pci_configure_ltr() to aspm.c PCI/ASPM: Always build aspm.c PCI/ASPM: Move pci_save_ltr_state() to aspm.c PCI/ASPM: Save L1 PM Substates Capability for suspend/resume PCI/ASPM: Call pci_save_ltr_state() from pci_save_pcie_state() drivers/pci/pci.c | 89 ++++------------ drivers/pci/pci.h | 13 ++- drivers/pci/pcie/Makefile | 2 +- drivers/pci/pcie/aspm.c | 215 ++++++++++++++++++++++++++++++++++++++ drivers/pci/probe.c | 62 +---------- include/linux/pci.h | 2 +- 6 files changed, 252 insertions(+), 131 deletions(-) -- 2.34.1