24 #ifndef _SPINDLE_CONTROL_H_
25 #define _SPINDLE_CONTROL_H_
29 #define SPINDLE_NONE 0
30 #define SPINDLE_HUANYANG1 1
31 #define SPINDLE_HUANYANG2 2
32 #define SPINDLE_GS20 3
33 #define SPINDLE_YL620A 4
34 #define SPINDLE_MODVFD 5
35 #define SPINDLE_H100 6
36 #define SPINDLE_ONOFF0 7
37 #define SPINDLE_ONOFF0_DIR 8
38 #define SPINDLE_ONOFF1 9
39 #define SPINDLE_ONOFF1_DIR 10
40 #define SPINDLE_PWM0 11
41 #define SPINDLE_PWM0_NODIR 12
42 #define SPINDLE_PWM1 13
43 #define SPINDLE_PWM1_NODIR 14
44 #define SPINDLE_PWM2 15
45 #define SPINDLE_PWM2_NODIR 16
46 #define SPINDLE_PWM0_CLONE 17
47 #define SPINDLE_SOLENOID 18
48 #define SPINDLE_STEPPER 19
49 #define SPINDLE_NOWFOREVER 20
50 #define SPINDLE_MY_SPINDLE 30
52 #define SPINDLE_ALL_VFD ((1<<SPINDLE_HUANYANG1)|(1<<SPINDLE_HUANYANG2)|(1<<SPINDLE_GS20)|(1<<SPINDLE_YL620A)|(1<<SPINDLE_MODVFD)|(1<<SPINDLE_H100)|(1<<SPINDLE_NOWFOREVER))
53 #define SPINDLE_ALL (SPINDLE_ALL_VFD|(1<<SPINDLE_PWM0))
146 typedef void (*esp32_spindle_off_ptr)(
struct spindle_ptrs *spindle);
288 esp32_spindle_off_ptr esp32_off;
359 #define spindle_validate_at_speed(d, r) { d.rpm = r; d.state_programmed.at_speed = !d.at_speed_enabled || (d.rpm >= d.rpm_low_limit && d.rpm <= d.rpm_high_limit); }
409 void spindle1_settings_register (
spindle_cap_t cap, spindle1_settings_changed_ptr on_changed);
#define SPINDLE_NPWM_PIECES
Number of pieces used for spindle RPM linearization, enabled by setting ENABLE_SPINDLE_LINEARIZATION ...
Definition: config.h:109
__attribute__
Definition: errors.h:30
uint_fast16_t override_t
Definition: grbl.h:236
grbl_hal_t hal
Global HAL struct.
Definition: grbllib.c:88
settings_t settings
Definition: settings.c:43
void spindle_bind_encoder(const spindle_data_ptrs_t *encoder_data)
Definition: spindle_control.c:314
void spindle_update_caps(spindle_ptrs_t *spindle, spindle_pwm_t *pwm_caps)
Update the capabilities of a registered PWM spindle. May be used by the driver on spindle initializat...
Definition: spindle_control.c:261
bool spindle_precompute_pwm_values(spindle_ptrs_t *spindle, spindle_pwm_t *pwm_data, spindle_settings_t *settings, uint32_t clock_hz)
Precompute PWM values for faster conversion.
Definition: spindle_control.c:788
spindle_hal_t
Definition: spindle_control.h:123
@ SpindleHAL_Raw
0 - NOTE: read-only
Definition: spindle_control.h:124
@ SpindleHAL_Active
2
Definition: spindle_control.h:126
@ SpindleHAL_Configured
1
Definition: spindle_control.h:125
bool spindle_is_enabled(spindle_num_t spindle_num)
Check if a spindle is enabled and available or not.
Definition: spindle_control.c:393
spindle_type_t
Definition: spindle_control.h:114
@ SpindleType_VFD
2
Definition: spindle_control.h:117
@ SpindleType_PWM
0
Definition: spindle_control.h:115
@ SpindleType_Basic
1 - on/off + optional direction
Definition: spindle_control.h:116
@ SpindleType_Null
5
Definition: spindle_control.h:120
@ SpindleType_Stepper
4
Definition: spindle_control.h:119
@ SpindleType_Solenoid
3
Definition: spindle_control.h:118
void(* spindle_enumerate_callback_ptr)(spindle_info_t *spindle, void *data)
Pointer to callback function called by spindle_enumerate_spindles().
Definition: spindle_control.h:337
const char * spindle_get_name(spindle_id_t spindle_id)
Get the registered name of a spindle.
Definition: spindle_control.c:251
bool spindle_set_at_speed_range(spindle_ptrs_t *spindle, spindle_data_t *spindle_data, float rpm)
Definition: spindle_control.c:344
bool spindle_enumerate_spindles(spindle_enumerate_callback_ptr callback, void *data)
Enumerate registered spindles by calling a callback function for each of them.
Definition: spindle_control.c:362
bool spindle_select(spindle_id_t spindle_id)
Enables a spindle and sets it as default spindle (spindle number 0).
Definition: spindle_control.c:181
bool(* spindle_config_ptr)(struct spindle_ptrs *spindle)
Pointer to function for configuring a spindle.
Definition: spindle_control.h:137
spindle_state_t(* spindle_get_state_ptr)(struct spindle_ptrs *spindle)
Pointer to function for getting the spindle state.
Definition: spindle_control.h:152
uint_fast16_t(* spindle_get_pwm_ptr)(struct spindle_ptrs *spindle, float rpm)
Pointer to function for converting a RPM value to a PWM value.
Definition: spindle_control.h:161
spindle_num_t spindle_enable(spindle_id_t spindle_id)
Enable a spindle and make it available for use by gcode.
Definition: spindle_control.c:164
spindle_id_t spindle_get_default(void)
Get the spindle id of the default spindle (spindle number 0).
Definition: spindle_control.c:225
uint8_t spindle_get_count(void)
Get number of registered spindles.
Definition: spindle_control.c:285
int8_t spindle_id_t
Definition: spindle_control.h:55
void(* spindle_update_pwm_ptr)(struct spindle_ptrs *spindle, uint_fast16_t pwm)
Pointer to function for updating spindle speed on the fly.
Definition: spindle_control.h:169
void(* spindle_reset_data_ptr)(void)
Pointer to function for resetting spindle data.
Definition: spindle_control.h:185
bool spindle_is_on(void)
Check if any of the enabled spindles is running.
Definition: spindle_control.c:700
spindle_id_t spindle_register(const spindle_ptrs_t *spindle, const char *name)
Register a spindle with the core.
Definition: spindle_control.c:132
bool spindle_sync(spindle_ptrs_t *spindle, spindle_state_t state, float rpm)
G-code parser entry-point for setting spindle state. Forces a planner buffer sync and bails if an abo...
Definition: spindle_control.c:592
bool spindle_set_state(spindle_ptrs_t *spindle, spindle_state_t state, float rpm)
Immediately sets spindle running state with direction and spindle rpm, if enabled....
Definition: spindle_control.c:579
spindle_cap_t spindle_get_caps(bool active)
Get the merged spindle capabilities of all registered spindles.
Definition: spindle_control.c:234
struct spindle_param spindle_param_t
Structure used for holding the current state of an enabled spindle.
void(* spindle_set_state_ptr)(struct spindle_ptrs *spindle, spindle_state_t state, float rpm)
Pointer to function for setting the spindle state.
Definition: spindle_control.h:143
spindle_data_request_t
Definition: spindle_control.h:107
@ SpindleData_RPM
1
Definition: spindle_control.h:109
@ SpindleData_AngularPosition
2
Definition: spindle_control.h:110
@ SpindleData_AtSpeed
3
Definition: spindle_control.h:111
@ SpindleData_Counters
0
Definition: spindle_control.h:108
void spindle_all_off(void)
Turn off all enabled spindles.
Definition: spindle_control.c:677
void spindle_set_override(spindle_ptrs_t *spindle, override_t speed_override)
Set spindle speed override.
Definition: spindle_control.c:503
spindle_ptrs_t * spindle_get_hal(spindle_id_t spindle_id, spindle_hal_t hal)
Get the handlers (function pointers) etc. associated with the spindle.
Definition: spindle_control.c:202
bool spindle_restore(spindle_ptrs_t *spindle, spindle_state_t state, float rpm)
Restore spindle running state with direction, enable, spindle RPM and appropriate delay.
Definition: spindle_control.c:627
spindle_data_t *(* spindle_get_data_ptr)(spindle_data_request_t request)
Pointer to function for getting spindle data.
Definition: spindle_control.h:182
spindle_ptrs_t * spindle_get(spindle_num_t spindle_num)
Get the handlers (function pointers) etc. associated with an enabled spindle.
Definition: spindle_control.c:407
int8_t spindle_num_t
Definition: spindle_control.h:56
spindle_id_t spindle_add_null(void)
Register a null spindle that has no connection to the outside world. This is done automatically on st...
Definition: spindle_control.c:464
struct spindle_pwm spindle_pwm_t
Precalculated values that may be set/used by HAL driver to speed up RPM to PWM conversions if variabl...
void(* spindle_pulse_on_ptr)(uint_fast16_t pulse_length)
Pointer to function for outputting a spindle on pulse. Used for Pulses Per Inch (PPI) laser mode.
Definition: spindle_control.h:191
void(* spindle_update_rpm_ptr)(struct spindle_ptrs *spindle, float rpm)
Pointer to function for updating spindle RPM.
Definition: spindle_control.h:174
float spindle_set_rpm(spindle_ptrs_t *spindle, float rpm, override_t speed_override)
Calculate and set programmed RPM according to override and max/min limits.
Definition: spindle_control.c:662
Definition: spindle_control.h:193
float rpm
Definition: spindle_control.h:194
float end
Definition: spindle_control.h:196
float start
Definition: spindle_control.h:195
Definition: spindle_control.h:226
spindle_settings_t cfg
Definition: spindle_control.h:230
uint8_t port_on
Definition: spindle_control.h:227
uint8_t port_pwm
Definition: spindle_control.h:229
uint8_t port_dir
Definition: spindle_control.h:228
Data used for Constant Surface Speed (CSS) mode calculations.
Definition: spindle_control.h:299
float target_rpm
Target RPM at end of movement.
Definition: spindle_control.h:301
float surface_speed
Surface speed in millimeters/min.
Definition: spindle_control.h:300
float tool_offset
Tool offset.
Definition: spindle_control.h:304
uint_fast8_t axis
Linear (tool) axis.
Definition: spindle_control.h:305
float max_rpm
Maximum spindle RPM.
Definition: spindle_control.h:303
float delta_rpm
Delta between start and target RPM.
Definition: spindle_control.h:302
Definition: spindle_control.h:318
spindle_get_data_ptr get
Optional handler for getting spindle data. Required for spindle sync.
Definition: spindle_control.h:319
spindle_reset_data_ptr reset
Optional handler for resetting spindle data. Required for spindle sync.
Definition: spindle_control.h:320
Used when HAL driver supports spindle synchronization.
Definition: spindle_control.h:94
float rpm_programmed
Definition: spindle_control.h:99
float angular_position
Number of revolutions since last reset.
Definition: spindle_control.h:98
float rpm_high_limit
Definition: spindle_control.h:97
float rpm
Definition: spindle_control.h:95
spindle_state_t state_programmed
Definition: spindle_control.h:104
bool at_speed_enabled
Definition: spindle_control.h:103
uint32_t index_count
Definition: spindle_control.h:100
uint32_t pulse_count
Definition: spindle_control.h:101
float rpm_low_limit
Definition: spindle_control.h:96
uint32_t error_count
Definition: spindle_control.h:102
Structure holding data passed to the callback function called by spindle_enumerate_spindles().
Definition: spindle_control.h:324
uint8_t ref_id
Definition: spindle_control.h:326
bool enabled
Definition: spindle_control.h:329
const char * name
Definition: spindle_control.h:328
spindle_num_t num
Definition: spindle_control.h:327
const spindle_ptrs_t * hal
Definition: spindle_control.h:331
spindle_id_t id
Definition: spindle_control.h:325
bool is_current
Definition: spindle_control.h:330
Structure used for holding the current state of an enabled spindle.
Definition: spindle_control.h:309
float rpm_overridden
Definition: spindle_control.h:311
float rpm
Definition: spindle_control.h:310
spindle_state_t state
Definition: spindle_control.h:312
spindle_ptrs_t * hal
Definition: spindle_control.h:315
override_t override_pct
Spindle RPM override value in percent.
Definition: spindle_control.h:313
spindle_css_data_t css
Data used for Constant Surface Speed Mode (CSS) calculations, NULL if not in CSS mode.
Definition: spindle_control.h:314
Handlers and data for spindle support.
Definition: spindle_control.h:270
spindle_context_ptr_t context
Optional pointer to spindle specific context.
Definition: spindle_control.h:276
spindle_set_state_ptr set_state
Handler for setting spindle state.
Definition: spindle_control.h:282
spindle_update_rpm_ptr update_rpm
Handler for updating spindle RPM.
Definition: spindle_control.h:286
spindle_reset_data_ptr reset_data
Optional handler for resetting spindle data. Required for spindle sync, copied from hal....
Definition: spindle_control.h:293
float rpm_max
Maximum spindle RPM.
Definition: spindle_control.h:279
spindle_config_ptr config
Optional handler for configuring the spindle.
Definition: spindle_control.h:281
spindle_get_data_ptr get_data
Optional handler for getting spindle data. Required for spindle sync, copied from hal....
Definition: spindle_control.h:292
uint_fast16_t pwm_off_value
Value for switching PWM signal off.
Definition: spindle_control.h:277
spindle_get_pwm_ptr get_pwm
Handler for calculating spindle PWM value from RPM.
Definition: spindle_control.h:284
uint8_t ref_id
Spindle id, assigned on spindle registration.
Definition: spindle_control.h:272
spindle_pulse_on_ptr pulse_on
Optional handler for Pulses Per Inch (PPI) mode. Required for the laser PPI plugin.
Definition: spindle_control.h:291
spindle_update_pwm_ptr update_pwm
Handler for updating spindle PWM output.
Definition: spindle_control.h:285
float at_speed_tolerance
Tolerance in percent of programmed speed.
Definition: spindle_control.h:280
spindle_id_t id
Spindle id, assigned on spindle registration.
Definition: spindle_control.h:271
float rpm_min
Minimum spindle RPM.
Definition: spindle_control.h:278
spindle_get_state_ptr get_state
Handler for getting spindle state.
Definition: spindle_control.h:283
spindle_cap_t cap
Spindle capabilities.
Definition: spindle_control.h:275
struct spindle_param * param
Pointer to current spindle parameters, assigned when spindle is enabled.
Definition: spindle_control.h:273
spindle_type_t type
Spindle type.
Definition: spindle_control.h:274
Precalculated values that may be set/used by HAL driver to speed up RPM to PWM conversions if variabl...
Definition: spindle_control.h:245
uint_fast16_t period
Definition: spindle_control.h:248
bool cloned
deprecated, use bit in flags instead
Definition: spindle_control.h:256
uint_fast16_t off_value
NOTE: this value holds the inverted version if software PWM inversion is enabled by the driver.
Definition: spindle_control.h:249
uint32_t f_clock
Definition: spindle_control.h:246
bool invert_pwm
deprecated, use bit in flags instead
Definition: spindle_control.h:254
pwm_piece_t piece[SPINDLE_NPWM_PIECES]
Definition: spindle_control.h:260
uint_fast16_t min_value
Definition: spindle_control.h:250
int_fast16_t offset
Definition: spindle_control.h:258
uint_fast16_t(* compute_value)(struct spindle_pwm *pwm_data, float rpm, bool pid_limit)
Definition: spindle_control.h:261
spindle_settings_t * settings
Definition: spindle_control.h:247
uint_fast16_t n_pieces
Definition: spindle_control.h:259
float rpm_min
Minimum spindle RPM.
Definition: spindle_control.h:252
bool always_on
deprecated, use bit in flags instead
Definition: spindle_control.h:255
uint_fast16_t max_value
Definition: spindle_control.h:251
float pwm_gradient
Definition: spindle_control.h:253
spindle_pwm_flags_t flags
Definition: spindle_control.h:257
Definition: spindle_control.h:210
float pwm_freq
Definition: spindle_control.h:213
uint16_t ppr
Spindle encoder pulses per revolution (PPR).
Definition: spindle_control.h:221
float pwm_period
Definition: spindle_control.h:214
spindle_state_t invert
Definition: spindle_control.h:222
float pwm_off_value
Definition: spindle_control.h:215
pid_values_t pid
Definition: spindle_control.h:220
float rpm_max
Definition: spindle_control.h:211
spindle_settings_flags_t flags
Definition: spindle_control.h:223
float pwm_max_value
Definition: spindle_control.h:217
float pwm_min_value
Definition: spindle_control.h:216
float at_speed_tolerance
Tolerance in percent of programmed speed.
Definition: spindle_control.h:218
float rpm_min
Definition: spindle_control.h:212
Bitmap flags for spindle capabilities.
Definition: spindle_control.h:75
uint16_t at_speed
Spindle at speed feedback is supported.
Definition: spindle_control.h:80
uint16_t unassigned
Definition: spindle_control.h:89
uint16_t laser
Spindle can control a laser.
Definition: spindle_control.h:81
uint16_t pwm_invert
Spindle PWM output can be inverted.
Definition: spindle_control.h:82
uint16_t direction
Spindle direction (M4) is supported.
Definition: spindle_control.h:79
uint16_t cmd_controlled
Command controlled, e.g. over ModBus.
Definition: spindle_control.h:87
uint16_t value
All bitmap flags.
Definition: spindle_control.h:76
uint16_t pid
Definition: spindle_control.h:83
uint16_t gpio_controlled
On/off and direction is controlled by GPIO.
Definition: spindle_control.h:86
uint16_t cloned
Spindle is cloned.
Definition: spindle_control.h:88
uint16_t variable
Variable spindle speed is supported.
Definition: spindle_control.h:78
uint16_t rpm_range_locked
Spindle RPM range (min, max) not inherited from settings.
Definition: spindle_control.h:85
uint16_t pwm_linearization
Definition: spindle_control.h:84
Definition: spindle_control.h:265
spindle_pwm_t * pwm
Definition: spindle_control.h:266
Definition: spindle_control.h:233
uint8_t cloned
Definition: spindle_control.h:238
uint8_t value
Definition: spindle_control.h:234
uint8_t laser_mode_disable
Definition: spindle_control.h:239
uint8_t invert_pwm
NOTE: set (by driver) when inversion is done in code.
Definition: spindle_control.h:236
uint8_t always_on
Definition: spindle_control.h:237
uint8_t unused
Definition: spindle_control.h:240
Definition: spindle_control.h:199
uint8_t type
Definition: spindle_control.h:205
uint8_t pwm_disable
Definition: spindle_control.h:206
uint8_t value
Definition: spindle_control.h:200
uint8_t enable_rpm_controlled
Definition: spindle_control.h:203
uint8_t mask
Definition: spindle_control.h:201
uint8_t laser_mode_disable
Definition: spindle_control.h:204
Definition: spindle_control.h:59
uint8_t value
Definition: spindle_control.h:60
uint8_t on
Definition: spindle_control.h:63
uint8_t at_speed
Spindle is at speed.
Definition: spindle_control.h:69
uint8_t synchronized
Definition: spindle_control.h:70
uint8_t mask
Definition: spindle_control.h:61
uint8_t pwm
NOTE: only used for PWM inversion setting.
Definition: spindle_control.h:65
uint8_t reserved
Definition: spindle_control.h:66
uint8_t override_disable
Definition: spindle_control.h:67
uint8_t encoder_error
Definition: spindle_control.h:68
uint8_t ccw
Definition: spindle_control.h:64