All of lore.kernel.org
 help / color / mirror / Atom feed
From: "Cédric Le Goater" <clg@kaod.org>
To: "Jamin Lin" <jamin_lin@aspeedtech.com>,
	"Philippe Mathieu-Daudé" <philmd@linaro.org>,
	"Peter Maydell" <peter.maydell@linaro.org>,
	"Steven Lee" <steven_lee@aspeedtech.com>,
	"Troy Lee" <leetroy@gmail.com>,
	"Kane Chen" <kane_chen@aspeedtech.com>,
	"Andrew Jeffery" <andrew@codeconstruct.com.au>,
	"Joel Stanley" <joel@jms.id.au>,
	"open list:ASPEED BMCs" <qemu-arm@nongnu.org>,
	"open list:All patches CC here" <qemu-devel@nongnu.org>
Cc: Troy Lee <troy_lee@aspeedtech.com>,
	"flwu@google.com" <flwu@google.com>,
	"nabihestefan@google.com" <nabihestefan@google.com>
Subject: Re: [PATCH v3 13/17] hw/usb/hcd-ehci: Add descriptor address offset property
Date: Mon, 20 Apr 2026 09:08:45 +0200	[thread overview]
Message-ID: <8ae66243-d55d-4d7b-bcab-dbdcd680aaf7@kaod.org> (raw)
In-Reply-To: <TYPPR06MB8206A19AD70BA0FAD7F68B15FC2F2@TYPPR06MB8206.apcprd06.prod.outlook.com>

On 4/20/26 07:47, Jamin Lin wrote:
> Hi Philippe, Cédric
> 
>>>> -    return ehci_get_buf_addr(s, s->ctrldssegment, low, UINT32_MAX);
>>>> +    uint64_t addr;
>>>> +
>>>> +    addr = ehci_get_buf_addr(s, s->ctrldssegment, low, UINT32_MAX);
>>>> +    addr += s->descriptor_addr_offset;
>>>
>>>
>>> Instead, can we force a default value for ctrldssegment when
>>> caps_64bit_addr is set ?
>>>
>>> I am still trying to digest :
>>>
>>>     https://lore.kernel.org/qemu-devel/
>>>
>> TYPPR06MB8206C7461E004C4FF07B8E92FC242@TYPPR06MB8206.apcprd06.
>> prod.out
>>> look.com/
>>
>> Same here, but since it doesn't break and I don't have much more time to
>> dedicate to this I ended thinking "good enough for now, could be improved
>> later", so no objection on my side.
>>
>>>
>>> We have time let's take a moment to think about the workaround.
>>
>> Then keep me in the loop!
> 
> 
> Thanks for the review and the suggestion.
> 
> I tried to address this by introducing a new property:
> aspeed-ast2700-workaround.

This is not specific to AST2700.

I think a forced default value for CTRLDSSEGMENT would be more
appropriate. Perhaps "ctrldssegment-default", as a uint32_t,
which defaults to 0x0 and when the ast2700 SoC is realized,
set to BIT(2).


