提交 a47126ec 编写于 作者: B Bjorn Helgaas

PCI/PTM: Cache PTM Capability offset

Cache the PTM Capability offset instead of searching for it every time we
enable/disable PTM or save/restore PTM state.  No functional change
intended.

Link: https://lore.kernel.org/r/20220909202505.314195-2-helgaas@kernel.orgTested-by: NRajvi Jingar <rajvi.jingar@linux.intel.com>
Signed-off-by: NBjorn Helgaas <bhelgaas@google.com>
Reviewed-by: NKuppuswamy Sathyanarayanan <sathyanarayanan.kuppuswamy@linux.intel.com>
Reviewed-by: NMika Westerberg <mika.westerberg@linux.intel.com>
上级 568035b0
...@@ -31,13 +31,9 @@ static void pci_ptm_info(struct pci_dev *dev) ...@@ -31,13 +31,9 @@ static void pci_ptm_info(struct pci_dev *dev)
void pci_disable_ptm(struct pci_dev *dev) void pci_disable_ptm(struct pci_dev *dev)
{ {
int ptm; u16 ptm = dev->ptm_cap;
u16 ctrl; u16 ctrl;
if (!pci_is_pcie(dev))
return;
ptm = pci_find_ext_capability(dev, PCI_EXT_CAP_ID_PTM);
if (!ptm) if (!ptm)
return; return;
...@@ -48,14 +44,10 @@ void pci_disable_ptm(struct pci_dev *dev) ...@@ -48,14 +44,10 @@ void pci_disable_ptm(struct pci_dev *dev)
void pci_save_ptm_state(struct pci_dev *dev) void pci_save_ptm_state(struct pci_dev *dev)
{ {
int ptm; u16 ptm = dev->ptm_cap;
struct pci_cap_saved_state *save_state; struct pci_cap_saved_state *save_state;
u16 *cap; u16 *cap;
if (!pci_is_pcie(dev))
return;
ptm = pci_find_ext_capability(dev, PCI_EXT_CAP_ID_PTM);
if (!ptm) if (!ptm)
return; return;
...@@ -69,16 +61,15 @@ void pci_save_ptm_state(struct pci_dev *dev) ...@@ -69,16 +61,15 @@ void pci_save_ptm_state(struct pci_dev *dev)
void pci_restore_ptm_state(struct pci_dev *dev) void pci_restore_ptm_state(struct pci_dev *dev)
{ {
u16 ptm = dev->ptm_cap;
struct pci_cap_saved_state *save_state; struct pci_cap_saved_state *save_state;
int ptm;
u16 *cap; u16 *cap;
if (!pci_is_pcie(dev)) if (!ptm)
return; return;
save_state = pci_find_saved_ext_cap(dev, PCI_EXT_CAP_ID_PTM); save_state = pci_find_saved_ext_cap(dev, PCI_EXT_CAP_ID_PTM);
ptm = pci_find_ext_capability(dev, PCI_EXT_CAP_ID_PTM); if (!save_state)
if (!save_state || !ptm)
return; return;
cap = (u16 *)&save_state->cap.data[0]; cap = (u16 *)&save_state->cap.data[0];
...@@ -87,7 +78,7 @@ void pci_restore_ptm_state(struct pci_dev *dev) ...@@ -87,7 +78,7 @@ void pci_restore_ptm_state(struct pci_dev *dev)
void pci_ptm_init(struct pci_dev *dev) void pci_ptm_init(struct pci_dev *dev)
{ {
int pos; u16 ptm;
u32 cap, ctrl; u32 cap, ctrl;
u8 local_clock; u8 local_clock;
struct pci_dev *ups; struct pci_dev *ups;
...@@ -117,13 +108,14 @@ void pci_ptm_init(struct pci_dev *dev) ...@@ -117,13 +108,14 @@ void pci_ptm_init(struct pci_dev *dev)
return; return;
} }
pos = pci_find_ext_capability(dev, PCI_EXT_CAP_ID_PTM); ptm = pci_find_ext_capability(dev, PCI_EXT_CAP_ID_PTM);
if (!pos) if (!ptm)
return; return;
dev->ptm_cap = ptm;
pci_add_ext_cap_save_buffer(dev, PCI_EXT_CAP_ID_PTM, sizeof(u16)); pci_add_ext_cap_save_buffer(dev, PCI_EXT_CAP_ID_PTM, sizeof(u16));
pci_read_config_dword(dev, pos + PCI_PTM_CAP, &cap); pci_read_config_dword(dev, ptm + PCI_PTM_CAP, &cap);
local_clock = (cap & PCI_PTM_GRANULARITY_MASK) >> 8; local_clock = (cap & PCI_PTM_GRANULARITY_MASK) >> 8;
/* /*
...@@ -148,7 +140,7 @@ void pci_ptm_init(struct pci_dev *dev) ...@@ -148,7 +140,7 @@ void pci_ptm_init(struct pci_dev *dev)
} }
ctrl |= dev->ptm_granularity << 8; ctrl |= dev->ptm_granularity << 8;
pci_write_config_dword(dev, pos + PCI_PTM_CTRL, ctrl); pci_write_config_dword(dev, ptm + PCI_PTM_CTRL, ctrl);
dev->ptm_enabled = 1; dev->ptm_enabled = 1;
pci_ptm_info(dev); pci_ptm_info(dev);
...@@ -156,18 +148,19 @@ void pci_ptm_init(struct pci_dev *dev) ...@@ -156,18 +148,19 @@ void pci_ptm_init(struct pci_dev *dev)
int pci_enable_ptm(struct pci_dev *dev, u8 *granularity) int pci_enable_ptm(struct pci_dev *dev, u8 *granularity)
{ {
int pos; u16 ptm;
u32 cap, ctrl; u32 cap, ctrl;
struct pci_dev *ups; struct pci_dev *ups;
if (!pci_is_pcie(dev)) if (!pci_is_pcie(dev))
return -EINVAL; return -EINVAL;
pos = pci_find_ext_capability(dev, PCI_EXT_CAP_ID_PTM); ptm = pci_find_ext_capability(dev, PCI_EXT_CAP_ID_PTM);
if (!pos) if (!ptm)
return -EINVAL; return -EINVAL;
pci_read_config_dword(dev, pos + PCI_PTM_CAP, &cap); dev->ptm_cap = ptm;
pci_read_config_dword(dev, ptm + PCI_PTM_CAP, &cap);
if (!(cap & PCI_PTM_CAP_REQ)) if (!(cap & PCI_PTM_CAP_REQ))
return -EINVAL; return -EINVAL;
...@@ -192,7 +185,7 @@ int pci_enable_ptm(struct pci_dev *dev, u8 *granularity) ...@@ -192,7 +185,7 @@ int pci_enable_ptm(struct pci_dev *dev, u8 *granularity)
ctrl = PCI_PTM_CTRL_ENABLE; ctrl = PCI_PTM_CTRL_ENABLE;
ctrl |= dev->ptm_granularity << 8; ctrl |= dev->ptm_granularity << 8;
pci_write_config_dword(dev, pos + PCI_PTM_CTRL, ctrl); pci_write_config_dword(dev, ptm + PCI_PTM_CTRL, ctrl);
dev->ptm_enabled = 1; dev->ptm_enabled = 1;
pci_ptm_info(dev); pci_ptm_info(dev);
......
...@@ -475,6 +475,7 @@ struct pci_dev { ...@@ -475,6 +475,7 @@ struct pci_dev {
unsigned int broken_cmd_compl:1; /* No compl for some cmds */ unsigned int broken_cmd_compl:1; /* No compl for some cmds */
#endif #endif
#ifdef CONFIG_PCIE_PTM #ifdef CONFIG_PCIE_PTM
u16 ptm_cap; /* PTM Capability */
unsigned int ptm_root:1; unsigned int ptm_root:1;
unsigned int ptm_enabled:1; unsigned int ptm_enabled:1;
u8 ptm_granularity; u8 ptm_granularity;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册