stepcompress: Return number of steps traveled from stepcompress_push()
Return the same information from stepcompress_push() that is returned from stepcompress_push_const() and stpcompress_push_delta(). Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
52156d2c41
commit
14810d7e80
|
@ -25,7 +25,7 @@ defs_stepcompress = """
|
||||||
int stepcompress_set_homing(struct stepcompress *sc, uint64_t homing_clock);
|
int stepcompress_set_homing(struct stepcompress *sc, uint64_t homing_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_push(struct stepcompress *sc, double step_clock
|
int32_t stepcompress_push(struct stepcompress *sc, double step_clock
|
||||||
, int32_t sdir);
|
, int32_t sdir);
|
||||||
int32_t stepcompress_push_const(struct stepcompress *sc, double clock_offset
|
int32_t stepcompress_push_const(struct stepcompress *sc, double clock_offset
|
||||||
, double step_offset, double steps, double start_sv, double accel);
|
, double step_offset, double steps, double start_sv, double accel);
|
||||||
|
|
|
@ -108,14 +108,11 @@ class MCU_stepper:
|
||||||
if ret:
|
if ret:
|
||||||
raise error("Internal error in stepcompress")
|
raise error("Internal error in stepcompress")
|
||||||
def step(self, mcu_time, sdir):
|
def step(self, mcu_time, sdir):
|
||||||
clock = mcu_time * self._mcu_freq
|
count = self._ffi_lib.stepcompress_push(
|
||||||
ret = self._ffi_lib.stepcompress_push(self._stepqueue, clock, sdir)
|
self._stepqueue, mcu_time * self._mcu_freq, sdir)
|
||||||
if ret:
|
if count == STEPCOMPRESS_ERROR_RET:
|
||||||
raise error("Internal error in stepcompress")
|
raise error("Internal error in stepcompress")
|
||||||
if sdir:
|
self._commanded_pos += count
|
||||||
self._commanded_pos += 1
|
|
||||||
else:
|
|
||||||
self._commanded_pos -= 1
|
|
||||||
def step_const(self, mcu_time, start_pos, dist, start_v, accel):
|
def step_const(self, mcu_time, start_pos, dist, start_v, accel):
|
||||||
inv_step_dist = self._inv_step_dist
|
inv_step_dist = self._inv_step_dist
|
||||||
step_offset = self._commanded_pos - start_pos * inv_step_dist
|
step_offset = self._commanded_pos - start_pos * inv_step_dist
|
||||||
|
|
|
@ -488,7 +488,7 @@ static inline double safe_sqrt(double v) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Schedule a step event at the specified step_clock time
|
// Schedule a step event at the specified step_clock time
|
||||||
int
|
int32_t
|
||||||
stepcompress_push(struct stepcompress *sc, double step_clock, int32_t sdir)
|
stepcompress_push(struct stepcompress *sc, double step_clock, int32_t sdir)
|
||||||
{
|
{
|
||||||
int ret = set_next_step_dir(sc, !!sdir);
|
int ret = set_next_step_dir(sc, !!sdir);
|
||||||
|
@ -499,7 +499,7 @@ stepcompress_push(struct stepcompress *sc, double step_clock, int32_t sdir)
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
queue_append_finish(qa);
|
queue_append_finish(qa);
|
||||||
return 0;
|
return sdir ? 1 : -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Schedule 'steps' number of steps at constant acceleration. If
|
// Schedule 'steps' number of steps at constant acceleration. If
|
||||||
|
|
Loading…
Reference in New Issue