diff mbox series

[for-9.0] ppc440_pcix: Do not expose a bridge device on PCI bus

Message ID 20240409235543.0E0C34E601C@zero.eik.bme.hu
State New
Headers show
Series [for-9.0] ppc440_pcix: Do not expose a bridge device on PCI bus | expand

Commit Message

BALATON Zoltan April 9, 2024, 11:55 p.m. UTC
Real 460EX SoC apparently does not expose a bridge device and having
it appear on PCI bus confuses an AmigaOS file system driver that uses
this to detect which machine it is running on. Since values written
here by firmware are never read, just ignore these writes and drop the
bridge device.

Signed-off-by: BALATON Zoltan <balaton@eik.bme.hu>
---
This is only used by sam460ex and this fixes an issue with AmigaOS on
this machine so I'd like this to be merged for 9.0 please.

 hw/pci-host/ppc440_pcix.c | 14 +-------------
 1 file changed, 1 insertion(+), 13 deletions(-)

Comments

Nicholas Piggin April 10, 2024, 4:38 a.m. UTC | #1
On Wed Apr 10, 2024 at 9:55 AM AEST, BALATON Zoltan wrote:
> Real 460EX SoC apparently does not expose a bridge device and having
> it appear on PCI bus confuses an AmigaOS file system driver that uses
> this to detect which machine it is running on. Since values written
> here by firmware are never read, just ignore these writes and drop the
> bridge device.
>
> Signed-off-by: BALATON Zoltan <balaton@eik.bme.hu>
> ---
> This is only used by sam460ex and this fixes an issue with AmigaOS on
> this machine so I'd like this to be merged for 9.0 please.

Is it a regression? Does it have a fixes: or resolves: tag?

Unless we broke it in this cycle, I would be inclined to wait,
and we can ask to put it in stable.

Thanks,
Nick

