129 lines
3.9 KiB
C
129 lines
3.9 KiB
C
|
/*
|
||
|
* Permission to use, copy, modify, and/or distribute this software for any
|
||
|
* purpose with or without fee is hereby granted, provided that the above
|
||
|
* copyright notice and this permission notice appear in all copies.
|
||
|
*
|
||
|
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
||
|
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
||
|
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
||
|
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
||
|
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
||
|
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
||
|
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||
|
*
|
||
|
* Copyright (C) 2019 Intel Corporation
|
||
|
*/
|
||
|
#ifndef _LINUX_UM_TIMETRAVEL_H
|
||
|
#define _LINUX_UM_TIMETRAVEL_H
|
||
|
#include <linux/types.h>
|
||
|
|
||
|
/**
|
||
|
* struct um_timetravel_msg - UM time travel message
|
||
|
*
|
||
|
* This is the basic message type, going in both directions.
|
||
|
*
|
||
|
* This is the message passed between the host (user-mode Linux instance)
|
||
|
* and the calendar (the application on the other side of the socket) in
|
||
|
* order to implement common scheduling.
|
||
|
*
|
||
|
* Whenever UML has an event it will request runtime for it from the
|
||
|
* calendar, and then wait for its turn until it can run, etc. Note
|
||
|
* that it will only ever request the single next runtime, i.e. multiple
|
||
|
* REQUEST messages override each other.
|
||
|
*/
|
||
|
struct um_timetravel_msg {
|
||
|
/**
|
||
|
* @op: operation value from &enum um_timetravel_ops
|
||
|
*/
|
||
|
__u32 op;
|
||
|
|
||
|
/**
|
||
|
* @seq: sequence number for the message - shall be reflected in
|
||
|
* the ACK response, and should be checked while processing
|
||
|
* the response to see if it matches
|
||
|
*/
|
||
|
__u32 seq;
|
||
|
|
||
|
/**
|
||
|
* @time: time in nanoseconds
|
||
|
*/
|
||
|
__u64 time;
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* enum um_timetravel_ops - Operation codes
|
||
|
*/
|
||
|
enum um_timetravel_ops {
|
||
|
/**
|
||
|
* @UM_TIMETRAVEL_ACK: response (ACK) to any previous message,
|
||
|
* this usually doesn't carry any data in the 'time' field
|
||
|
* unless otherwise specified below
|
||
|
*/
|
||
|
UM_TIMETRAVEL_ACK = 0,
|
||
|
|
||
|
/**
|
||
|
* @UM_TIMETRAVEL_START: initialize the connection, the time
|
||
|
* field contains an (arbitrary) ID to possibly be able
|
||
|
* to distinguish the connections.
|
||
|
*/
|
||
|
UM_TIMETRAVEL_START = 1,
|
||
|
|
||
|
/**
|
||
|
* @UM_TIMETRAVEL_REQUEST: request to run at the given time
|
||
|
* (host -> calendar)
|
||
|
*/
|
||
|
UM_TIMETRAVEL_REQUEST = 2,
|
||
|
|
||
|
/**
|
||
|
* @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.
|
||
|
* (host -> calendar)
|
||
|
*/
|
||
|
UM_TIMETRAVEL_WAIT = 3,
|
||
|
|
||
|
/**
|
||
|
* @UM_TIMETRAVEL_GET: return the current time from the calendar in the
|
||
|
* ACK message, the time in the request message is ignored
|
||
|
* (host -> calendar)
|
||
|
*/
|
||
|
UM_TIMETRAVEL_GET = 4,
|
||
|
|
||
|
/**
|
||
|
* @UM_TIMETRAVEL_UPDATE: time update to the calendar, must be sent e.g.
|
||
|
* before kicking an interrupt to another calendar
|
||
|
* (host -> calendar)
|
||
|
*/
|
||
|
UM_TIMETRAVEL_UPDATE = 5,
|
||
|
|
||
|
/**
|
||
|
* @UM_TIMETRAVEL_RUN: run time request granted, current time is in
|
||
|
* the time field
|
||
|
* (calendar -> host)
|
||
|
*/
|
||
|
UM_TIMETRAVEL_RUN = 6,
|
||
|
|
||
|
/**
|
||
|
* @UM_TIMETRAVEL_FREE_UNTIL: Enable free-running until the given time,
|
||
|
* this is a message from the calendar telling the host that it can
|
||
|
* freely do its own scheduling for anything before the indicated
|
||
|
* time.
|
||
|
* Note that if a calendar sends this message once, the host may
|
||
|
* assume that it will also do so in the future, if it implements
|
||
|
* wraparound semantics for the time field.
|
||
|
* (calendar -> host)
|
||
|
*/
|
||
|
UM_TIMETRAVEL_FREE_UNTIL = 7,
|
||
|
|
||
|
/**
|
||
|
* @UM_TIMETRAVEL_GET_TOD: Return time of day, typically used once at
|
||
|
* boot by the virtual machines to get a synchronized time from
|
||
|
* the simulation.
|
||
|
*/
|
||
|
UM_TIMETRAVEL_GET_TOD = 8,
|
||
|
};
|
||
|
|
||
|
#endif /* _LINUX_UM_TIMETRAVEL_H */
|