From: Paolo Bonzini <pbonzini@redhat.com>
To: Alex Bligh <alex@alex.org.uk>
Cc: Kevin Wolf <kwolf@redhat.com>,
Anthony Liguori <aliguori@us.ibm.com>,
liu ping fan <qemulist@gmail.com>,
qemu-devel@nongnu.org, Stefan Hajnoczi <stefanha@redhat.com>,
MORITA Kazutaka <morita.kazutaka@lab.ntt.co.jp>,
rth@twiddle.net
Subject: Re: [Qemu-devel] [RFC] [PATCHv8 09/30] aio / timers: Add QEMUTimerListGroup and helper functions
Date: Fri, 09 Aug 2013 12:02:57 +0200 [thread overview]
Message-ID: <5204BE51.70006@redhat.com> (raw)
In-Reply-To: <1375998147-24292-10-git-send-email-alex@alex.org.uk>
Il 08/08/2013 23:42, Alex Bligh ha scritto:
> Add QEMUTimerListGroup and helper functions, to represent
> a QEMUTimerList associated with each clock. Add a default
> QEMUTimerListGroup representing the default timer lists
> which are not associated with any other object (e.g.
> an AioContext as added by future patches).
>
> Signed-off-by: Alex Bligh <alex@alex.org.uk>
> ---
> include/qemu/timer.h | 45 +++++++++++++++++++++++++++++++++++++++++++++
> qemu-timer.c | 41 +++++++++++++++++++++++++++++++++++++++++
> 2 files changed, 86 insertions(+)
>
> diff --git a/include/qemu/timer.h b/include/qemu/timer.h
> index 1baa0e2..3b46f60 100644
> --- a/include/qemu/timer.h
> +++ b/include/qemu/timer.h
> @@ -52,8 +52,10 @@ typedef enum {
>
> typedef struct QEMUClock QEMUClock;
> typedef struct QEMUTimerList QEMUTimerList;
> +typedef QEMUTimerList *QEMUTimerListGroup[QEMU_CLOCK_MAX];
Please wrap this in a struct for easier future extensibility.
I'm not a big fan of the TimerListGroup name, but I cannot think of
anything better...
... except if we get rid of TimerListGroup completely and put it in
AioContext. To do so, we can have _two_ AioContexts in main-loop.c.
One is for the block layer, the other is only used for timers. Later we
could move bottom halves from the first to the second, too.
Sorry for not thinking of this before.
Paolo
> typedef void QEMUTimerCB(void *opaque);
>
> +extern QEMUTimerListGroup main_loop_tlg;
> extern QEMUClock *qemu_clocks[QEMU_CLOCK_MAX];
>
> /**
> @@ -211,6 +213,49 @@ QEMUClock *timerlist_get_clock(QEMUTimerList *timer_list);
> bool timerlist_run_timers(QEMUTimerList *timer_list);
>
> /**
> + * timerlistgroup_init:
> + * @tlg: the timer list group
> + *
> + * Initialise a timer list group. This must already be
> + * allocated in memory and zeroed.
> + */
> +void timerlistgroup_init(QEMUTimerListGroup tlg);
> +
> +/**
> + * timerlistgroup_deinit:
> + * @tlg: the timer list group
> + *
> + * Deinitialise a timer list group. This must already be
> + * initialised. Note the memory is not freed.
> + */
> +void timerlistgroup_deinit(QEMUTimerListGroup tlg);
> +
> +/**
> + * timerlistgroup_run_timers:
> + * @tlg: the timer list group
> + *
> + * Run the timers associated with a timer list group.
> + * This will run timers on multiple clocks.
> + *
> + * Returns: true if any timer callback ran
> + */
> +bool timerlistgroup_run_timers(QEMUTimerListGroup tlg);
> +
> +/**
> + * timerlistgroup_deadline_ns
> + * @tlg: the timer list group
> + *
> + * Determine the deadline of the soonest timer to
> + * expire associated with any timer list linked to
> + * the timer list group. Only clocks suitable for
> + * deadline calculation are included.
> + *
> + * Returns: the deadline in nanoseconds or -1 if no
> + * timers are to expire.
> + */
> +int64_t timerlistgroup_deadline_ns(QEMUTimerListGroup tlg);
> +
> +/**
> * qemu_timeout_ns_to_ms:
> * @ns: nanosecond timeout value
> *
> diff --git a/qemu-timer.c b/qemu-timer.c
> index 1a0a4b1..e151d24 100644
> --- a/qemu-timer.c
> +++ b/qemu-timer.c
> @@ -59,6 +59,7 @@ struct QEMUClock {
> bool enabled;
> };
>
> +QEMUTimerListGroup main_loop_tlg;
> QEMUClock *qemu_clocks[QEMU_CLOCK_MAX];
>
> /* A QEMUTimerList is a list of timers attached to a clock. More
> @@ -575,6 +576,45 @@ bool qemu_run_timers(QEMUClock *clock)
> return timerlist_run_timers(clock->main_loop_timerlist);
> }
>
> +void timerlistgroup_init(QEMUTimerListGroup tlg)
> +{
> + QEMUClockType type;
> + for (type = 0; type < QEMU_CLOCK_MAX; type++) {
> + tlg[type] = timerlist_new(type);
> + }
> +}
> +
> +void timerlistgroup_deinit(QEMUTimerListGroup tlg)
> +{
> + QEMUClockType type;
> + for (type = 0; type < QEMU_CLOCK_MAX; type++) {
> + timerlist_free(tlg[type]);
> + }
> +}
> +
> +bool timerlistgroup_run_timers(QEMUTimerListGroup tlg)
> +{
> + QEMUClockType type;
> + bool progress = false;
> + for (type = 0; type < QEMU_CLOCK_MAX; type++) {
> + progress |= timerlist_run_timers(tlg[type]);
> + }
> + return progress;
> +}
> +
> +int64_t timerlistgroup_deadline_ns(QEMUTimerListGroup tlg)
> +{
> + int64_t deadline = -1;
> + QEMUClockType type;
> + for (type = 0; type < QEMU_CLOCK_MAX; type++) {
> + if (qemu_clock_use_for_deadline(tlg[type]->clock)) {
> + deadline = qemu_soonest_timeout(deadline,
> + timerlist_deadline_ns(tlg[type]));
> + }
> + }
> + return deadline;
> +}
> +
> int64_t qemu_get_clock_ns(QEMUClock *clock)
> {
> int64_t now, last;
> @@ -616,6 +656,7 @@ void init_clocks(void)
> for (type = 0; type < QEMU_CLOCK_MAX; type++) {
> if (!qemu_clocks[type]) {
> qemu_clocks[type] = qemu_clock_new(type);
> + main_loop_tlg[type] = qemu_clocks[type]->main_loop_timerlist;
> }
> }
>
>
next prev parent reply other threads:[~2013-08-09 10:03 UTC|newest]
Thread overview: 91+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-08-08 21:41 [Qemu-devel] [RFC] [PATCHv8 00/30] aio / timers: Add AioContext timers and use ppoll Alex Bligh
2013-08-08 21:41 ` [Qemu-devel] [RFC] [PATCHv8 01/30] aio / timers: Rename qemu_new_clock and expose clock types Alex Bligh
2013-08-08 21:41 ` [Qemu-devel] [RFC] [PATCHv8 02/30] aio / timers: add qemu-timer.c utility functions Alex Bligh
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 03/30] aio / timers: Consistent treatment of disabled clocks for deadlines Alex Bligh
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 04/30] aio / timers: add ppoll support with qemu_poll_ns Alex Bligh
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 05/30] aio / timers: Add prctl(PR_SET_TIMERSLACK, 1, ...) to reduce timer slack Alex Bligh
2013-08-09 8:53 ` Stefan Hajnoczi
2013-08-09 14:10 ` Alex Bligh
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 06/30] aio / timers: Make qemu_run_timers and qemu_run_all_timers return progress Alex Bligh
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 07/30] aio / timers: Split QEMUClock into QEMUClock and QEMUTimerList Alex Bligh
2013-08-09 10:03 ` Paolo Bonzini
2013-08-09 14:23 ` Alex Bligh
2013-08-09 14:28 ` Paolo Bonzini
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 08/30] aio / timers: Untangle include files Alex Bligh
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 09/30] aio / timers: Add QEMUTimerListGroup and helper functions Alex Bligh
2013-08-09 10:02 ` Paolo Bonzini [this message]
2013-08-09 14:27 ` Alex Bligh
2013-08-09 14:35 ` Paolo Bonzini
2013-08-09 14:47 ` Alex Bligh
2013-08-09 14:59 ` Paolo Bonzini
2013-08-10 11:05 ` Alex Bligh
2013-08-11 7:53 ` Paolo Bonzini
2013-08-11 8:29 ` Alex Bligh
2013-08-12 17:27 ` Paolo Bonzini
2013-08-12 17:32 ` Alex Bligh
2013-08-12 6:53 ` Wenchao Xia
2013-08-12 7:08 ` Alex Bligh
2013-08-09 15:09 ` Stefan Hajnoczi
2013-08-09 15:15 ` Paolo Bonzini
2013-08-10 3:27 ` liu ping fan
2013-08-10 8:38 ` Paolo Bonzini
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 10/30] aio / timers: Add QEMUTimerListGroup to AioContext Alex Bligh
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 11/30] aio / timers: Add a notify callback to QEMUTimerList Alex Bligh
2013-08-09 9:02 ` Stefan Hajnoczi
2013-08-09 14:16 ` Alex Bligh
2013-08-09 10:03 ` Paolo Bonzini
2013-08-09 14:28 ` Alex Bligh
2013-08-10 11:13 ` Alex Bligh
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 12/30] aio / timers: aio_ctx_prepare sets timeout from AioContext timers Alex Bligh
2013-08-09 10:04 ` Paolo Bonzini
2013-08-09 14:30 ` Alex Bligh
2013-08-09 14:41 ` Paolo Bonzini
2013-08-09 14:55 ` Alex Bligh
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 13/30] aio / timers: Add aio_timer_new wrapper Alex Bligh
2013-08-09 10:06 ` Paolo Bonzini
2013-08-09 14:32 ` Alex Bligh
2013-08-09 14:36 ` Paolo Bonzini
2013-08-09 14:51 ` Alex Bligh
2013-08-09 14:51 ` Paolo Bonzini
2013-08-09 14:57 ` Alex Bligh
2013-08-09 14:58 ` Paolo Bonzini
2013-08-09 22:57 ` Alex Bligh
2013-08-10 8:36 ` Paolo Bonzini
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 14/30] aio / timers: Convert aio_poll to use AioContext timers' deadline Alex Bligh
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 15/30] aio / timers: Convert mainloop to use timeout Alex Bligh
2013-08-09 10:07 ` Paolo Bonzini
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 16/30] aio / timers: On timer modification, qemu_notify or aio_notify Alex Bligh
2013-08-09 10:08 ` Paolo Bonzini
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 17/30] aio / timers: Introduce new API qemu_timer_new and friends Alex Bligh
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 18/30] aio / timers: Use all timerlists in icount warp calculations Alex Bligh
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 19/30] aio / timers: Add documentation and new format calls Alex Bligh
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 20/30] aio / timers: Remove alarm timers Alex Bligh
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 21/30] aio / timers: Remove legacy qemu_clock_deadline & qemu_timerlist_deadline Alex Bligh
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 22/30] aio / timers: Add qemu_clock_get_ms and qemu_clock_get_ms Alex Bligh
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 23/30] aio / timers: Rearrange timer.h & make legacy functions call non-legacy Alex Bligh
2013-08-08 22:12 ` Alex Bligh
2013-08-09 9:23 ` Stefan Hajnoczi
2013-08-09 14:18 ` Alex Bligh
2013-08-09 14:26 ` Paolo Bonzini
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 24/30] aio / timers: Remove main_loop_timerlist Alex Bligh
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 25/30] aio / timers: Convert rtc_clock to be a QEMUClockType Alex Bligh
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 26/30] aio / timers: convert block_job_sleep_ns and co_sleep_ns to new API Alex Bligh
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 27/30] aio / timers: Add test harness for AioContext timers Alex Bligh
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 28/30] aio / timers: Add scripts/switch-timer-api Alex Bligh
2013-08-09 10:23 ` Paolo Bonzini
2013-08-09 14:34 ` Alex Bligh
2013-08-09 10:26 ` Paolo Bonzini
2013-08-09 14:35 ` Alex Bligh
2013-08-09 14:37 ` Paolo Bonzini
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 29/30] aio / timers: Switch entire codebase to the new timer API Alex Bligh
2013-08-08 21:42 ` [Qemu-devel] [RFC] [PATCHv8 30/30] aio / timers: Remove legacy interface Alex Bligh
2013-08-08 21:46 ` [Qemu-devel] [RFC] [PATCHv8 00/30] aio / timers: Add AioContext timers and use ppoll Alex Bligh
2013-08-09 8:12 ` Jan Kiszka
2013-08-09 8:24 ` liu ping fan
2013-08-09 8:33 ` Jan Kiszka
2013-08-09 10:35 ` Alex Bligh
2013-08-09 9:41 ` Stefan Hajnoczi
2013-08-09 14:19 ` Alex Bligh
2013-08-09 14:27 ` Paolo Bonzini
2013-08-09 10:27 ` Paolo Bonzini
2013-08-09 11:18 ` Stefan Hajnoczi
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=5204BE51.70006@redhat.com \
--to=pbonzini@redhat.com \
--cc=alex@alex.org.uk \
--cc=aliguori@us.ibm.com \
--cc=kwolf@redhat.com \
--cc=morita.kazutaka@lab.ntt.co.jp \
--cc=qemu-devel@nongnu.org \
--cc=qemulist@gmail.com \
--cc=rth@twiddle.net \
--cc=stefanha@redhat.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).