mbed-os5 only for TYBLE16
Dependents: TYBLE16_simple_data_logger TYBLE16_MP3_Air
Diff: drivers/internal/TaskQueue.h
- Revision:
- 1:9db0e321a9f4
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/drivers/internal/TaskQueue.h Tue Dec 31 06:02:27 2019 +0000 @@ -0,0 +1,142 @@ +/* + * 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