14#ifndef ZEPHYR_INCLUDE_DRIVERS_STEPPER_H_
15#define ZEPHYR_INCLUDE_DRIVERS_STEPPER_H_
36#define MICRO_STEP_RES_INDEX(res) LOG2(res)
110typedef int (*stepper_enable_t)(
const struct device *dev,
const bool enable);
117typedef int (*stepper_move_by_t)(
const struct device *dev,
const int32_t micro_steps);
124typedef int (*stepper_set_microstep_interval_t)(
const struct device *dev,
125 const uint64_t microstep_interval_ns);
132typedef int (*stepper_set_micro_step_res_t)(
const struct device *dev,
140typedef int (*stepper_get_micro_step_res_t)(
const struct device *dev,
147typedef int (*stepper_set_reference_position_t)(
const struct device *dev,
const int32_t value);
154typedef int (*stepper_get_actual_position_t)(
const struct device *dev,
int32_t *value);
161typedef int (*stepper_move_to_t)(
const struct device *dev,
const int32_t micro_steps);
168typedef int (*stepper_is_moving_t)(
const struct device *dev,
bool *is_moving);
180typedef void (*stepper_event_callback_t)(
const struct device *dev,
const enum stepper_event event,
188typedef int (*stepper_set_event_callback_t)(
const struct device *dev,
189 stepper_event_callback_t callback,
void *user_data);
194__subsystem
struct stepper_driver_api {
195 stepper_enable_t enable;
196 stepper_move_by_t move_by;
197 stepper_set_microstep_interval_t set_microstep_interval;
198 stepper_set_micro_step_res_t set_micro_step_res;
199 stepper_get_micro_step_res_t get_micro_step_res;
200 stepper_set_reference_position_t set_reference_position;
201 stepper_get_actual_position_t get_actual_position;
202 stepper_move_to_t move_to;
203 stepper_is_moving_t is_moving;
205 stepper_set_event_callback_t set_event_callback;
223static inline int z_impl_stepper_enable(
const struct device *dev,
const bool enable)
225 const struct stepper_driver_api *api = (
const struct stepper_driver_api *)dev->
api;
227 return api->enable(dev, enable);
245static inline int z_impl_stepper_move_by(
const struct device *dev,
const int32_t micro_steps)
247 const struct stepper_driver_api *api = (
const struct stepper_driver_api *)dev->
api;
249 return api->move_by(dev, micro_steps);
271static inline int z_impl_stepper_set_microstep_interval(
const struct device *dev,
272 const uint64_t microstep_interval_ns)
274 const struct stepper_driver_api *api = (
const struct stepper_driver_api *)dev->
api;
276 if (api->set_microstep_interval == NULL) {
279 return api->set_microstep_interval(dev, microstep_interval_ns);
296static inline int z_impl_stepper_set_micro_step_res(
const struct device *dev,
299 const struct stepper_driver_api *api = (
const struct stepper_driver_api *)dev->
api;
301 if (api->set_micro_step_res == NULL) {
304 return api->set_micro_step_res(dev, resolution);
320static inline int z_impl_stepper_get_micro_step_res(
const struct device *dev,
323 const struct stepper_driver_api *api = (
const struct stepper_driver_api *)dev->
api;
325 if (api->get_micro_step_res == NULL) {
328 return api->get_micro_step_res(dev, resolution);
343static inline int z_impl_stepper_set_reference_position(
const struct device *dev,
346 const struct stepper_driver_api *api = (
const struct stepper_driver_api *)dev->
api;
348 if (api->set_reference_position == NULL) {
351 return api->set_reference_position(dev, value);
366static inline int z_impl_stepper_get_actual_position(
const struct device *dev,
int32_t *value)
368 const struct stepper_driver_api *api = (
const struct stepper_driver_api *)dev->
api;
370 if (api->get_actual_position == NULL) {
373 return api->get_actual_position(dev, value);
392static inline int z_impl_stepper_move_to(
const struct device *dev,
const int32_t micro_steps)
394 const struct stepper_driver_api *api = (
const struct stepper_driver_api *)dev->
api;
396 if (api->move_to == NULL) {
399 return api->move_to(dev, micro_steps);
414static inline int z_impl_stepper_is_moving(
const struct device *dev,
bool *is_moving)
416 const struct stepper_driver_api *api = (
const struct stepper_driver_api *)dev->
api;
418 if (api->is_moving == NULL) {
421 return api->is_moving(dev, is_moving);
441static inline int z_impl_stepper_run(
const struct device *dev,
444 const struct stepper_driver_api *api = (
const struct stepper_driver_api *)dev->
api;
446 if (api->run == NULL) {
449 return api->run(dev, direction);
464 stepper_event_callback_t callback,
void *user_data);
466static inline int z_impl_stepper_set_event_callback(
const struct device *dev,
467 stepper_event_callback_t callback,
470 const struct stepper_driver_api *api = (
const struct stepper_driver_api *)dev->
api;
472 if (api->set_event_callback == NULL) {
475 return api->set_event_callback(dev, callback, user_data);
486#include <zephyr/syscalls/stepper.h>
stepper_direction
Stepper Motor direction options.
Definition stepper.h:65
int stepper_enable(const struct device *dev, const bool enable)
Enable or disable motor controller.
int stepper_set_reference_position(const struct device *dev, int32_t value)
Set the reference position of the stepper.
stepper_run_mode
Stepper Motor run mode options.
Definition stepper.h:75
int stepper_set_microstep_interval(const struct device *dev, uint64_t microstep_interval_ns)
Set the time interval between steps in microseconds.
int stepper_get_actual_position(const struct device *dev, int32_t *value)
Get the actual a.k.a reference position of the stepper.
int stepper_get_micro_step_res(const struct device *dev, enum stepper_micro_step_resolution *resolution)
Get the microstep resolution in stepper motor controller.
int stepper_move_to(const struct device *dev, int32_t micro_steps)
Set the absolute target position of the stepper.
int stepper_move_by(const struct device *dev, int32_t micro_steps)
Set the microsteps to be moved from the current position i.e.
int stepper_run(const struct device *dev, enum stepper_direction direction)
Run the stepper with a given step interval in a given direction.
int stepper_is_moving(const struct device *dev, bool *is_moving)
Check if the stepper motor is currently moving.
stepper_event
Stepper Events.
Definition stepper.h:87
int stepper_set_micro_step_res(const struct device *dev, enum stepper_micro_step_resolution resolution)
Set the microstep resolution in stepper motor controller.
int stepper_set_event_callback(const struct device *dev, stepper_event_callback_t callback, void *user_data)
Set the callback function to be called when a stepper event occurs.
stepper_micro_step_resolution
Stepper Motor microstep resolution options.
Definition stepper.h:41
@ STEPPER_DIRECTION_POSITIVE
Positive direction.
Definition stepper.h:69
@ STEPPER_DIRECTION_NEGATIVE
Negative direction.
Definition stepper.h:67
@ STEPPER_RUN_MODE_VELOCITY
Velocity Mode.
Definition stepper.h:81
@ STEPPER_RUN_MODE_HOLD
Hold Mode.
Definition stepper.h:77
@ STEPPER_RUN_MODE_POSITION
Position Mode.
Definition stepper.h:79
@ STEPPER_EVENT_LEFT_END_STOP_DETECTED
Left end switch status changes to pressed.
Definition stepper.h:93
@ STEPPER_EVENT_RIGHT_END_STOP_DETECTED
Right end switch status changes to pressed.
Definition stepper.h:95
@ STEPPER_EVENT_STEPS_COMPLETED
Steps set using move_by or move_to have been executed.
Definition stepper.h:89
@ STEPPER_EVENT_STALL_DETECTED
Stall detected.
Definition stepper.h:91
@ STEPPER_MICRO_STEP_64
64 microsteps per full step
Definition stepper.h:55
@ STEPPER_MICRO_STEP_4
4 microsteps per full step
Definition stepper.h:47
@ STEPPER_MICRO_STEP_1
Full step resolution.
Definition stepper.h:43
@ STEPPER_MICRO_STEP_2
2 microsteps per full step
Definition stepper.h:45
@ STEPPER_MICRO_STEP_256
256 microsteps per full step
Definition stepper.h:59
@ STEPPER_MICRO_STEP_8
8 microsteps per full step
Definition stepper.h:49
@ STEPPER_MICRO_STEP_16
16 microsteps per full step
Definition stepper.h:51
@ STEPPER_MICRO_STEP_32
32 microsteps per full step
Definition stepper.h:53
@ STEPPER_MICRO_STEP_128
128 microsteps per full step
Definition stepper.h:57
#define ENOSYS
Function not implemented.
Definition errno.h:82
__INT32_TYPE__ int32_t
Definition stdint.h:74
__UINT64_TYPE__ uint64_t
Definition stdint.h:91
Runtime device structure (in ROM) per driver instance.
Definition device.h:411
const void * api
Address of the API structure exposed by the device instance.
Definition device.h:417