Fork of Smoothie to port to mbed non-LPC targets.

Dependencies:   mbed

Fork of Smoothie by Stéphane Cachat

Revision:
2:1df0b61d3b5a
diff -r ab59fc9af055 -r 1df0b61d3b5a libs/StepperMotor.h
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/libs/StepperMotor.h	Fri Feb 28 18:52:52 2014 -0800
@@ -0,0 +1,98 @@
+/*
+      This file is part of Smoothie (http://smoothieware.org/). The motion control part is heavily based on Grbl (https://github.com/simen/grbl).
+      Smoothie is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
+      Smoothie is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
+      You should have received a copy of the GNU General Public License along with Smoothie. If not, see <http://www.gnu.org/licenses/>.
+*/
+
+#ifndef STEPPERMOTOR_H
+#define STEPPERMOTOR_H
+
+#include "libs/Hook.h"
+#include "Pin.h"
+
+class StepTicker;
+class Hook;
+
+class StepperMotor {
+    public:
+        StepperMotor();
+        StepperMotor(Pin& step, Pin& dir, Pin& en);
+
+        // Called a great many times per second, to step if we have to now
+        inline void tick() {
+            // increase the ( fixed point ) counter by one tick 11t
+            fx_counter += (uint32_t)(1<<16);
+
+            // if we are to step now 10t
+            if (fx_counter >= fx_ticks_per_step)
+                step();
+        };
+
+        void step();
+        inline void unstep() { step_pin.set(0); };
+
+        inline void enable(bool state) { en_pin.set(!state); };
+
+        void move_finished();
+        void move( bool direction, unsigned int steps );
+        void signal_move_finished();
+        void set_speed( float speed );
+        void update_exit_tick();
+        void pause();
+        void unpause();
+
+        void change_steps_per_mm(float);
+        void change_last_milestone(float);
+
+        int  steps_to_target(float);
+
+        template<typename T> void attach( T *optr, uint32_t ( T::*fptr )( uint32_t ) ){
+            Hook* hook = new Hook();
+            hook->attach(optr, fptr);
+            this->end_hook = hook;
+        }
+
+        template<typename T> void attach_signal_step(uint32_t step, T *optr, uint32_t ( T::*fptr )( uint32_t ) ){
+            this->step_signal_hook->attach(optr, fptr);
+            this->signal_step_number = step;
+            this->signal_step = true;
+        }
+
+        Hook* end_hook;
+        Hook* step_signal_hook;
+
+        bool signal_step;
+        uint32_t signal_step_number;
+
+        StepTicker* step_ticker;
+        Pin step_pin;
+        Pin dir_pin;
+        Pin en_pin;
+
+        float steps_per_second;
+
+        volatile bool moving;
+        bool paused;
+
+        float steps_per_mm;
+        float max_rate;
+
+        int32_t last_milestone_steps;
+        float   last_milestone_mm;
+
+        uint32_t steps_to_move;
+        uint32_t stepped;
+        uint32_t fx_counter;
+        uint32_t fx_ticks_per_step;
+
+        bool     direction;
+
+        //bool exit_tick;
+        bool remove_from_active_list_next_reset;
+
+        bool is_move_finished; // Whether the move just finished
+};
+
+#endif
+