stepcompress: Add support for queuing messages that consume move queue space
Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
4688c21c54
commit
48a05eaa54
|
@ -49,6 +49,8 @@ defs_stepcompress = """
|
||||||
, uint64_t clock);
|
, uint64_t clock);
|
||||||
int stepcompress_queue_msg(struct stepcompress *sc
|
int stepcompress_queue_msg(struct stepcompress *sc
|
||||||
, uint32_t *data, int len);
|
, uint32_t *data, int len);
|
||||||
|
int stepcompress_queue_mq_msg(struct stepcompress *sc, uint64_t req_clock
|
||||||
|
, uint32_t *data, int len);
|
||||||
int stepcompress_extract_old(struct stepcompress *sc
|
int stepcompress_extract_old(struct stepcompress *sc
|
||||||
, struct pull_history_steps *p, int max
|
, struct pull_history_steps *p, int max
|
||||||
, uint64_t start_clock, uint64_t end_clock);
|
, uint64_t start_clock, uint64_t end_clock);
|
||||||
|
|
|
@ -623,6 +623,21 @@ stepcompress_queue_msg(struct stepcompress *sc, uint32_t *data, int len)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Queue an mcu command that will consume space in the mcu move queue
|
||||||
|
int __visible
|
||||||
|
stepcompress_queue_mq_msg(struct stepcompress *sc, uint64_t req_clock
|
||||||
|
, uint32_t *data, int len)
|
||||||
|
{
|
||||||
|
int ret = stepcompress_flush(sc, UINT64_MAX);
|
||||||
|
if (ret)
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
struct queue_message *qm = message_alloc_and_encode(data, len);
|
||||||
|
qm->min_clock = qm->req_clock = req_clock;
|
||||||
|
list_add_tail(&qm->node, &sc->msg_queue);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
// Return history of queue_step commands
|
// Return history of queue_step commands
|
||||||
int __visible
|
int __visible
|
||||||
stepcompress_extract_old(struct stepcompress *sc, struct pull_history_steps *p
|
stepcompress_extract_old(struct stepcompress *sc, struct pull_history_steps *p
|
||||||
|
|
|
@ -29,6 +29,8 @@ int stepcompress_set_last_position(struct stepcompress *sc, uint64_t clock
|
||||||
int64_t stepcompress_find_past_position(struct stepcompress *sc
|
int64_t stepcompress_find_past_position(struct stepcompress *sc
|
||||||
, uint64_t clock);
|
, uint64_t clock);
|
||||||
int stepcompress_queue_msg(struct stepcompress *sc, uint32_t *data, int len);
|
int stepcompress_queue_msg(struct stepcompress *sc, uint32_t *data, int len);
|
||||||
|
int stepcompress_queue_mq_msg(struct stepcompress *sc, uint64_t req_clock
|
||||||
|
, uint32_t *data, int len);
|
||||||
int stepcompress_extract_old(struct stepcompress *sc
|
int stepcompress_extract_old(struct stepcompress *sc
|
||||||
, struct pull_history_steps *p, int max
|
, struct pull_history_steps *p, int max
|
||||||
, uint64_t start_clock, uint64_t end_clock);
|
, uint64_t start_clock, uint64_t end_clock);
|
||||||
|
|
Loading…
Reference in New Issue