mirror of
https://github.com/S3NEO/android_kernel_samsung_msm8226.git
synced 2024-11-07 03:47:13 +00:00
PCI: prepare pci=realloc for multiple options
Let the user could enable and disable with pci=realloc=on or pci=realloc=off Also 1. move variable and functions near the place they are used. 2. change macro to function 3. change related functions and variable to static and _init 4. update parameter description accordingly. This will let us add a config option to control default behavior, and still allow the user to turn off automatic reallocation if it fails on their platform until a permanent solution is found. -v2: still honor pci=realloc, and treat it as pci=realloc=on also use enum instead of ... -v3: update kernel-paramenters.txt according to Jesse. Signed-off-by: Yinghai Lu <yinghai@kernel.org> Acked-by: Jesse Barnes <jbarnes@virtuousgeek.org> Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
This commit is contained in:
parent
0c5be0cb0e
commit
b55438fdd5
4 changed files with 38 additions and 11 deletions
|
@ -2109,8 +2109,13 @@ bytes respectively. Such letter suffixes can also be entirely omitted.
|
||||||
the default.
|
the default.
|
||||||
off: Turn ECRC off
|
off: Turn ECRC off
|
||||||
on: Turn ECRC on.
|
on: Turn ECRC on.
|
||||||
realloc reallocate PCI resources if allocations done by BIOS
|
realloc= Enable/disable reallocating PCI bridge resources
|
||||||
are erroneous.
|
if allocations done by BIOS are too small to
|
||||||
|
accommodate resources required by all child
|
||||||
|
devices.
|
||||||
|
off: Turn realloc off
|
||||||
|
on: Turn realloc on
|
||||||
|
realloc same as realloc=on
|
||||||
|
|
||||||
pcie_aspm= [PCIE] Forcibly enable or disable PCIe Active State Power
|
pcie_aspm= [PCIE] Forcibly enable or disable PCIe Active State Power
|
||||||
Management.
|
Management.
|
||||||
|
|
|
@ -3772,8 +3772,10 @@ static int __init pci_setup(char *str)
|
||||||
pci_no_msi();
|
pci_no_msi();
|
||||||
} else if (!strcmp(str, "noaer")) {
|
} else if (!strcmp(str, "noaer")) {
|
||||||
pci_no_aer();
|
pci_no_aer();
|
||||||
|
} else if (!strncmp(str, "realloc=", 8)) {
|
||||||
|
pci_realloc_get_opt(str + 8);
|
||||||
} else if (!strncmp(str, "realloc", 7)) {
|
} else if (!strncmp(str, "realloc", 7)) {
|
||||||
pci_realloc();
|
pci_realloc_get_opt("on");
|
||||||
} else if (!strcmp(str, "nodomains")) {
|
} else if (!strcmp(str, "nodomains")) {
|
||||||
pci_no_domains();
|
pci_no_domains();
|
||||||
} else if (!strncmp(str, "cbiosize=", 9)) {
|
} else if (!strncmp(str, "cbiosize=", 9)) {
|
||||||
|
|
|
@ -149,7 +149,7 @@ static inline void pci_no_msi(void) { }
|
||||||
static inline void pci_msi_init_pci_dev(struct pci_dev *dev) { }
|
static inline void pci_msi_init_pci_dev(struct pci_dev *dev) { }
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
extern void pci_realloc(void);
|
void pci_realloc_get_opt(char *);
|
||||||
|
|
||||||
static inline int pci_no_d1d2(struct pci_dev *dev)
|
static inline int pci_no_d1d2(struct pci_dev *dev)
|
||||||
{
|
{
|
||||||
|
|
|
@ -48,13 +48,6 @@ static void free_list(struct list_head *head)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int pci_realloc_enable = 0;
|
|
||||||
#define pci_realloc_enabled() pci_realloc_enable
|
|
||||||
void pci_realloc(void)
|
|
||||||
{
|
|
||||||
pci_realloc_enable = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* add_to_list() - add a new resource tracker to the list
|
* add_to_list() - add a new resource tracker to the list
|
||||||
* @head: Head of the list
|
* @head: Head of the list
|
||||||
|
@ -1273,6 +1266,33 @@ static int __init pci_get_max_depth(void)
|
||||||
return depth;
|
return depth;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* -1: undefined, will auto detect later
|
||||||
|
* 0: disabled by user
|
||||||
|
* 1: disabled by auto detect
|
||||||
|
* 2: enabled by user
|
||||||
|
* 3: enabled by auto detect
|
||||||
|
*/
|
||||||
|
enum enable_type {
|
||||||
|
undefined = -1,
|
||||||
|
user_disabled,
|
||||||
|
auto_disabled,
|
||||||
|
user_enabled,
|
||||||
|
auto_enabled,
|
||||||
|
};
|
||||||
|
|
||||||
|
static enum enable_type pci_realloc_enable __initdata = undefined;
|
||||||
|
void __init pci_realloc_get_opt(char *str)
|
||||||
|
{
|
||||||
|
if (!strncmp(str, "off", 3))
|
||||||
|
pci_realloc_enable = user_disabled;
|
||||||
|
else if (!strncmp(str, "on", 2))
|
||||||
|
pci_realloc_enable = user_enabled;
|
||||||
|
}
|
||||||
|
static bool __init pci_realloc_enabled(void)
|
||||||
|
{
|
||||||
|
return pci_realloc_enable >= user_enabled;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* first try will not touch pci bridge res
|
* first try will not touch pci bridge res
|
||||||
|
|
Loading…
Reference in a new issue