mbed-os5 only for TYBLE16
Dependents: TYBLE16_simple_data_logger TYBLE16_MP3_Air
drivers/internal/TaskQueue.h
- Committer:
- kenjiArai
- Date:
- 2019-12-31
- Revision:
- 1:9db0e321a9f4
File content as of revision 1:9db0e321a9f4:
/* * Copyright (c) 2018-2019, Arm Limited and affiliates. * SPDX-License-Identifier: Apache-2.0 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef TASK_QUEUE_H #define TASK_QUEUE_H #include "drivers/internal/TaskBase.h" #include "platform/Callback.h" #include "mbed_critical.h" #define MBED_MAX_TASK_SIZE 32 namespace events { /** * \defgroup drivers_TaskQueue TaskQueue class * \ingroup drivers-internal-api-usb * @{ */ /** TaskQueue * * Flexible task queue for dispatching tasks */ class TaskQueue { public: /** Create a TaskQueue * * Create an event queue. */ TaskQueue() { } /** Destroy a TaskQueue */ virtual ~TaskQueue() { } /** * Add this event to the queue for execution * * If the event is already in the queue then it is canceled and * added to the end of the queue. * * @param event Pointer to the event */ virtual void post(TaskBase *event) = 0; /** Cancel an in-flight event * * Cancels the given event so the event's memory can be reused. * * The cancel function is IRQ safe. * * If called while the event queue's dispatch loop is active, the cancel * function does not guarantee that the event will not execute after it * returns, as the event may have already begun executing. It does * guarantee that the event queue is no longer using event data so * the event can be freed or reused. * * @param event Pointer to the event */ virtual void cancel(TaskBase *event) = 0; protected: /** * Get the size required to run this task * * Get the minimum size required for TaskQueue::task_start * * @param task The task to check size on * @return required size * @note This call must be made in a critical section */ static uint32_t task_size(TaskBase *task) { return task->size(); } /** * Start processing this event by copying out its data * * Inform this event both that callback execution has started * and that the event is free to be posted again. * * @param task The task to start processing * @param dest The buffer to copy the callback arguments to * @param size maximum size to copy * @return Pointer to function run * * @note event_start must not be called on a canceled event as the * memory may have been freed already * @note Every call to event_start must be paired with event_finish * @note This call must be made in a critical section */ static TaskBase::run_callback_t task_start(TaskBase *task, uint8_t *dest, uint32_t size) { return task->_start(dest, size); } /** * Finish processing this event * * Inform this event that the callback has run to completion. * * @param task The task to finish processing * * @note Every call to event_finish must be preceded by a call to event_start * @note This call must be made in a critical section */ static void task_finish(TaskBase *task) { task->_finish(); } }; /** @}*/ } #endif