>
>  hw/pci-host/ppc440_pcix.c | 14 +-------------
>  1 file changed, 1 insertion(+), 13 deletions(-)
>
> diff --git a/hw/pci-host/ppc440_pcix.c b/hw/pci-host/ppc440_pcix.c
> index 1926ae2a27..ba38172989 100644
> --- a/hw/pci-host/ppc440_pcix.c
> +++ b/hw/pci-host/ppc440_pcix.c
> @@ -52,7 +52,6 @@ OBJECT_DECLARE_SIMPLE_TYPE(PPC440PCIXState, PPC440_PCIX_HOST)
>  struct PPC440PCIXState {
>      PCIHostState parent_obj;
>  
> -    PCIDevice *dev;
>      struct PLBOutMap pom[PPC440_PCIX_NR_POMS];
>      struct PLBInMap pim[PPC440_PCIX_NR_PIMS];
>      uint32_t sts;
> @@ -170,10 +169,6 @@ static void ppc440_pcix_reg_write4(void *opaque, hwaddr addr,
>  
>      trace_ppc440_pcix_reg_write(addr, val, size);
>      switch (addr) {
> -    case PCI_VENDOR_ID ... PCI_MAX_LAT:
> -        stl_le_p(s->dev->config + addr, val);
> -        break;
> -
>      case PCIX0_POM0LAL:
>          s->pom[0].la &= 0xffffffff00000000ULL;
>          s->pom[0].la |= val;
> @@ -301,10 +296,6 @@ static uint64_t ppc440_pcix_reg_read4(void *opaque, hwaddr addr,
>      uint32_t val;
>  
>      switch (addr) {
> -    case PCI_VENDOR_ID ... PCI_MAX_LAT:
> -        val = ldl_le_p(s->dev->config + addr);
> -        break;
> -
>      case PCIX0_POM0LAL:
>          val = s->pom[0].la;
>          break;
> @@ -498,10 +489,7 @@ static void ppc440_pcix_realize(DeviceState *dev, Error **errp)
>      memory_region_init(&s->iomem, OBJECT(dev), "pci-io", 64 * KiB);
>      h->bus = pci_register_root_bus(dev, NULL, ppc440_pcix_set_irq,
>                           ppc440_pcix_map_irq, &s->irq, &s->busmem, &s->iomem,
> -                         PCI_DEVFN(0, 0), 1, TYPE_PCI_BUS);
> -
> -    s->dev = pci_create_simple(h->bus, PCI_DEVFN(0, 0),
> -                               TYPE_PPC4xx_HOST_BRIDGE);
> +                         PCI_DEVFN(1, 0), 1, TYPE_PCI_BUS);
>  
>      memory_region_init(&s->bm, OBJECT(s), "bm-ppc440-pcix", UINT64_MAX);
>      memory_region_add_subregion(&s->bm, 0x0, &s->busmem);
BALATON Zoltan April 10, 2024, 11:03 a.m. UTC | #2
On Wed, 10 Apr 2024, Nicholas Piggin wrote:
> On Wed Apr 10, 2024 at 9:55 AM AEST, BALATON Zoltan wrote:
>> Real 460EX SoC apparently does not expose a bridge device and having
>> it appear on PCI bus confuses an AmigaOS file system driver that uses
>> this to detect which machine it is running on. Since values written
>> here by firmware are never read, just ignore these writes and drop the
>> bridge device.
>>
>> Signed-off-by: BALATON Zoltan <balaton@eik.bme.hu>
>> ---
>> This is only used by sam460ex and this fixes an issue with AmigaOS on
>> this machine so I'd like this to be merged for 9.0 please.
>
> Is it a regression? Does it have a fixes: or resolves: tag?
>
> Unless we broke it in this cycle, I would be inclined to wait,
> and we can ask to put it in stable.

It's not something that broke in this cycle but since this does not affect 
anything else than sam460ex I think it's OK to change this for 9.0. The 
changes to 440 tlb in this cycle made sam460ex more useful to run AmigaOS 
and this fixes the file system driver on it so it would make 9.0 really 
usable. Otherwise people would have to wait longer until August or install 
a stable update. Since this has low chance to break anything (tested with 
AmogaOS and Linux and MorphOS does not boot due to do_io changes anyway) I 
don't think we have to wait with this.

Regards,
BALATON Zoltan

> Thanks,
> Nick
>
>>
>>  hw/pci-host/ppc440_pcix.c | 14 +-------------
>>  1 file changed, 1 insertion(+), 13 deletions(-)
>>
>> diff --git a/hw/pci-host/ppc440_pcix.c b/hw/pci-host/ppc440_pcix.c
>> index 1926ae2a27..ba38172989 100644
>> --- a/hw/pci-host/ppc440_pcix.c
>> +++ b/hw/pci-host/ppc440_pcix.c
>> @@ -52,7 +52,6 @@ OBJECT_DECLARE_SIMPLE_TYPE(PPC440PCIXState, PPC440_PCIX_HOST)
>>  struct PPC440PCIXState {
>>      PCIHostState parent_obj;
>>
>> -    PCIDevice *dev;
>>      struct PLBOutMap pom[PPC440_PCIX_NR_POMS];
>>      struct PLBInMap pim[PPC440_PCIX_NR_PIMS];
>>      uint32_t sts;
>> @@ -170,10 +169,6 @@ static void ppc440_pcix_reg_write4(void *opaque, hwaddr addr,
>>
>>      trace_ppc440_pcix_reg_write(addr, val, size);
>>      switch (addr) {
>> -    case PCI_VENDOR_ID ... PCI_MAX_LAT:
>> -        stl_le_p(s->dev->config + addr, val);
>> -        break;
>> -
>>      case PCIX0_POM0LAL:
>>          s->pom[0].la &= 0xffffffff00000000ULL;
>>          s->pom[0].la |= val;
>> @@ -301,10 +296,6 @@ static uint64_t ppc440_pcix_reg_read4(void *opaque, hwaddr addr,
>>      uint32_t val;
>>
>>      switch (addr) {
>> -    case PCI_VENDOR_ID ... PCI_MAX_LAT:
>> -        val = ldl_le_p(s->dev->config + addr);
>> -        break;
>> -
>>      case PCIX0_POM0LAL:
>>          val = s->pom[0].la;
>>          break;
>> @@ -498,10 +489,7 @@ static void ppc440_pcix_realize(DeviceState *dev, Error **errp)
>>      memory_region_init(&s->iomem, OBJECT(dev), "pci-io", 64 * KiB);
>>      h->bus = pci_register_root_bus(dev, NULL, ppc440_pcix_set_irq,
>>                           ppc440_pcix_map_irq, &s->irq, &s->busmem, &s->iomem,
>> -                         PCI_DEVFN(0, 0), 1, TYPE_PCI_BUS);
>> -
>> -    s->dev = pci_create_simple(h->bus, PCI_DEVFN(0, 0),
>> -                               TYPE_PPC4xx_HOST_BRIDGE);
>> +                         PCI_DEVFN(1, 0), 1, TYPE_PCI_BUS);
>>
>>      memory_region_init(&s->bm, OBJECT(s), "bm-ppc440-pcix", UINT64_MAX);
>>      memory_region_add_subregion(&s->bm, 0x0, &s->busmem);
>
>
>
Nicholas Piggin April 16, 2024, 2:26 a.m. UTC | #3
On Wed Apr 10, 2024 at 9:03 PM AEST, BALATON Zoltan wrote:
> On Wed, 10 Apr 2024, Nicholas Piggin wrote:
> > On Wed Apr 10, 2024 at 9:55 AM AEST, BALATON Zoltan wrote:
> >> Real 460EX SoC apparently does not expose a bridge device and having
> >> it appear on PCI bus confuses an AmigaOS file system driver that uses
> >> this to detect which machine it is running on. Since values written
> >> here by firmware are never read, just ignore these writes and drop the
> >> bridge device.
> >>
> >> Signed-off-by: BALATON Zoltan <balaton@eik.bme.hu>
> >> ---
> >> This is only used by sam460ex and this fixes an issue with AmigaOS on
> >> this machine so I'd like this to be merged for 9.0 please.
> >
> > Is it a regression? Does it have a fixes: or resolves: tag?
> >
> > Unless we broke it in this cycle, I would be inclined to wait,
> > and we can ask to put it in stable.
>
> It's not something that broke in this cycle but since this does not affect 
> anything else than sam460ex I think it's OK to change this for 9.0. The 
> changes to 440 tlb in this cycle made sam460ex more useful to run AmigaOS 
> and this fixes the file system driver on it so it would make 9.0 really 
> usable. Otherwise people would have to wait longer until August or install 
> a stable update. Since this has low chance to break anything (tested with 
> AmogaOS and Linux and MorphOS does not boot due to do_io changes anyway) I 
> don't think we have to wait with this.

Hey, travelling / at a conference / on vacation for the next couple of
weeks.

It's just a bit late for hard freeze IMO, since we didn't break it
before the prior release or a bad security / crash bug. Will put it in
9.1.

Thanks,
Nick
BALATON Zoltan April 16, 2024, 9:43 a.m. UTC | #4
On Tue, 16 Apr 2024, Nicholas Piggin wrote:
> On Wed Apr 10, 2024 at 9:03 PM AEST, BALATON Zoltan wrote:
>> On Wed, 10 Apr 2024, Nicholas Piggin wrote:
>>> On Wed Apr 10, 2024 at 9:55 AM AEST, BALATON Zoltan wrote:
>>>> Real 460EX SoC apparently does not expose a bridge device and having
>>>> it appear on PCI bus confuses an AmigaOS file system driver that uses
>>>> this to detect which machine it is running on. Since values written
>>>> here by firmware are never read, just ignore these writes and drop the
>>>> bridge device.
>>>>
>>>> Signed-off-by: BALATON Zoltan <balaton@eik.bme.hu>
>>>> ---
>>>> This is only used by sam460ex and this fixes an issue with AmigaOS on
>>>> this machine so I'd like this to be merged for 9.0 please.
>>>
>>> Is it a regression? Does it have a fixes: or resolves: tag?
>>>
>>> Unless we broke it in this cycle, I would be inclined to wait,
>>> and we can ask to put it in stable.
>>
>> It's not something that broke in this cycle but since this does not affect
>> anything else than sam460ex I think it's OK to change this for 9.0. The
>> changes to 440 tlb in this cycle made sam460ex more useful to run AmigaOS
>> and this fixes the file system driver on it so it would make 9.0 really
>> usable. Otherwise people would have to wait longer until August or install
>> a stable update. Since this has low chance to break anything (tested with
>> AmogaOS and Linux and MorphOS does not boot due to do_io changes anyway) I
>> don't think we have to wait with this.
>
> Hey, travelling / at a conference / on vacation for the next couple of
> weeks.
>
> It's just a bit late for hard freeze IMO, since we didn't break it
> before the prior release or a bad security / crash bug. Will put it in
> 9.1.

Philippe already queued this (and another) patch. This fixes AmigaOS on 
sam460ex which became usable with the tlbwe changes in this cycle but it's 
not really usable without a file system driver that this patch fixes. 
Please allow this in 9.0 so users who want to try it don't have to wait a 
few months more. Sorry for sending it this late but it was reported late 
and took time to debug it.

Regards,
BALATON Zoltan
Nicholas Piggin April 17, 2024, 2:09 a.m. UTC | #5
On Tue Apr 16, 2024 at 7:43 PM AEST, BALATON Zoltan wrote:
> On Tue, 16 Apr 2024, Nicholas Piggin wrote:
> > On Wed Apr 10, 2024 at 9:03 PM AEST, BALATON Zoltan wrote:
> >> On Wed, 10 Apr 2024, Nicholas Piggin wrote:
> >>> On Wed Apr 10, 2024 at 9:55 AM AEST, BALATON Zoltan wrote:
> >>>> Real 460EX SoC apparently does not expose a bridge device and having
> >>>> it appear on PCI bus confuses an AmigaOS file system driver that uses
> >>>> this to detect which machine it is running on. Since values written
> >>>> here by firmware are never read, just ignore these writes and drop the
> >>>> bridge device.
> >>>>
> >>>> Signed-off-by: BALATON Zoltan <balaton@eik.bme.hu>
> >>>> ---
> >>>> This is only used by sam460ex and this fixes an issue with AmigaOS on
> >>>> this machine so I'd like this to be merged for 9.0 please.
> >>>
> >>> Is it a regression? Does it have a fixes: or resolves: tag?
> >>>
> >>> Unless we broke it in this cycle, I would be inclined to wait,
> >>> and we can ask to put it in stable.
> >>
> >> It's not something that broke in this cycle but since this does not affect
> >> anything else than sam460ex I think it's OK to change this for 9.0. The
> >> changes to 440 tlb in this cycle made sam460ex more useful to run AmigaOS
> >> and this fixes the file system driver on it so it would make 9.0 really
> >> usable. Otherwise people would have to wait longer until August or install
> >> a stable update. Since this has low chance to break anything (tested with
> >> AmogaOS and Linux and MorphOS does not boot due to do_io changes anyway) I
> >> don't think we have to wait with this.
> >
> > Hey, travelling / at a conference / on vacation for the next couple of
> > weeks.
> >
> > It's just a bit late for hard freeze IMO, since we didn't break it
> > before the prior release or a bad security / crash bug. Will put it in
> > 9.1.
>
> Philippe already queued this (and another) patch. This fixes AmigaOS on 
> sam460ex which became usable with the tlbwe changes in this cycle but it's 
> not really usable without a file system driver that this patch fixes. 
> Please allow this in 9.0 so users who want to try it don't have to wait a 
> few months more. Sorry for sending it this late but it was reported late 
> and took time to debug it.

No worries, I don't have a problem with the patch so if Philippe
thinks it's okay then I'm fine with that.

Thanks,
Nick
diff mbox series

Patch

diff --git a/hw/pci-host/ppc440_pcix.c b/hw/pci-host/ppc440_pcix.c
index 1926ae2a27..ba38172989 100644
--- a/hw/pci-host/ppc440_pcix.c
+++ b/hw/pci-host/ppc440_pcix.c
@@ -52,7 +52,6 @@  OBJECT_DECLARE_SIMPLE_TYPE(PPC440PCIXState, PPC440_PCIX_HOST)
 struct PPC440PCIXState {
     PCIHostState parent_obj;
 
-    PCIDevice *dev;
     struct PLBOutMap pom[PPC440_PCIX_NR_POMS];
     struct PLBInMap pim[PPC440_PCIX_NR_PIMS];
     uint32_t sts;
@@ -170,10 +169,6 @@  static void ppc440_pcix_reg_write4(void *opaque, hwaddr addr,
 
     trace_ppc440_pcix_reg_write(addr, val, size);
     switch (addr) {
-    case PCI_VENDOR_ID ... PCI_MAX_LAT:
-        stl_le_p(s->dev->config + addr, val);
-        break;
-
     case PCIX0_POM0LAL:
         s->pom[0].la &= 0xffffffff00000000ULL;
         s->pom[0].la |= val;
@@ -301,10 +296,6 @@  static uint64_t ppc440_pcix_reg_read4(void *opaque, hwaddr addr,
     uint32_t val;
 
     switch (addr) {
-    case PCI_VENDOR_ID ... PCI_MAX_LAT:
-        val = ldl_le_p(s->dev->config + addr);
-        break;
-
     case PCIX0_POM0LAL:
         val = s->pom[0].la;
         break;
@@ -498,10 +489,7 @@  static void ppc440_pcix_realize(DeviceState *dev, Error **errp)
     memory_region_init(&s->iomem, OBJECT(dev), "pci-io", 64 * KiB);
     h->bus = pci_register_root_bus(dev, NULL, ppc440_pcix_set_irq,
                          ppc440_pcix_map_irq, &s->irq, &s->busmem, &s->iomem,
-                         PCI_DEVFN(0, 0), 1, TYPE_PCI_BUS);
-
-    s->dev = pci_create_simple(h->bus, PCI_DEVFN(0, 0),
-                               TYPE_PPC4xx_HOST_BRIDGE);
+                         PCI_DEVFN(1, 0), 1, TYPE_PCI_BUS);
 
     memory_region_init(&s->bm, OBJECT(s), "bm-ppc440-pcix", UINT64_MAX);
     memory_region_add_subregion(&s->bm, 0x0, &s->busmem);