diff options
-rw-r--r-- | arch/x86/pci/mmconfig-shared.c | 12 |
1 files changed, 7 insertions, 5 deletions
diff --git a/arch/x86/pci/mmconfig-shared.c b/arch/x86/pci/mmconfig-shared.c index 9bf04bcfb9c2..fbadb89c71eb 100644 --- a/arch/x86/pci/mmconfig-shared.c +++ b/arch/x86/pci/mmconfig-shared.c | |||
@@ -555,7 +555,7 @@ static int __init pci_parse_mcfg(struct acpi_table_header *header) | |||
555 | { | 555 | { |
556 | struct acpi_table_mcfg *mcfg; | 556 | struct acpi_table_mcfg *mcfg; |
557 | unsigned long i; | 557 | unsigned long i; |
558 | int config_size; | 558 | int entries, config_size; |
559 | 559 | ||
560 | if (!header) | 560 | if (!header) |
561 | return -EINVAL; | 561 | return -EINVAL; |
@@ -564,17 +564,18 @@ static int __init pci_parse_mcfg(struct acpi_table_header *header) | |||
564 | 564 | ||
565 | /* how many config structures do we have */ | 565 | /* how many config structures do we have */ |
566 | pci_mmcfg_config_num = 0; | 566 | pci_mmcfg_config_num = 0; |
567 | entries = 0; | ||
567 | i = header->length - sizeof(struct acpi_table_mcfg); | 568 | i = header->length - sizeof(struct acpi_table_mcfg); |
568 | while (i >= sizeof(struct acpi_mcfg_allocation)) { | 569 | while (i >= sizeof(struct acpi_mcfg_allocation)) { |
569 | ++pci_mmcfg_config_num; | 570 | entries++; |
570 | i -= sizeof(struct acpi_mcfg_allocation); | 571 | i -= sizeof(struct acpi_mcfg_allocation); |
571 | }; | 572 | }; |
572 | if (pci_mmcfg_config_num == 0) { | 573 | if (entries == 0) { |
573 | printk(KERN_ERR PREFIX "MMCONFIG has no entries\n"); | 574 | printk(KERN_ERR PREFIX "MMCONFIG has no entries\n"); |
574 | return -ENODEV; | 575 | return -ENODEV; |
575 | } | 576 | } |
576 | 577 | ||
577 | config_size = pci_mmcfg_config_num * sizeof(*pci_mmcfg_config); | 578 | config_size = entries * sizeof(*pci_mmcfg_config); |
578 | pci_mmcfg_config = kmalloc(config_size, GFP_KERNEL); | 579 | pci_mmcfg_config = kmalloc(config_size, GFP_KERNEL); |
579 | if (!pci_mmcfg_config) { | 580 | if (!pci_mmcfg_config) { |
580 | printk(KERN_WARNING PREFIX | 581 | printk(KERN_WARNING PREFIX |
@@ -583,8 +584,9 @@ static int __init pci_parse_mcfg(struct acpi_table_header *header) | |||
583 | } | 584 | } |
584 | 585 | ||
585 | memcpy(pci_mmcfg_config, &mcfg[1], config_size); | 586 | memcpy(pci_mmcfg_config, &mcfg[1], config_size); |
587 | pci_mmcfg_config_num = entries; | ||
586 | 588 | ||
587 | for (i = 0; i < pci_mmcfg_config_num; ++i) { | 589 | for (i = 0; i < entries; i++) { |
588 | if (acpi_mcfg_check_entry(mcfg, &pci_mmcfg_config[i])) { | 590 | if (acpi_mcfg_check_entry(mcfg, &pci_mmcfg_config[i])) { |
589 | kfree(pci_mmcfg_config); | 591 | kfree(pci_mmcfg_config); |
590 | pci_mmcfg_config_num = 0; | 592 | pci_mmcfg_config_num = 0; |