remove acceleration tick from timer3, use the pending sv from stepper tick. this...
[clinton/Smoothieware.git] / src / modules / tools / extruder / Extruder.h
... / ...
CommitLineData
1/*
2 This file is part of Smoothie (http://smoothieware.org/). The motion control part is heavily based on Grbl (https://github.com/simen/grbl).
3 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.
4 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.
5 You should have received a copy of the GNU General Public License along with Smoothie. If not, see <http://www.gnu.org/licenses/>.
6*/
7
8
9
10#ifndef EXTURDER_MODULE_H
11#define EXTRUDER_MODULE_H
12
13#include "Tool.h"
14#include "Pin.h"
15
16class StepperMotor;
17class Block;
18
19// NOTE Tool is also a module, no need for multiple inheritance here
20class Extruder : public Tool {
21 public:
22 Extruder(uint16_t config_identifier, bool single= false);
23 virtual ~Extruder();
24
25 void on_module_loaded();
26 void on_config_reload(void* argument);
27 void on_gcode_received(void*);
28 void on_gcode_execute(void* argument);
29 void on_block_begin(void* argument);
30 void on_block_end(void* argument);
31 void on_play(void* argument);
32 void on_pause(void* argument);
33 void on_halt(void* argument);
34 void on_speed_change(void* argument);
35 void acceleration_tick(void);
36 uint32_t stepper_motor_finished_move(uint32_t dummy);
37 Block* append_empty_block();
38
39 private:
40 void on_get_public_data(void* argument);
41 uint32_t rate_increase() const;
42
43 StepperMotor* stepper_motor;
44 Pin step_pin; // Step pin for the stepper driver
45 Pin dir_pin; // Dir pin for the stepper driver
46 Pin en_pin;
47
48 float target_position; // End point ( in mm ) for the current move
49 float current_position; // Current point ( in mm ) for the current move, incremented every time a move is executed
50 float unstepped_distance; // overflow buffer for requested moves that are less than 1 step
51 Block* current_block; // Current block we are stepping, same as Stepper's one
52
53 // kept together so they can be passed as public data
54 struct {
55 float steps_per_millimeter; // Steps to travel one millimeter
56 float filament_diameter; // filament diameter
57 float extruder_multiplier; // flow rate 1.0 == 100%
58 float acceleration; // extruder accleration SOLO setting
59 float retract_length; // firmware retract length
60 };
61
62 float volumetric_multiplier;
63 float feed_rate; // mm/sec for SOLO moves only
64
65 float travel_ratio;
66 float travel_distance;
67
68 // for firmware retract
69 float retract_feedrate;
70 float retract_recover_feedrate;
71 float retract_recover_length;
72 float retract_zlift_length;
73 float retract_zlift_feedrate;
74
75 struct {
76 char mode:3; // extruder motion mode, OFF, SOLO, or FOLLOW
77 bool absolute_mode:1; // absolute/relative coordinate mode switch
78 bool paused:1;
79 bool single_config:1;
80 bool retracted:1;
81 bool cancel_zlift_restore:1; // hack to stop a G11 zlift restore from overring an absolute Z setting
82 };
83
84
85};
86
87#endif