* [PATCH 0/2] um: time-travel=ext fixes
@ 2020-09-10 9:29 Johannes Berg
2020-09-10 9:29 ` [PATCH 1/2] um: time-travel: fix IRQ handling in time_travel_handle_message() Johannes Berg
2020-09-10 9:29 ` [PATCH 2/2] um: time-travel: return the sequence number in ACK messages Johannes Berg
0 siblings, 2 replies; 3+ messages in thread
From: Johannes Berg @ 2020-09-10 9:29 UTC (permalink / raw)
To: linux-um
Hi,
I had been noticing some hangs in my simulations, and finally had
enough time (and a machine that they reproduce on easily - it's a
timing thing) to debug, so two small fixes for this.
johannes
_______________________________________________
linux-um mailing list
linux-um@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-um
^ permalink raw reply [flat|nested] 3+ messages in thread
* [PATCH 1/2] um: time-travel: fix IRQ handling in time_travel_handle_message()
2020-09-10 9:29 [PATCH 0/2] um: time-travel=ext fixes Johannes Berg
@ 2020-09-10 9:29 ` Johannes Berg
2020-09-10 9:29 ` [PATCH 2/2] um: time-travel: return the sequence number in ACK messages Johannes Berg
1 sibling, 0 replies; 3+ messages in thread
From: Johannes Berg @ 2020-09-10 9:29 UTC (permalink / raw)
To: linux-um; +Cc: Johannes Berg
From: Johannes Berg <johannes.berg@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")
Change-Id: Ic74385f3d36466cc01cc8487fc54affe0fdf7f26
Signed-off-by: Johannes Berg <johannes.berg@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));
--
2.26.2
_______________________________________________
linux-um mailing list
linux-um@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-um
^ permalink raw reply related [flat|nested] 3+ messages in thread
* [PATCH 2/2] um: time-travel: return the sequence number in ACK messages
2020-09-10 9:29 [PATCH 0/2] um: time-travel=ext fixes Johannes Berg
2020-09-10 9:29 ` [PATCH 1/2] um: time-travel: fix IRQ handling in time_travel_handle_message() Johannes Berg
@ 2020-09-10 9:29 ` Johannes Berg
1 sibling, 0 replies; 3+ messages in thread
From: Johannes Berg @ 2020-09-10 9:29 UTC (permalink / raw)
To: linux-um; +Cc: Johannes Berg
From: Johannes Berg <johannes.berg@intel.com>
For external time travel, the protocol says to return the
incoming sequence number in the ACK message to aid debugging,
so do that.
Change-Id: Ib2bcca1371247b2f8643f35fb85ca5051addd8cc
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
---
arch/um/kernel/time.c | 1 +
1 file changed, 1 insertion(+)
diff --git a/arch/um/kernel/time.c b/arch/um/kernel/time.c
index c07436e89e59..3d109ff3309b 100644
--- a/arch/um/kernel/time.c
+++ b/arch/um/kernel/time.c
@@ -106,6 +106,7 @@ static void time_travel_handle_message(struct um_timetravel_msg *msg,
break;
}
+ resp.seq = msg->seq;
os_write_file(time_travel_ext_fd, &resp, sizeof(resp));
}
--
2.26.2
_______________________________________________
linux-um mailing list
linux-um@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-um
^ permalink raw reply related [flat|nested] 3+ messages in thread
end of thread, other threads:[~2020-09-10 9:29 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2020-09-10 9:29 [PATCH 0/2] um: time-travel=ext fixes Johannes Berg
2020-09-10 9:29 ` [PATCH 1/2] um: time-travel: fix IRQ handling in time_travel_handle_message() Johannes Berg
2020-09-10 9:29 ` [PATCH 2/2] um: time-travel: return the sequence number in ACK messages Johannes Berg
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).