[PATCH RFC 05/11] um: Add final request time to TT wait message

Benjamin Beichler benjamin.beichler at uni-rostock.de
Fri Nov 3 09:41:43 PDT 2023


Although the information for the next requested time was already sent in
a prior message, this change introduces the otherwise unused time
variable in the TT message. This addition enables an extra consistency
check and can otherwise be ignored.

Signed-off-by: Benjamin Beichler <benjamin.beichler at uni-rostock.de>
---
 arch/um/kernel/time.c              | 6 +++---
 include/uapi/linux/um_timetravel.h | 6 +++---
 2 files changed, 6 insertions(+), 6 deletions(-)

diff --git a/arch/um/kernel/time.c b/arch/um/kernel/time.c
index ff5ef75bbb94..abd5fd0f62ee 100644
--- a/arch/um/kernel/time.c
+++ b/arch/um/kernel/time.c
@@ -220,7 +220,7 @@ static bool time_travel_ext_request(unsigned long long time)
 	return true;
 }
 
-static void time_travel_ext_wait(bool idle)
+static void time_travel_ext_wait(bool idle, unsigned long long ns)
 {
 	struct um_timetravel_msg msg = {
 		.op = UM_TIMETRAVEL_ACK,
@@ -230,7 +230,7 @@ static void time_travel_ext_wait(bool idle)
 	time_travel_ext_free_until_valid = false;
 	time_travel_ext_waiting++;
 
-	time_travel_ext_req(UM_TIMETRAVEL_WAIT, -1);
+	time_travel_ext_req(UM_TIMETRAVEL_WAIT, ns);
 
 	/*
 	 * Here we are deep in the idle loop, so we have to break out of the
@@ -256,7 +256,7 @@ static void time_travel_ext_get_time(void)
 static void __time_travel_update_time(unsigned long long ns, bool idle)
 {
 	if (time_travel_mode == TT_MODE_EXTERNAL && time_travel_ext_request(ns))
-		time_travel_ext_wait(idle);
+		time_travel_ext_wait(idle, ns);
 	else
 		time_travel_set_time(ns);
 }
diff --git a/include/uapi/linux/um_timetravel.h b/include/uapi/linux/um_timetravel.h
index ca3238222b6d..3127f069d9dc 100644
--- a/include/uapi/linux/um_timetravel.h
+++ b/include/uapi/linux/um_timetravel.h
@@ -77,9 +77,9 @@ enum um_timetravel_ops {
 	/**
 	 * @UM_TIMETRAVEL_WAIT: Indicate waiting for the previously requested
 	 *	runtime, new requests may be made while waiting (e.g. due to
-	 *	interrupts); the time field is ignored. The calendar must process
-	 *	this message and later	send a %UM_TIMETRAVEL_RUN message when
-	 *	the host can run again.
+	 *	interrupts); the time field contains the next requested runtime
+	 *  for consistency checks. The calendar must process this message and
+	 *  later send a %UM_TIMETRAVEL_RUN message when the host can run again.
 	 *	(host -> calendar)
 	 */
 	UM_TIMETRAVEL_WAIT		= 3,

-- 
2.34.1





More information about the linux-um mailing list