tusb_tasks.h 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. // Copyright 2020 Espressif Systems (Shanghai) PTE LTD
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. #pragma once
  15. #include "esp_err.h"
  16. #ifdef __cplusplus
  17. extern "C" {
  18. #endif
  19. /**
  20. * @brief This helper function creates and starts a task which wraps `tud_task()`.
  21. *
  22. * The wrapper function basically wraps tud_task and some log.
  23. * Default parameters: stack size and priority as configured, argument = NULL, not pinned to any core.
  24. * If you have more requirements for this task, you can create your own task which calls tud_task as the last step.
  25. *
  26. * @retval ESP_OK run tinyusb main task successfully
  27. * @retval ESP_FAIL run tinyusb main task failed of internal error
  28. * @retval ESP_ERR_INVALID_STATE tinyusb main task has been created before
  29. */
  30. esp_err_t tusb_run_task(void);
  31. /**
  32. * @brief This helper function stops and destroys the task created by `tusb_run_task()`
  33. *
  34. * @retval ESP_OK stop and destory tinyusb main task successfully
  35. * @retval ESP_ERR_INVALID_STATE tinyusb main task hasn't been created yet
  36. */
  37. esp_err_t tusb_stop_task(void);
  38. #ifdef __cplusplus
  39. }
  40. #endif