[PATCH v2 1/2] um: time-travel: fix IRQ handling in time_travel_handle_message()
Anton Ivanov
anton.ivanov at kot-begemot.co.uk
Wed Sep 16 03:30:33 EDT 2020
On 10/09/2020 10:31, Johannes Berg wrote:
> From: Johannes Berg <johannes.berg at intel.com>
>
> As the comment here indicates, we need to do the polling in the
> idle loop without blocking interrupts, since interrupts can be
> vhost-user messages that we must process even while in our idle
> loop.
>
> I don't know why I explained one thing and implemented another,
> but we have indeed observed random hangs due to this, depending
> on the timing of the messages.
>
> Fixes: 88ce64249233 ("um: Implement time-travel=ext")
> Signed-off-by: Johannes Berg <johannes.berg at intel.com>
> ---
> arch/um/kernel/time.c | 14 +++++++++-----
> 1 file changed, 9 insertions(+), 5 deletions(-)
>
> diff --git a/arch/um/kernel/time.c b/arch/um/kernel/time.c
> index 25eaa6a0c658..c07436e89e59 100644
> --- a/arch/um/kernel/time.c
> +++ b/arch/um/kernel/time.c
> @@ -70,13 +70,17 @@ static void time_travel_handle_message(struct um_timetravel_msg *msg,
> * read of the message and write of the ACK.
> */
> if (mode != TTMH_READ) {
> + bool disabled = irqs_disabled();
> +
> + BUG_ON(mode == TTMH_IDLE && !disabled);
> +
> + if (disabled)
> + local_irq_enable();
> while (os_poll(1, &time_travel_ext_fd) != 0) {
> - if (mode == TTMH_IDLE) {
> - BUG_ON(!irqs_disabled());
> - local_irq_enable();
> - local_irq_disable();
> - }
> + /* nothing */
> }
> + if (disabled)
> + local_irq_disable();
> }
>
> ret = os_read_file(time_travel_ext_fd, msg, sizeof(*msg));
>
Acked-By: Anton Ivanov <anton.ivanov at cambridgegreys.com>
--
Anton R. Ivanov
https://www.kot-begemot.co.uk/
More information about the linux-um
mailing list