qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Qemu-devel] [PATCH V2 0/4] pci: better support for 64-bit MMIO allo


From: Marcel Apfelbaum
Subject: Re: [Qemu-devel] [PATCH V2 0/4] pci: better support for 64-bit MMIO allocation
Date: Wed, 18 May 2016 17:22:43 +0300
User-agent: Mozilla/5.0 (X11; Linux x86_64; rv:38.0) Gecko/20100101 Thunderbird/38.5.0

On 05/18/2016 04:53 PM, Igor Mammedov wrote:
On Sun, 15 May 2016 22:23:30 +0300
Marcel Apfelbaum <address@hidden> wrote:

Hi,

First two patches allocate (max_reserved_ram - max_addr_cpu_addressable) range 
for PCI hotplug
(for PC Machines) instead of the previous 64-bit PCI window that included only
the ranges allocated by the firmware.

The next two patches fix 64-bit CRS computations.
I'd would add test case + expected tables as the first 2 patches
and then finish series with expected tables update with fixed 64bit range

as experiment I've hacked existing piix4 case:

@@ -744,7 +744,9 @@ static void test_acpi_piix4_tcg(void)
       */
      memset(&data, 0, sizeof(data));
      data.machine = MACHINE_PC;
-    test_acpi_one("-machine accel=tcg", &data);
+    test_acpi_one("-machine accel=tcg"
+                  " -device pxb,id=bridge1,bus=pci.0,bus_nr=4"
+                  " -device ivshmem,bus=bridge1,size=4G,shm", &data);
      free_test_data(&data);
  }

And it shows not related to this series, but another pxb issue

+    External (_SB_.PCI0.S18_.PCNT, MethodObj)    // Warning: Unresolved 
method, guessing 0 arguments
...
@@ -1197,8 +1322,8 @@ DefinitionBlock ("tests/acpi-test-data/pc/DSDT.aml", "DSDT", 1, 
"BOCHS ", "BXPCD

              Device (S18)
              {
-                Name (_SUN, 0x03)  // _SUN: Slot User Number
                  Name (_ADR, 0x00030000)  // _ADR: Address
+                Name (_SUN, 0x03)  // _SUN: Slot User Number
                  Method (_EJ0, 1, NotSerialized)  // _EJx: Eject Device
                  {
                      PCEJ (BSEL, _SUN)
@@ -1638,6 +1763,7 @@ DefinitionBlock ("tests/acpi-test-data/pc/DSDT.aml", "DSDT", 1, 
"BOCHS ", "BXPCD
                  BNUM = Zero
                  DVNT (PCIU, One)
                  DVNT (PCID, 0x03)
+                ^S18.PCNT ()
              }
          }
      }

so it's better to have test case in place so that changes to pxb
parts wouldn't go unnoticed and would be observable.

I'll add the test, thanks, and also I'll look for the PXB warning.


Also from above experiment I see that pxb duplicates and uses
the same _PRT method as PCI0, probably should be changed to
something like:

  Method(_PRT)
     return ^PCI0._PRT()


Their PRT are not exactly the same, please see build_prt in 
hw/i386/acpi-build.c .

Thanks,
Marcel

v1 -> v2:
  - resolved some styling issues (Laszlo)
  - rebase on latest master (Laszlo)

Thank you,
Marcel

Marcel Apfelbaum (4):
   hw/pc: extract reserved memory end computation to a standalone
     function
   pci: reserve 64 bit MMIO range for PCI hotplug
   acpi: refactor pxb crs computation
   hw/apci: handle 64-bit MMIO regions correctly

  hw/i386/acpi-build.c | 127 ++++++++++++++++++++++++++++++++++++---------------
  hw/i386/pc.c         |  29 ++++++++----
  hw/pci/pci.c         |  16 ++++++-
  include/hw/i386/pc.h |   1 +
  4 files changed, 127 insertions(+), 46 deletions(-)






reply via email to

[Prev in Thread] Current Thread [Next in Thread]