stepper: Add some comments on s->position tracking
Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
63ba7d231e
commit
e9e0f59204
|
@ -62,6 +62,7 @@ stepper_load_next(struct stepper *s, uint32_t min_next_time)
|
||||||
{
|
{
|
||||||
struct stepper_move *m = s->first;
|
struct stepper_move *m = s->first;
|
||||||
if (!m) {
|
if (!m) {
|
||||||
|
// There is no next move - the queue is empty
|
||||||
if (s->interval - s->add < s->min_stop_interval
|
if (s->interval - s->add < s->min_stop_interval
|
||||||
&& !(s->flags & SF_NO_NEXT_CHECK))
|
&& !(s->flags & SF_NO_NEXT_CHECK))
|
||||||
shutdown("No next step");
|
shutdown("No next step");
|
||||||
|
@ -69,6 +70,7 @@ stepper_load_next(struct stepper *s, uint32_t min_next_time)
|
||||||
return SF_DONE;
|
return SF_DONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Load next 'struct stepper_move' into 'struct stepper'
|
||||||
s->next_step_time += m->interval;
|
s->next_step_time += m->interval;
|
||||||
s->add = m->add;
|
s->add = m->add;
|
||||||
s->interval = m->interval + m->add;
|
s->interval = m->interval + m->add;
|
||||||
|
@ -91,6 +93,7 @@ stepper_load_next(struct stepper *s, uint32_t min_next_time)
|
||||||
}
|
}
|
||||||
s->count = (uint32_t)m->count * 2;
|
s->count = (uint32_t)m->count * 2;
|
||||||
}
|
}
|
||||||
|
// Add all steps to s->position (stepper_get_position() can calc mid-move)
|
||||||
if (m->flags & MF_DIR) {
|
if (m->flags & MF_DIR) {
|
||||||
s->position = -s->position + m->count;
|
s->position = -s->position + m->count;
|
||||||
gpio_out_toggle_noirq(s->dir_pin);
|
gpio_out_toggle_noirq(s->dir_pin);
|
||||||
|
@ -274,10 +277,12 @@ static uint32_t
|
||||||
stepper_get_position(struct stepper *s)
|
stepper_get_position(struct stepper *s)
|
||||||
{
|
{
|
||||||
uint32_t position = s->position;
|
uint32_t position = s->position;
|
||||||
|
// If stepper is mid-move, subtract out steps not yet taken
|
||||||
if (CONFIG_STEP_DELAY <= 0)
|
if (CONFIG_STEP_DELAY <= 0)
|
||||||
position -= s->count;
|
position -= s->count;
|
||||||
else
|
else
|
||||||
position -= s->count / 2;
|
position -= s->count / 2;
|
||||||
|
// The top bit of s->position is an optimized reverse direction flag
|
||||||
if (position & 0x80000000)
|
if (position & 0x80000000)
|
||||||
return -position;
|
return -position;
|
||||||
return position;
|
return position;
|
||||||
|
|
Loading…
Reference in New Issue