Linux Kernel  3.7.1
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Groups Pages
aspm.c
Go to the documentation of this file.
1 /*
2  * File: drivers/pci/pcie/aspm.c
3  * Enabling PCIe link L0s/L1 state and Clock Power Management
4  *
5  * Copyright (C) 2007 Intel
6  * Copyright (C) Zhang Yanmin ([email protected])
7  * Copyright (C) Shaohua Li ([email protected])
8  */
9 
10 #include <linux/kernel.h>
11 #include <linux/module.h>
12 #include <linux/moduleparam.h>
13 #include <linux/pci.h>
14 #include <linux/pci_regs.h>
15 #include <linux/errno.h>
16 #include <linux/pm.h>
17 #include <linux/init.h>
18 #include <linux/slab.h>
19 #include <linux/jiffies.h>
20 #include <linux/delay.h>
21 #include <linux/pci-aspm.h>
22 #include "../pci.h"
23 
24 #ifdef MODULE_PARAM_PREFIX
25 #undef MODULE_PARAM_PREFIX
26 #endif
27 #define MODULE_PARAM_PREFIX "pcie_aspm."
28 
29 /* Note: those are not register definitions */
30 #define ASPM_STATE_L0S_UP (1) /* Upstream direction L0s state */
31 #define ASPM_STATE_L0S_DW (2) /* Downstream direction L0s state */
32 #define ASPM_STATE_L1 (4) /* L1 state */
33 #define ASPM_STATE_L0S (ASPM_STATE_L0S_UP | ASPM_STATE_L0S_DW)
34 #define ASPM_STATE_ALL (ASPM_STATE_L0S | ASPM_STATE_L1)
35 
36 struct aspm_latency {
37  u32 l0s; /* L0s latency (nsec) */
38  u32 l1; /* L1 latency (nsec) */
39 };
40 
42  struct pci_dev *pdev; /* Upstream component of the Link */
43  struct pcie_link_state *root; /* pointer to the root port link */
44  struct pcie_link_state *parent; /* pointer to the parent Link state */
45  struct list_head sibling; /* node in link_list */
46  struct list_head children; /* list of child link states */
47  struct list_head link; /* node in parent's children list */
48 
49  /* ASPM state */
50  u32 aspm_support:3; /* Supported ASPM state */
51  u32 aspm_enabled:3; /* Enabled ASPM state */
52  u32 aspm_capable:3; /* Capable ASPM state with latency */
53  u32 aspm_default:3; /* Default ASPM state by BIOS */
54  u32 aspm_disable:3; /* Disabled ASPM state */
55 
56  /* Clock PM state */
57  u32 clkpm_capable:1; /* Clock PM capable? */
58  u32 clkpm_enabled:1; /* Current Clock PM state */
59  u32 clkpm_default:1; /* Default Clock PM state by BIOS */
60 
61  /* Exit latencies */
62  struct aspm_latency latency_up; /* Upstream direction exit latency */
63  struct aspm_latency latency_dw; /* Downstream direction exit latency */
64  /*
65  * Endpoint acceptable latencies. A pcie downstream port only
66  * has one slot under it, so at most there are 8 functions.
67  */
69 };
70 
71 static int aspm_disabled, aspm_force;
72 static bool aspm_support_enabled = true;
73 static DEFINE_MUTEX(aspm_lock);
74 static LIST_HEAD(link_list);
75 
76 #define POLICY_DEFAULT 0 /* BIOS default setting */
77 #define POLICY_PERFORMANCE 1 /* high performance */
78 #define POLICY_POWERSAVE 2 /* high power saving */
79 
80 #ifdef CONFIG_PCIEASPM_PERFORMANCE
81 static int aspm_policy = POLICY_PERFORMANCE;
82 #elif defined CONFIG_PCIEASPM_POWERSAVE
83 static int aspm_policy = POLICY_POWERSAVE;
84 #else
85 static int aspm_policy;
86 #endif
87 
88 static const char *policy_str[] = {
89  [POLICY_DEFAULT] = "default",
90  [POLICY_PERFORMANCE] = "performance",
91  [POLICY_POWERSAVE] = "powersave"
92 };
93 
94 #define LINK_RETRAIN_TIMEOUT HZ
95 
96 static int policy_to_aspm_state(struct pcie_link_state *link)
97 {
98  switch (aspm_policy) {
99  case POLICY_PERFORMANCE:
100  /* Disable ASPM and Clock PM */
101  return 0;
102  case POLICY_POWERSAVE:
103  /* Enable ASPM L0s/L1 */
104  return ASPM_STATE_ALL;
105  case POLICY_DEFAULT:
106  return link->aspm_default;
107  }
108  return 0;
109 }
110 
111 static int policy_to_clkpm_state(struct pcie_link_state *link)
112 {
113  switch (aspm_policy) {
114  case POLICY_PERFORMANCE:
115  /* Disable ASPM and Clock PM */
116  return 0;
117  case POLICY_POWERSAVE:
118  /* Disable Clock PM */
119  return 1;
120  case POLICY_DEFAULT:
121  return link->clkpm_default;
122  }
123  return 0;
124 }
125 
126 static void pcie_set_clkpm_nocheck(struct pcie_link_state *link, int enable)
127 {
128  struct pci_dev *child;
129  struct pci_bus *linkbus = link->pdev->subordinate;
130 
131  list_for_each_entry(child, &linkbus->devices, bus_list) {
132  if (enable)
133  pcie_capability_set_word(child, PCI_EXP_LNKCTL,
135  else
136  pcie_capability_clear_word(child, PCI_EXP_LNKCTL,
138  }
139  link->clkpm_enabled = !!enable;
140 }
141 
142 static void pcie_set_clkpm(struct pcie_link_state *link, int enable)
143 {
144  /* Don't enable Clock PM if the link is not Clock PM capable */
145  if (!link->clkpm_capable && enable)
146  enable = 0;
147  /* Need nothing if the specified equals to current state */
148  if (link->clkpm_enabled == enable)
149  return;
150  pcie_set_clkpm_nocheck(link, enable);
151 }
152 
153 static void pcie_clkpm_cap_init(struct pcie_link_state *link, int blacklist)
154 {
155  int capable = 1, enabled = 1;
156  u32 reg32;
157  u16 reg16;
158  struct pci_dev *child;
159  struct pci_bus *linkbus = link->pdev->subordinate;
160 
161  /* All functions should have the same cap and state, take the worst */
162  list_for_each_entry(child, &linkbus->devices, bus_list) {
164  if (!(reg32 & PCI_EXP_LNKCAP_CLKPM)) {
165  capable = 0;
166  enabled = 0;
167  break;
168  }
170  if (!(reg16 & PCI_EXP_LNKCTL_CLKREQ_EN))
171  enabled = 0;
172  }
173  link->clkpm_enabled = enabled;
174  link->clkpm_default = enabled;
175  link->clkpm_capable = (blacklist) ? 0 : capable;
176 }
177 
178 /*
179  * pcie_aspm_configure_common_clock: check if the 2 ends of a link
180  * could use common clock. If they are, configure them to use the
181  * common clock. That will reduce the ASPM state exit latency.
182  */
183 static void pcie_aspm_configure_common_clock(struct pcie_link_state *link)
184 {
185  int same_clock = 1;
186  u16 reg16, parent_reg, child_reg[8];
187  unsigned long start_jiffies;
188  struct pci_dev *child, *parent = link->pdev;
189  struct pci_bus *linkbus = parent->subordinate;
190  /*
191  * All functions of a slot should have the same Slot Clock
192  * Configuration, so just check one function
193  */
194  child = list_entry(linkbus->devices.next, struct pci_dev, bus_list);
195  BUG_ON(!pci_is_pcie(child));
196 
197  /* Check downstream component if bit Slot Clock Configuration is 1 */
199  if (!(reg16 & PCI_EXP_LNKSTA_SLC))
200  same_clock = 0;
201 
202  /* Check upstream component if bit Slot Clock Configuration is 1 */
203  pcie_capability_read_word(parent, PCI_EXP_LNKSTA, &reg16);
204  if (!(reg16 & PCI_EXP_LNKSTA_SLC))
205  same_clock = 0;
206 
207  /* Configure downstream component, all functions */
208  list_for_each_entry(child, &linkbus->devices, bus_list) {
210  child_reg[PCI_FUNC(child->devfn)] = reg16;
211  if (same_clock)
212  reg16 |= PCI_EXP_LNKCTL_CCC;
213  else
214  reg16 &= ~PCI_EXP_LNKCTL_CCC;
216  }
217 
218  /* Configure upstream component */
219  pcie_capability_read_word(parent, PCI_EXP_LNKCTL, &reg16);
220  parent_reg = reg16;
221  if (same_clock)
222  reg16 |= PCI_EXP_LNKCTL_CCC;
223  else
224  reg16 &= ~PCI_EXP_LNKCTL_CCC;
226 
227  /* Retrain link */
228  reg16 |= PCI_EXP_LNKCTL_RL;
230 
231  /* Wait for link training end. Break out after waiting for timeout */
232  start_jiffies = jiffies;
233  for (;;) {
234  pcie_capability_read_word(parent, PCI_EXP_LNKSTA, &reg16);
235  if (!(reg16 & PCI_EXP_LNKSTA_LT))
236  break;
237  if (time_after(jiffies, start_jiffies + LINK_RETRAIN_TIMEOUT))
238  break;
239  msleep(1);
240  }
241  if (!(reg16 & PCI_EXP_LNKSTA_LT))
242  return;
243 
244  /* Training failed. Restore common clock configurations */
245  dev_printk(KERN_ERR, &parent->dev,
246  "ASPM: Could not configure common clock\n");
247  list_for_each_entry(child, &linkbus->devices, bus_list)
249  child_reg[PCI_FUNC(child->devfn)]);
250  pcie_capability_write_word(parent, PCI_EXP_LNKCTL, parent_reg);
251 }
252 
253 /* Convert L0s latency encoding to ns */
254 static u32 calc_l0s_latency(u32 encoding)
255 {
256  if (encoding == 0x7)
257  return (5 * 1000); /* > 4us */
258  return (64 << encoding);
259 }
260 
261 /* Convert L0s acceptable latency encoding to ns */
262 static u32 calc_l0s_acceptable(u32 encoding)
263 {
264  if (encoding == 0x7)
265  return -1U;
266  return (64 << encoding);
267 }
268 
269 /* Convert L1 latency encoding to ns */
270 static u32 calc_l1_latency(u32 encoding)
271 {
272  if (encoding == 0x7)
273  return (65 * 1000); /* > 64us */
274  return (1000 << encoding);
275 }
276 
277 /* Convert L1 acceptable latency encoding to ns */
278 static u32 calc_l1_acceptable(u32 encoding)
279 {
280  if (encoding == 0x7)
281  return -1U;
282  return (1000 << encoding);
283 }
284 
290 };
291 
292 static void pcie_get_aspm_reg(struct pci_dev *pdev,
293  struct aspm_register_info *info)
294 {
295  u16 reg16;
296  u32 reg32;
297 
299  info->support = (reg32 & PCI_EXP_LNKCAP_ASPMS) >> 10;
300  info->latency_encoding_l0s = (reg32 & PCI_EXP_LNKCAP_L0SEL) >> 12;
301  info->latency_encoding_l1 = (reg32 & PCI_EXP_LNKCAP_L1EL) >> 15;
302  pcie_capability_read_word(pdev, PCI_EXP_LNKCTL, &reg16);
303  info->enabled = reg16 & PCI_EXP_LNKCTL_ASPMC;
304 }
305 
306 static void pcie_aspm_check_latency(struct pci_dev *endpoint)
307 {
308  u32 latency, l1_switch_latency = 0;
309  struct aspm_latency *acceptable;
310  struct pcie_link_state *link;
311 
312  /* Device not in D0 doesn't need latency check */
313  if ((endpoint->current_state != PCI_D0) &&
314  (endpoint->current_state != PCI_UNKNOWN))
315  return;
316 
317  link = endpoint->bus->self->link_state;
318  acceptable = &link->acceptable[PCI_FUNC(endpoint->devfn)];
319 
320  while (link) {
321  /* Check upstream direction L0s latency */
322  if ((link->aspm_capable & ASPM_STATE_L0S_UP) &&
323  (link->latency_up.l0s > acceptable->l0s))
325 
326  /* Check downstream direction L0s latency */
327  if ((link->aspm_capable & ASPM_STATE_L0S_DW) &&
328  (link->latency_dw.l0s > acceptable->l0s))
330  /*
331  * Check L1 latency.
332  * Every switch on the path to root complex need 1
333  * more microsecond for L1. Spec doesn't mention L0s.
334  */
335  latency = max_t(u32, link->latency_up.l1, link->latency_dw.l1);
336  if ((link->aspm_capable & ASPM_STATE_L1) &&
337  (latency + l1_switch_latency > acceptable->l1))
338  link->aspm_capable &= ~ASPM_STATE_L1;
339  l1_switch_latency += 1000;
340 
341  link = link->parent;
342  }
343 }
344 
345 static void pcie_aspm_cap_init(struct pcie_link_state *link, int blacklist)
346 {
347  struct pci_dev *child, *parent = link->pdev;
348  struct pci_bus *linkbus = parent->subordinate;
349  struct aspm_register_info upreg, dwreg;
350 
351  if (blacklist) {
352  /* Set enabled/disable so that we will disable ASPM later */
355  return;
356  }
357 
358  /* Configure common clock before checking latencies */
359  pcie_aspm_configure_common_clock(link);
360 
361  /* Get upstream/downstream components' register state */
362  pcie_get_aspm_reg(parent, &upreg);
363  child = list_entry(linkbus->devices.next, struct pci_dev, bus_list);
364  pcie_get_aspm_reg(child, &dwreg);
365 
366  /*
367  * Setup L0s state
368  *
369  * Note that we must not enable L0s in either direction on a
370  * given link unless components on both sides of the link each
371  * support L0s.
372  */
373  if (dwreg.support & upreg.support & PCIE_LINK_STATE_L0S)
374  link->aspm_support |= ASPM_STATE_L0S;
375  if (dwreg.enabled & PCIE_LINK_STATE_L0S)
377  if (upreg.enabled & PCIE_LINK_STATE_L0S)
379  link->latency_up.l0s = calc_l0s_latency(upreg.latency_encoding_l0s);
380  link->latency_dw.l0s = calc_l0s_latency(dwreg.latency_encoding_l0s);
381 
382  /* Setup L1 state */
383  if (upreg.support & dwreg.support & PCIE_LINK_STATE_L1)
384  link->aspm_support |= ASPM_STATE_L1;
385  if (upreg.enabled & dwreg.enabled & PCIE_LINK_STATE_L1)
386  link->aspm_enabled |= ASPM_STATE_L1;
387  link->latency_up.l1 = calc_l1_latency(upreg.latency_encoding_l1);
388  link->latency_dw.l1 = calc_l1_latency(dwreg.latency_encoding_l1);
389 
390  /* Save default state */
391  link->aspm_default = link->aspm_enabled;
392 
393  /* Setup initial capable state. Will be updated later */
394  link->aspm_capable = link->aspm_support;
395  /*
396  * If the downstream component has pci bridge function, don't
397  * do ASPM for now.
398  */
399  list_for_each_entry(child, &linkbus->devices, bus_list) {
400  if (pci_pcie_type(child) == PCI_EXP_TYPE_PCI_BRIDGE) {
402  break;
403  }
404  }
405 
406  /* Get and check endpoint acceptable latencies */
407  list_for_each_entry(child, &linkbus->devices, bus_list) {
408  u32 reg32, encoding;
409  struct aspm_latency *acceptable =
410  &link->acceptable[PCI_FUNC(child->devfn)];
411 
412  if (pci_pcie_type(child) != PCI_EXP_TYPE_ENDPOINT &&
413  pci_pcie_type(child) != PCI_EXP_TYPE_LEG_END)
414  continue;
415 
417  /* Calculate endpoint L0s acceptable latency */
418  encoding = (reg32 & PCI_EXP_DEVCAP_L0S) >> 6;
419  acceptable->l0s = calc_l0s_acceptable(encoding);
420  /* Calculate endpoint L1 acceptable latency */
421  encoding = (reg32 & PCI_EXP_DEVCAP_L1) >> 9;
422  acceptable->l1 = calc_l1_acceptable(encoding);
423 
424  pcie_aspm_check_latency(child);
425  }
426 }
427 
428 static void pcie_config_aspm_dev(struct pci_dev *pdev, u32 val)
429 {
430  pcie_capability_clear_and_set_word(pdev, PCI_EXP_LNKCTL, 0x3, val);
431 }
432 
433 static void pcie_config_aspm_link(struct pcie_link_state *link, u32 state)
434 {
435  u32 upstream = 0, dwstream = 0;
436  struct pci_dev *child, *parent = link->pdev;
437  struct pci_bus *linkbus = parent->subordinate;
438 
439  /* Nothing to do if the link is already in the requested state */
440  state &= (link->aspm_capable & ~link->aspm_disable);
441  if (link->aspm_enabled == state)
442  return;
443  /* Convert ASPM state to upstream/downstream ASPM register state */
444  if (state & ASPM_STATE_L0S_UP)
445  dwstream |= PCIE_LINK_STATE_L0S;
446  if (state & ASPM_STATE_L0S_DW)
447  upstream |= PCIE_LINK_STATE_L0S;
448  if (state & ASPM_STATE_L1) {
449  upstream |= PCIE_LINK_STATE_L1;
450  dwstream |= PCIE_LINK_STATE_L1;
451  }
452  /*
453  * Spec 2.0 suggests all functions should be configured the
454  * same setting for ASPM. Enabling ASPM L1 should be done in
455  * upstream component first and then downstream, and vice
456  * versa for disabling ASPM L1. Spec doesn't mention L0S.
457  */
458  if (state & ASPM_STATE_L1)
459  pcie_config_aspm_dev(parent, upstream);
460  list_for_each_entry(child, &linkbus->devices, bus_list)
461  pcie_config_aspm_dev(child, dwstream);
462  if (!(state & ASPM_STATE_L1))
463  pcie_config_aspm_dev(parent, upstream);
464 
465  link->aspm_enabled = state;
466 }
467 
468 static void pcie_config_aspm_path(struct pcie_link_state *link)
469 {
470  while (link) {
471  pcie_config_aspm_link(link, policy_to_aspm_state(link));
472  link = link->parent;
473  }
474 }
475 
476 static void free_link_state(struct pcie_link_state *link)
477 {
478  link->pdev->link_state = NULL;
479  kfree(link);
480 }
481 
482 static int pcie_aspm_sanity_check(struct pci_dev *pdev)
483 {
484  struct pci_dev *child;
485  u32 reg32;
486 
487  /*
488  * Some functions in a slot might not all be PCIe functions,
489  * very strange. Disable ASPM for the whole slot
490  */
491  list_for_each_entry(child, &pdev->subordinate->devices, bus_list) {
492  if (!pci_is_pcie(child))
493  return -EINVAL;
494 
495  /*
496  * If ASPM is disabled then we're not going to change
497  * the BIOS state. It's safe to continue even if it's a
498  * pre-1.1 device
499  */
500 
501  if (aspm_disabled)
502  continue;
503 
504  /*
505  * Disable ASPM for pre-1.1 PCIe device, we follow MS to use
506  * RBER bit to determine if a function is 1.1 version device
507  */
509  if (!(reg32 & PCI_EXP_DEVCAP_RBER) && !aspm_force) {
510  dev_printk(KERN_INFO, &child->dev, "disabling ASPM"
511  " on pre-1.1 PCIe device. You can enable it"
512  " with 'pcie_aspm=force'\n");
513  return -EINVAL;
514  }
515  }
516  return 0;
517 }
518 
519 static struct pcie_link_state *alloc_pcie_link_state(struct pci_dev *pdev)
520 {
521  struct pcie_link_state *link;
522 
523  link = kzalloc(sizeof(*link), GFP_KERNEL);
524  if (!link)
525  return NULL;
526  INIT_LIST_HEAD(&link->sibling);
527  INIT_LIST_HEAD(&link->children);
528  INIT_LIST_HEAD(&link->link);
529  link->pdev = pdev;
530  if (pci_pcie_type(pdev) == PCI_EXP_TYPE_DOWNSTREAM) {
531  struct pcie_link_state *parent;
532  parent = pdev->bus->parent->self->link_state;
533  if (!parent) {
534  kfree(link);
535  return NULL;
536  }
537  link->parent = parent;
538  list_add(&link->link, &parent->children);
539  }
540  /* Setup a pointer to the root port link */
541  if (!link->parent)
542  link->root = link;
543  else
544  link->root = link->parent->root;
545 
546  list_add(&link->sibling, &link_list);
547  pdev->link_state = link;
548  return link;
549 }
550 
551 /*
552  * pcie_aspm_init_link_state: Initiate PCI express link state.
553  * It is called after the pcie and its children devices are scaned.
554  * @pdev: the root port or switch downstream port
555  */
557 {
558  struct pcie_link_state *link;
559  int blacklist = !!pcie_aspm_sanity_check(pdev);
560 
561  if (!pci_is_pcie(pdev) || pdev->link_state)
562  return;
563  if (pci_pcie_type(pdev) != PCI_EXP_TYPE_ROOT_PORT &&
564  pci_pcie_type(pdev) != PCI_EXP_TYPE_DOWNSTREAM)
565  return;
566 
567  /* VIA has a strange chipset, root port is under a bridge */
568  if (pci_pcie_type(pdev) == PCI_EXP_TYPE_ROOT_PORT &&
569  pdev->bus->self)
570  return;
571 
573  if (list_empty(&pdev->subordinate->devices))
574  goto out;
575 
576  mutex_lock(&aspm_lock);
577  link = alloc_pcie_link_state(pdev);
578  if (!link)
579  goto unlock;
580  /*
581  * Setup initial ASPM state. Note that we need to configure
582  * upstream links also because capable state of them can be
583  * update through pcie_aspm_cap_init().
584  */
585  pcie_aspm_cap_init(link, blacklist);
586 
587  /* Setup initial Clock PM state */
588  pcie_clkpm_cap_init(link, blacklist);
589 
590  /*
591  * At this stage drivers haven't had an opportunity to change the
592  * link policy setting. Enabling ASPM on broken hardware can cripple
593  * it even before the driver has had a chance to disable ASPM, so
594  * default to a safe level right now. If we're enabling ASPM beyond
595  * the BIOS's expectation, we'll do so once pci_enable_device() is
596  * called.
597  */
598  if (aspm_policy != POLICY_POWERSAVE) {
599  pcie_config_aspm_path(link);
600  pcie_set_clkpm(link, policy_to_clkpm_state(link));
601  }
602 
603 unlock:
604  mutex_unlock(&aspm_lock);
605 out:
607 }
608 
609 /* Recheck latencies and update aspm_capable for links under the root */
610 static void pcie_update_aspm_capable(struct pcie_link_state *root)
611 {
612  struct pcie_link_state *link;
613  BUG_ON(root->parent);
614  list_for_each_entry(link, &link_list, sibling) {
615  if (link->root != root)
616  continue;
617  link->aspm_capable = link->aspm_support;
618  }
619  list_for_each_entry(link, &link_list, sibling) {
620  struct pci_dev *child;
621  struct pci_bus *linkbus = link->pdev->subordinate;
622  if (link->root != root)
623  continue;
624  list_for_each_entry(child, &linkbus->devices, bus_list) {
625  if ((pci_pcie_type(child) != PCI_EXP_TYPE_ENDPOINT) &&
626  (pci_pcie_type(child) != PCI_EXP_TYPE_LEG_END))
627  continue;
628  pcie_aspm_check_latency(child);
629  }
630  }
631 }
632 
633 /* @pdev: the endpoint device */
635 {
636  struct pci_dev *parent = pdev->bus->self;
637  struct pcie_link_state *link, *root, *parent_link;
638 
639  if (!pci_is_pcie(pdev) || !parent || !parent->link_state)
640  return;
641  if ((pci_pcie_type(parent) != PCI_EXP_TYPE_ROOT_PORT) &&
642  (pci_pcie_type(parent) != PCI_EXP_TYPE_DOWNSTREAM))
643  return;
644 
646  mutex_lock(&aspm_lock);
647  /*
648  * All PCIe functions are in one slot, remove one function will remove
649  * the whole slot, so just wait until we are the last function left.
650  */
651  if (!list_is_last(&pdev->bus_list, &parent->subordinate->devices))
652  goto out;
653 
654  link = parent->link_state;
655  root = link->root;
656  parent_link = link->parent;
657 
658  /* All functions are removed, so just disable ASPM for the link */
659  pcie_config_aspm_link(link, 0);
660  list_del(&link->sibling);
661  list_del(&link->link);
662  /* Clock PM is for endpoint device */
663  free_link_state(link);
664 
665  /* Recheck latencies and configure upstream links */
666  if (parent_link) {
667  pcie_update_aspm_capable(root);
668  pcie_config_aspm_path(parent_link);
669  }
670 out:
671  mutex_unlock(&aspm_lock);
673 }
674 
675 /* @pdev: the root port or switch downstream port */
677 {
678  struct pcie_link_state *link = pdev->link_state;
679 
680  if (aspm_disabled || !pci_is_pcie(pdev) || !link)
681  return;
682  if ((pci_pcie_type(pdev) != PCI_EXP_TYPE_ROOT_PORT) &&
683  (pci_pcie_type(pdev) != PCI_EXP_TYPE_DOWNSTREAM))
684  return;
685  /*
686  * Devices changed PM state, we should recheck if latency
687  * meets all functions' requirement
688  */
690  mutex_lock(&aspm_lock);
691  pcie_update_aspm_capable(link->root);
692  pcie_config_aspm_path(link);
693  mutex_unlock(&aspm_lock);
695 }
696 
698 {
699  struct pcie_link_state *link = pdev->link_state;
700 
701  if (aspm_disabled || !pci_is_pcie(pdev) || !link)
702  return;
703 
704  if (aspm_policy != POLICY_POWERSAVE)
705  return;
706 
707  if ((pci_pcie_type(pdev) != PCI_EXP_TYPE_ROOT_PORT) &&
708  (pci_pcie_type(pdev) != PCI_EXP_TYPE_DOWNSTREAM))
709  return;
710 
712  mutex_lock(&aspm_lock);
713  pcie_config_aspm_path(link);
714  pcie_set_clkpm(link, policy_to_clkpm_state(link));
715  mutex_unlock(&aspm_lock);
717 }
718 
719 /*
720  * pci_disable_link_state - disable pci device's link state, so the link will
721  * never enter specific states
722  */
723 static void __pci_disable_link_state(struct pci_dev *pdev, int state, bool sem,
724  bool force)
725 {
726  struct pci_dev *parent = pdev->bus->self;
727  struct pcie_link_state *link;
728 
729  if (aspm_disabled && !force)
730  return;
731 
732  if (!pci_is_pcie(pdev))
733  return;
734 
735  if (pci_pcie_type(pdev) == PCI_EXP_TYPE_ROOT_PORT ||
736  pci_pcie_type(pdev) == PCI_EXP_TYPE_DOWNSTREAM)
737  parent = pdev;
738  if (!parent || !parent->link_state)
739  return;
740 
741  if (sem)
742  down_read(&pci_bus_sem);
743  mutex_lock(&aspm_lock);
744  link = parent->link_state;
745  if (state & PCIE_LINK_STATE_L0S)
746  link->aspm_disable |= ASPM_STATE_L0S;
747  if (state & PCIE_LINK_STATE_L1)
748  link->aspm_disable |= ASPM_STATE_L1;
749  pcie_config_aspm_link(link, policy_to_aspm_state(link));
750 
751  if (state & PCIE_LINK_STATE_CLKPM) {
752  link->clkpm_capable = 0;
753  pcie_set_clkpm(link, 0);
754  }
755  mutex_unlock(&aspm_lock);
756  if (sem)
757  up_read(&pci_bus_sem);
758 }
759 
760 void pci_disable_link_state_locked(struct pci_dev *pdev, int state)
761 {
762  __pci_disable_link_state(pdev, state, false, false);
763 }
765 
766 void pci_disable_link_state(struct pci_dev *pdev, int state)
767 {
768  __pci_disable_link_state(pdev, state, true, false);
769 }
771 
773 {
774  struct pci_dev *child;
775 
776  /*
777  * Clear any ASPM setup that the firmware has carried out on this bus
778  */
779  list_for_each_entry(child, &bus->devices, bus_list) {
780  __pci_disable_link_state(child, PCIE_LINK_STATE_L0S |
781  PCIE_LINK_STATE_L1 |
782  PCIE_LINK_STATE_CLKPM,
783  false, true);
784  }
785 }
786 
787 static int pcie_aspm_set_policy(const char *val, struct kernel_param *kp)
788 {
789  int i;
790  struct pcie_link_state *link;
791 
792  if (aspm_disabled)
793  return -EPERM;
794  for (i = 0; i < ARRAY_SIZE(policy_str); i++)
795  if (!strncmp(val, policy_str[i], strlen(policy_str[i])))
796  break;
797  if (i >= ARRAY_SIZE(policy_str))
798  return -EINVAL;
799  if (i == aspm_policy)
800  return 0;
801 
802  down_read(&pci_bus_sem);
803  mutex_lock(&aspm_lock);
804  aspm_policy = i;
805  list_for_each_entry(link, &link_list, sibling) {
806  pcie_config_aspm_link(link, policy_to_aspm_state(link));
807  pcie_set_clkpm(link, policy_to_clkpm_state(link));
808  }
809  mutex_unlock(&aspm_lock);
810  up_read(&pci_bus_sem);
811  return 0;
812 }
813 
814 static int pcie_aspm_get_policy(char *buffer, struct kernel_param *kp)
815 {
816  int i, cnt = 0;
817  for (i = 0; i < ARRAY_SIZE(policy_str); i++)
818  if (i == aspm_policy)
819  cnt += sprintf(buffer + cnt, "[%s] ", policy_str[i]);
820  else
821  cnt += sprintf(buffer + cnt, "%s ", policy_str[i]);
822  return cnt;
823 }
824 
825 module_param_call(policy, pcie_aspm_set_policy, pcie_aspm_get_policy,
826  NULL, 0644);
827 
828 #ifdef CONFIG_PCIEASPM_DEBUG
829 static ssize_t link_state_show(struct device *dev,
830  struct device_attribute *attr,
831  char *buf)
832 {
833  struct pci_dev *pci_device = to_pci_dev(dev);
834  struct pcie_link_state *link_state = pci_device->link_state;
835 
836  return sprintf(buf, "%d\n", link_state->aspm_enabled);
837 }
838 
839 static ssize_t link_state_store(struct device *dev,
840  struct device_attribute *attr,
841  const char *buf,
842  size_t n)
843 {
844  struct pci_dev *pdev = to_pci_dev(dev);
845  struct pcie_link_state *link, *root = pdev->link_state->root;
846  u32 val = buf[0] - '0', state = 0;
847 
848  if (aspm_disabled)
849  return -EPERM;
850  if (n < 1 || val > 3)
851  return -EINVAL;
852 
853  /* Convert requested state to ASPM state */
854  if (val & PCIE_LINK_STATE_L0S)
855  state |= ASPM_STATE_L0S;
856  if (val & PCIE_LINK_STATE_L1)
857  state |= ASPM_STATE_L1;
858 
859  down_read(&pci_bus_sem);
860  mutex_lock(&aspm_lock);
861  list_for_each_entry(link, &link_list, sibling) {
862  if (link->root != root)
863  continue;
864  pcie_config_aspm_link(link, state);
865  }
866  mutex_unlock(&aspm_lock);
867  up_read(&pci_bus_sem);
868  return n;
869 }
870 
871 static ssize_t clk_ctl_show(struct device *dev,
872  struct device_attribute *attr,
873  char *buf)
874 {
875  struct pci_dev *pci_device = to_pci_dev(dev);
876  struct pcie_link_state *link_state = pci_device->link_state;
877 
878  return sprintf(buf, "%d\n", link_state->clkpm_enabled);
879 }
880 
881 static ssize_t clk_ctl_store(struct device *dev,
882  struct device_attribute *attr,
883  const char *buf,
884  size_t n)
885 {
886  struct pci_dev *pdev = to_pci_dev(dev);
887  int state;
888 
889  if (n < 1)
890  return -EINVAL;
891  state = buf[0]-'0';
892 
893  down_read(&pci_bus_sem);
894  mutex_lock(&aspm_lock);
895  pcie_set_clkpm_nocheck(pdev->link_state, !!state);
896  mutex_unlock(&aspm_lock);
897  up_read(&pci_bus_sem);
898 
899  return n;
900 }
901 
902 static DEVICE_ATTR(link_state, 0644, link_state_show, link_state_store);
903 static DEVICE_ATTR(clk_ctl, 0644, clk_ctl_show, clk_ctl_store);
904 
905 static char power_group[] = "power";
906 void pcie_aspm_create_sysfs_dev_files(struct pci_dev *pdev)
907 {
908  struct pcie_link_state *link_state = pdev->link_state;
909 
910  if (!pci_is_pcie(pdev) ||
911  (pci_pcie_type(pdev) != PCI_EXP_TYPE_ROOT_PORT &&
912  pci_pcie_type(pdev) != PCI_EXP_TYPE_DOWNSTREAM) || !link_state)
913  return;
914 
915  if (link_state->aspm_support)
916  sysfs_add_file_to_group(&pdev->dev.kobj,
917  &dev_attr_link_state.attr, power_group);
918  if (link_state->clkpm_capable)
919  sysfs_add_file_to_group(&pdev->dev.kobj,
920  &dev_attr_clk_ctl.attr, power_group);
921 }
922 
923 void pcie_aspm_remove_sysfs_dev_files(struct pci_dev *pdev)
924 {
925  struct pcie_link_state *link_state = pdev->link_state;
926 
927  if (!pci_is_pcie(pdev) ||
928  (pci_pcie_type(pdev) != PCI_EXP_TYPE_ROOT_PORT &&
929  pci_pcie_type(pdev) != PCI_EXP_TYPE_DOWNSTREAM) || !link_state)
930  return;
931 
932  if (link_state->aspm_support)
933  sysfs_remove_file_from_group(&pdev->dev.kobj,
934  &dev_attr_link_state.attr, power_group);
935  if (link_state->clkpm_capable)
936  sysfs_remove_file_from_group(&pdev->dev.kobj,
937  &dev_attr_clk_ctl.attr, power_group);
938 }
939 #endif
940 
941 static int __init pcie_aspm_disable(char *str)
942 {
943  if (!strcmp(str, "off")) {
944  aspm_policy = POLICY_DEFAULT;
945  aspm_disabled = 1;
946  aspm_support_enabled = false;
947  printk(KERN_INFO "PCIe ASPM is disabled\n");
948  } else if (!strcmp(str, "force")) {
949  aspm_force = 1;
950  printk(KERN_INFO "PCIe ASPM is forcibly enabled\n");
951  }
952  return 1;
953 }
954 
955 __setup("pcie_aspm=", pcie_aspm_disable);
956 
957 void pcie_no_aspm(void)
958 {
959  /*
960  * Disabling ASPM is intended to prevent the kernel from modifying
961  * existing hardware state, not to clear existing state. To that end:
962  * (a) set policy to POLICY_DEFAULT in order to avoid changing state
963  * (b) prevent userspace from changing policy
964  */
965  if (!aspm_force) {
966  aspm_policy = POLICY_DEFAULT;
967  aspm_disabled = 1;
968  }
969 }
970 
978 {
979  return !aspm_disabled;
980 }
982 
984 {
985  return aspm_support_enabled;
986 }