aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKevin O'Connor <kevin@koconnor.net>2016-07-13 14:47:03 -0400
committerKevin O'Connor <kevin@koconnor.net>2016-07-16 21:33:15 -0400
commit3fa7da804d1d558fa0a39262a5d13f859b6357fa (patch)
tree0c40f1eab217d800edb3409ffa76ef4e315d229b
parentaf99ab164543bc5e1ee68ef35b1b6f42f06ca887 (diff)
downloadkutter-3fa7da804d1d558fa0a39262a5d13f859b6357fa.tar.gz
kutter-3fa7da804d1d558fa0a39262a5d13f859b6357fa.tar.xz
kutter-3fa7da804d1d558fa0a39262a5d13f859b6357fa.zip
stepcompress: Check for invalid count in step_factor and step_sqrt
Check for an invalid count and report an error if found. This prevents some segfaults when count goes negative. Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
-rw-r--r--klippy/stepcompress.c15
1 files changed, 13 insertions, 2 deletions
diff --git a/klippy/stepcompress.c b/klippy/stepcompress.c
index 569522a6..34b2a7d0 100644
--- a/klippy/stepcompress.c
+++ b/klippy/stepcompress.c
@@ -280,6 +280,11 @@ stepcompress_push_factor(struct stepcompress *sc
double ceil_steps = ceil(steps - step_offset);
double next_step_offset = ceil_steps - (steps - step_offset);
int count = ceil_steps;
+ if (count < 0 || count > 1000000) {
+ fprintf(stderr, "ERROR: push_factor invalid count %d %f %f %f %f\n"
+ , sc->oid, steps, step_offset, clock_offset, factor);
+ return next_step_offset;
+ }
check_expand(sc, count);
// Calculate each step time
@@ -304,6 +309,12 @@ stepcompress_push_sqrt(struct stepcompress *sc, double steps, double step_offset
double ceil_steps = ceil(steps - step_offset);
double next_step_offset = ceil_steps - (steps - step_offset);
int count = ceil_steps;
+ if (count < 0 || count > 1000000) {
+ fprintf(stderr, "ERROR: push_sqrt invalid count %d %f %f %f %f %f\n"
+ , sc->oid, steps, step_offset, clock_offset, sqrt_offset
+ , factor);
+ return next_step_offset;
+ }
check_expand(sc, count);
// Calculate each step time
@@ -320,7 +331,7 @@ stepcompress_push_sqrt(struct stepcompress *sc, double steps, double step_offset
*qn++ = clock_offset - sqrt(pos*factor);
pos += 1.0;
}
- sc->queue_next = end;
+ sc->queue_next = qn;
return next_step_offset;
}
@@ -405,7 +416,7 @@ struct steppersync {
int num_move_clocks;
};
-// Allocate a new 'stepperysync' object
+// Allocate a new 'steppersync' object
struct steppersync *
steppersync_alloc(struct serialqueue *sq, struct stepcompress **sc_list
, int sc_num, int move_num)