Expose the clock period via the QOM 'qtest-clock-period' property so it
can be used in QTests. This property is only accessible in QTests (not
via HMP).
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Inès Varhol <ines.varhol@telecom-paris.fr>
---
docs/devel/clocks.rst | 3 +++
hw/core/clock.c | 16 ++++++++++++++++
2 files changed, 19 insertions(+)
diff --git a/docs/devel/clocks.rst b/docs/devel/clocks.rst
index 177ee1c90d..19e67601ec 100644
--- a/docs/devel/clocks.rst
+++ b/docs/devel/clocks.rst
@@ -358,6 +358,9 @@ humans (for instance in debugging), use ``clock_display_freq()``,
which returns a prettified string-representation, e.g. "33.3 MHz".
The caller must free the string with g_free() after use.
+It's also possible to retrieve the clock period from a QTest by
+accessing QOM property ``qtest-clock-period`` using a QMP command.
+
Calculating expiry deadlines
----------------------------
diff --git a/hw/core/clock.c b/hw/core/clock.c
index e212865307..216b54b8df 100644
--- a/hw/core/clock.c
+++ b/hw/core/clock.c
@@ -13,6 +13,8 @@
#include "qemu/osdep.h"
#include "qemu/cutils.h"
+#include "qapi/visitor.h"
+#include "sysemu/qtest.h"
#include "hw/clock.h"
#include "trace.h"
@@ -158,6 +160,15 @@ bool clock_set_mul_div(Clock *clk, uint32_t multiplier, uint32_t divider)
return true;
}
+static void clock_period_prop_get(Object *obj, Visitor *v, const char *name,
+ void *opaque, Error **errp)
+{
+ Clock *clk = CLOCK(obj);
+ uint64_t freq_hz = clock_get(clk);
+ visit_type_uint64(v, name, &freq_hz, errp);
+}
+
+
static void clock_initfn(Object *obj)
{
Clock *clk = CLOCK(obj);
@@ -166,6 +177,11 @@ static void clock_initfn(Object *obj)
clk->divider = 1;
QLIST_INIT(&clk->children);
+
+ if (qtest_enabled()) {
+ object_property_add(obj, "qtest-clock-period", "uint64",
+ clock_period_prop_get, NULL, NULL, NULL);
+ }
}
static void clock_finalizefn(Object *obj)
--
2.43.2
On 23/5/24 21:41, Inès Varhol wrote: > Expose the clock period via the QOM 'qtest-clock-period' property so it > can be used in QTests. This property is only accessible in QTests (not > via HMP). > > Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org> Addressing Luc and Peter comments, you can replace that line by: Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org> Thanks! > Signed-off-by: Inès Varhol <ines.varhol@telecom-paris.fr> > --- > docs/devel/clocks.rst | 3 +++ > hw/core/clock.c | 16 ++++++++++++++++ > 2 files changed, 19 insertions(+)
On Thu, 23 May 2024 at 20:44, Inès Varhol <ines.varhol@telecom-paris.fr> wrote: > > Expose the clock period via the QOM 'qtest-clock-period' property so it > can be used in QTests. This property is only accessible in QTests (not > via HMP). > > Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org> > Signed-off-by: Inès Varhol <ines.varhol@telecom-paris.fr> > --- > docs/devel/clocks.rst | 3 +++ > hw/core/clock.c | 16 ++++++++++++++++ > 2 files changed, 19 insertions(+) > > diff --git a/docs/devel/clocks.rst b/docs/devel/clocks.rst > index 177ee1c90d..19e67601ec 100644 > --- a/docs/devel/clocks.rst > +++ b/docs/devel/clocks.rst > @@ -358,6 +358,9 @@ humans (for instance in debugging), use ``clock_display_freq()``, > which returns a prettified string-representation, e.g. "33.3 MHz". > The caller must free the string with g_free() after use. > > +It's also possible to retrieve the clock period from a QTest by > +accessing QOM property ``qtest-clock-period`` using a QMP command. We should add: This property is only present when the device is being run under the ``qtest`` accelerator; it is not available when QEMU is being run normally. thanks -- PMM
On 21:41 Thu 23 May , Inès Varhol wrote:
> Expose the clock period via the QOM 'qtest-clock-period' property so it
> can be used in QTests. This property is only accessible in QTests (not
> via HMP).
>
> Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org>
> Signed-off-by: Inès Varhol <ines.varhol@telecom-paris.fr>
> ---
> docs/devel/clocks.rst | 3 +++
> hw/core/clock.c | 16 ++++++++++++++++
> 2 files changed, 19 insertions(+)
>
> diff --git a/docs/devel/clocks.rst b/docs/devel/clocks.rst
> index 177ee1c90d..19e67601ec 100644
> --- a/docs/devel/clocks.rst
> +++ b/docs/devel/clocks.rst
> @@ -358,6 +358,9 @@ humans (for instance in debugging), use ``clock_display_freq()``,
> which returns a prettified string-representation, e.g. "33.3 MHz".
> The caller must free the string with g_free() after use.
>
> +It's also possible to retrieve the clock period from a QTest by
> +accessing QOM property ``qtest-clock-period`` using a QMP command.
> +
> Calculating expiry deadlines
> ----------------------------
>
> diff --git a/hw/core/clock.c b/hw/core/clock.c
> index e212865307..216b54b8df 100644
> --- a/hw/core/clock.c
> +++ b/hw/core/clock.c
> @@ -13,6 +13,8 @@
>
> #include "qemu/osdep.h"
> #include "qemu/cutils.h"
> +#include "qapi/visitor.h"
> +#include "sysemu/qtest.h"
> #include "hw/clock.h"
> #include "trace.h"
>
> @@ -158,6 +160,15 @@ bool clock_set_mul_div(Clock *clk, uint32_t multiplier, uint32_t divider)
> return true;
> }
>
> +static void clock_period_prop_get(Object *obj, Visitor *v, const char *name,
> + void *opaque, Error **errp)
> +{
> + Clock *clk = CLOCK(obj);
> + uint64_t freq_hz = clock_get(clk);
> + visit_type_uint64(v, name, &freq_hz, errp);
s/freq_hz/period
Otherwise:
Reviewed-by: Luc Michel <luc@lmichel.fr>
> +}
> +
> +
> static void clock_initfn(Object *obj)
> {
> Clock *clk = CLOCK(obj);
> @@ -166,6 +177,11 @@ static void clock_initfn(Object *obj)
> clk->divider = 1;
>
> QLIST_INIT(&clk->children);
> +
> + if (qtest_enabled()) {
> + object_property_add(obj, "qtest-clock-period", "uint64",
> + clock_period_prop_get, NULL, NULL, NULL);
> + }
> }
>
> static void clock_finalizefn(Object *obj)
> --
> 2.43.2
>
--
© 2016 - 2026 Red Hat, Inc.