Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Deprecation warning for mcpwm_isr_register() (IDFGH-6217) #7890

Closed
gin66 opened this issue Nov 13, 2021 · 5 comments
Closed

Deprecation warning for mcpwm_isr_register() (IDFGH-6217) #7890

gin66 opened this issue Nov 13, 2021 · 5 comments
Labels
Resolution: Done Issue is done internally Status: Done Issue is done internally

Comments

@gin66
Copy link

gin66 commented Nov 13, 2021

I am the author of FastAccelStepper. This provides for esp32 a high speed stepper motor driver (up to 200kStep/s) supporting up to six parallel active motors. This is enabled by the use of mcpwm and pcnt modules of the esp32. While upgrading to espidf 4.4 a deprecation warning has popped up:

warning: 'esp_err_t mcpwm_isr_register(mcpwm_unit_t, void (*)(void*), void*, int, intr_handle_data_t**)' is deprecated: interrupt events are handled by driver, please use callback [-Wdeprecated-declarations]
         NULL, ESP_INTR_FLAG_IRAM | ESP_INTR_FLAG_SHARED, NULL);

Now I have checked for the proposed callback alternative. Apparently this callback only supports the capture events, but not the other great features of the mcpwm module. The library FastAccelStepper relies on interrupts linked to op0_tea_int_st, op1_tea_int_st and op2_tea_int_st.

That's why I request to either NOT deprecate this API call, or add a callback for interrupts related to these opX_tea_int_st.

BTW: I have noticed, that espressif has dropped the mcpwm modules in all new derivates. This means, espressif does not want its users to use the esp32-derivates for any kind of high performance stepper motor application ?

@espressif-bot espressif-bot added the Status: Opened Issue is new label Nov 13, 2021
@github-actions github-actions bot changed the title Deprecation warning for mcpwm_isr_register() Deprecation warning for mcpwm_isr_register() (IDFGH-6217) Nov 13, 2021
@gin66
Copy link
Author

gin66 commented Nov 14, 2021

Just have seen ESP32-S3 series has a comeback of mcpwm, but a smaller pulse counter.

@suda-morris
Copy link
Collaborator

suda-morris commented Nov 15, 2021

Hi @gin66 The MCPWM peripheral does have a lot more interrupts than just capture interrupts. But I remember the driver didn't ever exposed any API for users to use the events like "utez", "utez". I guess you enabled the interrupt by expanding the mcpwm_intr_t by yourself. If that's the case, we can remove those deprecations.

In ESP-IDF 5.0, the MCPWM driver will be totally re-design, exposing all abilities to user with much extensible APIs. We will provide all the callbacks to user and user don't have to handle the ISR low level stuffs by themselves.

This means, espressif does not want its users to use the esp32-derivates for any kind of high performance stepper motor application.

MCPWM peripheral is resource consuming, so in some ESP32 derivates (like ESP32C3), it's not supported.

BTW, for stepper motor applications, you can also try the RMT peripheral, you can use it to generate fixed number of pulses. See example https://github.com/espressif/esp-idf/tree/master/examples/peripherals/rmt/step_motor

@gin66
Copy link
Author

gin66 commented Nov 15, 2021

Thanks for the feedback. In the FastAccelStepper library, normally the mcpwm driver is only used for basic setup and for the generic interrupt callback. All else (e.g. timer prescaler, interrupt flag management,...) is more or less done by direct register access. This is for me much more convenient and transparent on what is going on. If the IDF 5.0 mcpwm still supports the co-existence of direct register access, then this should be fine.

Thanks for the hint to the RMT peripheral. After some deeper look, there should be something possible. And the need for the pulse counter could be gone. Just the 64 entry depth is not very long. Another drawback is the varying device support (8 TX for esp32, 4 TX for esp32-s2, 2 TX for esp32-c3 and 4 TX for esp32s4). This does not make it easy to develop a driver.

Nevertheless better than no mcpwm at all on s2/c3....

@suda-morris
Copy link
Collaborator

Yes, sure, the register file is always available.

Thanks for your trial with RMT, with regard to the RMT entry depth, it can be altered from https://github.com/espressif/esp-idf/blob/master/components/driver/include/driver/rmt.h#L75

@espressif-bot espressif-bot added Status: In Progress Work is in progress Resolution: Done Issue is done internally Status: Done Issue is done internally and removed Status: Opened Issue is new Status: In Progress Work is in progress labels Nov 17, 2021
@Alvin1Zhang
Copy link
Collaborator

Thanks for reporting, fix is available at e6ee8b2, feel free to reopen.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Resolution: Done Issue is done internally Status: Done Issue is done internally
Projects
None yet
Development

No branches or pull requests

4 participants