> 
> When this property is enabled:
> 
> 1. We force bit 2 of the CTRLDSSEGMENT register to 1 during initialization (when caps_64bit_addr is set).
> 2. Additionally, if firmware writes to the CTRLDSSEGMENT register, we also ensure that bit 2 remains set.
> 
> This keeps the behavior contained to AST2700-specific usage and avoids impacting other platforms.
> Let me know if you think this approach makes sense, or if you'd prefer a different direction.
> 
> Jamin
> 
> diff --git a/hw/usb/hcd-ehci.h b/hw/usb/hcd-ehci.h
> index af8c080c60..0a58dca668 100644
> --- a/hw/usb/hcd-ehci.h
> +++ b/hw/usb/hcd-ehci.h
> @@ -263,6 +263,7 @@ struct EHCIState {
>       /* properties */
>       uint32_t maxframes;
>       bool caps_64bit_addr;
> +    bool aspeed_ast2700_workaround;
> 
>       /*
>        *  EHCI spec version 1.0 Section 2.3
> diff --git a/hw/arm/aspeed_ast27x0.c b/hw/arm/aspeed_ast27x0.c
> index 4a1f7cad73..83114bae90 100644
> --- a/hw/arm/aspeed_ast27x0.c
> +++ b/hw/arm/aspeed_ast27x0.c
> @@ -858,6 +858,9 @@ static void aspeed_soc_ast2700_realize(DeviceState *dev, Error **errp)
>       for (i = 0; i < sc->ehcis_num; i++) {
>           object_property_set_bool(OBJECT(&s->ehci[i]), "caps-64bit-addr", true,
>                                    &error_abort);
> +        object_property_set_bool(OBJECT(&s->ehci[i]),
> +                                 "aspeed-ast2700-workaround", true,
> +                                 &error_abort);
>           if (!sysbus_realize(SYS_BUS_DEVICE(&s->ehci[i]), errp)) {
>               return;
>           }
> diff --git a/hw/usb/hcd-ehci-sysbus.c b/hw/usb/hcd-ehci-sysbus.c
> index 61215e9f3d..01f72a5a1e 100644
> --- a/hw/usb/hcd-ehci-sysbus.c
> +++ b/hw/usb/hcd-ehci-sysbus.c
> @@ -36,6 +36,9 @@ static const Property ehci_sysbus_properties[] = {
>                        false),
>       DEFINE_PROP_BOOL("caps-64bit-addr", EHCISysBusState, ehci.caps_64bit_addr,
>                        false),
> +    DEFINE_PROP_BOOL("aspeed-ast2700-workaround", EHCISysBusState,
> +                     ehci.aspeed_ast2700_workaround,
> +                     false),
>   };
> 
>   static void usb_ehci_sysbus_realize(DeviceState *dev, Error **errp)
> diff --git a/hw/usb/hcd-ehci.c b/hw/usb/hcd-ehci.c
> index 7f90fd119d..403d7e84a7 100644
> --- a/hw/usb/hcd-ehci.c
> +++ b/hw/usb/hcd-ehci.c
> @@ -1133,6 +1133,9 @@ static void ehci_opreg_write(void *ptr, hwaddr addr,
>                             "      64-bit addressing capability is disabled\n");
>               return;
>           }
> +        if (s->aspeed_ast2700_workaround) {
> +            val |= BIT(2);
> +        }

With the proposal above, this would be changed to :

	val |= s->ctrldssegment_default;

>           break;
>       case ASYNCLISTADDR:
>           if (ehci_async_enabled(s)) {
> @@ -2582,6 +2585,9 @@ void usb_ehci_realize(EHCIState *s, DeviceState *dev, Error **errp)
>       }
>       if (s->caps_64bit_addr) {
>           s->caps[0x08] |= BIT(0);
> +        if (s->aspeed_ast2700_workaround) {
> +            s->ctrldssegment |= BIT(2);

Shouldn't these assignments be in the reset handlers ?

Thanks,

C.


> +        }
>       }



  reply	other threads:[~2026-04-20  7:09 UTC|newest]

Thread overview: 69+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2026-04-16  1:49 [PATCH v3 00/17] hw/usb/ehci: Add 64-bit descriptor addressing support Jamin Lin
2026-04-16  1:49 ` [PATCH v3 01/17] hw/usb/hcd-ehci: Remove unused EHCIfstn structure and dead code Jamin Lin
2026-04-16 12:09   ` BALATON Zoltan
2026-04-17  1:16     ` Jamin Lin
2026-04-17  2:25       ` Jamin Lin
2026-04-17  9:47         ` BALATON Zoltan
2026-04-20  3:46           ` Jamin Lin
2026-04-17  6:30   ` Cédric Le Goater
2026-04-16  1:49 ` [PATCH v3 02/17] hw/usb/hcd-ehci.h: Fix coding style issues reported by checkpatch Jamin Lin
2026-04-17  6:32   ` Philippe Mathieu-Daudé
2026-04-16  1:49 ` [PATCH v3 03/17] hw/usb/hcd-ehci.c: " Jamin Lin
2026-04-17  6:31   ` Cédric Le Goater
2026-04-17  6:32   ` Philippe Mathieu-Daudé
2026-04-16  1:49 ` [PATCH v3 04/17] hw/usb/hcd-ehci.c: Replace fprintf(stderr, ...) with qemu_log_mask(LOG_GUEST_ERROR) Jamin Lin
2026-04-17  6:31   ` Philippe Mathieu-Daudé
2026-04-17  8:41     ` Jamin Lin
2026-04-16  1:49 ` [PATCH v3 05/17] hw/usb/hcd-ehci: Replace DPRINTF debug logs with trace events Jamin Lin
2026-04-17  5:04   ` Philippe Mathieu-Daudé
2026-04-16  1:49 ` [PATCH v3 06/17] hw/usb/hcd-ehci: Change descriptor addresses to 64-bit Jamin Lin
2026-04-17  4:54   ` Philippe Mathieu-Daudé
2026-04-17  7:01   ` Cédric Le Goater
2026-04-17 15:10     ` Peter Xu
2026-04-20  5:56       ` Jamin Lin
2026-04-20 13:34         ` Peter Xu
2026-04-22  9:21           ` Jamin Lin
2026-04-22 14:37             ` Peter Xu
2026-04-23  1:48               ` Jamin Lin
2026-04-23 16:03                 ` Peter Xu
2026-04-20 16:04         ` Cédric Le Goater
2026-04-22  9:10           ` Jamin Lin
2026-04-16  1:49 ` [PATCH v3 07/17] hw/usb/hcd-ehci: Add property to advertise 64-bit addressing capability Jamin Lin
2026-04-17  4:55   ` Philippe Mathieu-Daudé
2026-04-16  1:49 ` [PATCH v3 08/17] hw/usb/hcd-ehci: Reject CTRLDSSEGMENT writes without 64-bit capability Jamin Lin
2026-04-17  6:33   ` Philippe Mathieu-Daudé
2026-04-17  8:07     ` Jamin Lin
2026-04-16  1:49 ` [PATCH v3 09/17] hw/usb/hcd-ehci: Implement 64-bit QH descriptor addressing Jamin Lin
2026-04-17  5:03   ` Philippe Mathieu-Daudé
2026-04-17  5:40     ` Jamin Lin
2026-04-17  6:14       ` Philippe Mathieu-Daudé
2026-04-17  7:02         ` Jamin Lin
2026-04-16  1:49 ` [PATCH v3 10/17] hw/usb/hcd-ehci: Implement 64-bit qTD " Jamin Lin
2026-04-17  6:14   ` Philippe Mathieu-Daudé
2026-04-16  1:49 ` [PATCH v3 11/17] hw/usb/hcd-ehci: Implement 64-bit iTD " Jamin Lin
2026-04-17  6:15   ` Philippe Mathieu-Daudé
2026-04-16  1:49 ` [PATCH v3 12/17] hw/usb/hcd-ehci: Implement 64-bit siTD " Jamin Lin
2026-04-17  6:27   ` Philippe Mathieu-Daudé
2026-04-17  7:44     ` Jamin Lin
2026-04-17  8:42       ` Philippe Mathieu-Daudé
2026-04-16  1:49 ` [PATCH v3 13/17] hw/usb/hcd-ehci: Add descriptor address offset property Jamin Lin
2026-04-17  6:23   ` Philippe Mathieu-Daudé
2026-04-22  5:00     ` Jamin Lin
2026-04-17  6:45   ` Cédric Le Goater
2026-04-17  7:08     ` Philippe Mathieu-Daudé
2026-04-20  5:47       ` Jamin Lin
2026-04-20  7:08         ` Cédric Le Goater [this message]
2026-04-22  6:58           ` Jamin Lin
2026-04-16  1:50 ` [PATCH v3 14/17] hw/arm/aspeed_ast27x0: Enable 64-bit EHCI DMA addressing Jamin Lin
2026-04-17  6:23   ` Philippe Mathieu-Daudé
2026-04-16  1:50 ` [PATCH v3 15/17] hw/arm/aspeed_ast27x0: Set EHCI descriptor address offset Jamin Lin
2026-04-17  6:25   ` Philippe Mathieu-Daudé
2026-04-22  5:03     ` Jamin Lin
2026-04-16  1:50 ` [PATCH v3 16/17] tests/functional/arm/test_aspeed_ast2600_sdk: Add USB EHCI test for AST2600 SDK Jamin Lin
2026-04-17  6:27   ` Philippe Mathieu-Daudé
2026-04-17  7:40     ` Jamin Lin
2026-04-17  8:44       ` Philippe Mathieu-Daudé
2026-04-17  8:50         ` Jamin Lin
2026-04-16  1:50 ` [PATCH v3 17/17] tests/functional/aarch64/test_aspeed_ast2700: Add USB EHCI test for AST2700 A1/A2 Jamin Lin
2026-04-17  6:27   ` Philippe Mathieu-Daudé
2026-04-17  6:35 ` [PATCH v3 00/17] hw/usb/ehci: Add 64-bit descriptor addressing support Philippe Mathieu-Daudé

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=8ae66243-d55d-4d7b-bcab-dbdcd680aaf7@kaod.org \
    --to=clg@kaod.org \
    --cc=andrew@codeconstruct.com.au \
    --cc=flwu@google.com \
    --cc=jamin_lin@aspeedtech.com \
    --cc=joel@jms.id.au \
    --cc=kane_chen@aspeedtech.com \
    --cc=leetroy@gmail.com \
    --cc=nabihestefan@google.com \
    --cc=peter.maydell@linaro.org \
    --cc=philmd@linaro.org \
    --cc=qemu-arm@nongnu.org \
    --cc=qemu-devel@nongnu.org \
    --cc=steven_lee@aspeedtech.com \
    --cc=troy_lee@aspeedtech.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.