x86/PCI: Use generic cacheline sizing instead of per-vendor tests.
Instead of the PCI code needing to have code to determine the cacheline size of each processor, use the data the cpu identification code should have already determined during early boot. (The vendor checks are also incomplete, and don't take into account modern CPUs) I've been carrying a variant of this code in Fedora for a while, that prints debug information. There are a number of cases where we are currently setting the PCI cacheline size to 32 bytes, when the CPU cacheline size is 64 bytes. With this patch, we set them both the same. Signed-off-by: Dave Jones <davej@redhat.com> Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
This commit is contained in:
parent
98e724c791
commit
76b1a87b21
1 changed files with 11 additions and 7 deletions
|
@ -420,15 +420,19 @@ int __init pcibios_init(void)
|
|||
}
|
||||
|
||||
/*
|
||||
* Assume PCI cacheline size of 32 bytes for all x86s except K7/K8
|
||||
* and P4. It's also good for 386/486s (which actually have 16)
|
||||
* Set PCI cacheline size to that of the CPU if the CPU has reported it.
|
||||
* (For older CPUs that don't support cpuid, we se it to 32 bytes
|
||||
* It's also good for 386/486s (which actually have 16)
|
||||
* as quite a few PCI devices do not support smaller values.
|
||||
*/
|
||||
pci_dfl_cache_line_size = 32 >> 2;
|
||||
if (c->x86 >= 6 && c->x86_vendor == X86_VENDOR_AMD)
|
||||
pci_dfl_cache_line_size = 64 >> 2; /* K7 & K8 */
|
||||
else if (c->x86 > 6 && c->x86_vendor == X86_VENDOR_INTEL)
|
||||
pci_dfl_cache_line_size = 128 >> 2; /* P4 */
|
||||
if (c->x86_clflush_size > 0) {
|
||||
pci_dfl_cache_line_size = c->x86_clflush_size >> 2;
|
||||
printk(KERN_DEBUG "PCI: pci_cache_line_size set to %d bytes\n",
|
||||
pci_dfl_cache_line_size << 2);
|
||||
} else {
|
||||
pci_dfl_cache_line_size = 32 >> 2;
|
||||
printk(KERN_DEBUG "PCI: Unknown cacheline size. Setting to 32 bytes\n");
|
||||
}
|
||||
|
||||
pcibios_resource_survey();
|
||||
|
||||
|
|
Loading…
Reference in a new issue