intertask_interface.h 7.76 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
/*
 * Licensed to the OpenAirInterface (OAI) Software Alliance under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The OpenAirInterface Software Alliance licenses this file to You under
 * the OAI Public License, Version 1.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.openairinterface.org/?page_id=698
 *
 * 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.
 *-------------------------------------------------------------------------------
 * For more information about the OpenAirInterface (OAI) Software Alliance:
 *      contact@openairinterface.org
 */

Cedric Roux's avatar
Cedric Roux committed
22 23 24 25 26 27
/** @defgroup _intertask_interface_impl_ Intertask Interface Mechanisms
 * Implementation
 * @ingroup _ref_implementation_
 * @{
 */

28
#include <sys/epoll.h>
29

30 31 32 33
#ifdef RTAI
# include <rtai_sem.h>
#endif

Cedric Roux's avatar
Cedric Roux committed
34 35 36 37 38 39 40
#ifndef INTERTASK_INTERFACE_H_
#define INTERTASK_INTERFACE_H_

#include <stdio.h>
#include <stdlib.h>
#include <stdint.h>

41
#include "intertask_interface_conf.h"
Cedric Roux's avatar
Cedric Roux committed
42 43
#include "intertask_interface_types.h"

44 45 46 47 48 49 50
#define ITTI_MSG_ID(mSGpTR)                 ((mSGpTR)->ittiMsgHeader.messageId)
#define ITTI_MSG_ORIGIN_ID(mSGpTR)          ((mSGpTR)->ittiMsgHeader.originTaskId)
#define ITTI_MSG_DESTINATION_ID(mSGpTR)     ((mSGpTR)->ittiMsgHeader.destinationTaskId)
#define ITTI_MSG_INSTANCE(mSGpTR)           ((mSGpTR)->ittiMsgHeader.instance)
#define ITTI_MSG_NAME(mSGpTR)               itti_get_message_name(ITTI_MSG_ID(mSGpTR))
#define ITTI_MSG_ORIGIN_NAME(mSGpTR)        itti_get_task_name(ITTI_MSG_ORIGIN_ID(mSGpTR))
#define ITTI_MSG_DESTINATION_NAME(mSGpTR)   itti_get_task_name(ITTI_MSG_DESTINATION_ID(mSGpTR))
51

Cedric Roux's avatar
Cedric Roux committed
52 53 54 55
/* Make the message number platform specific */
typedef unsigned long message_number_t;
#define MESSAGE_NUMBER_SIZE (sizeof(unsigned long))

56
typedef enum message_priorities_e {
57 58 59 60 61 62 63
  MESSAGE_PRIORITY_MAX       = 100,
  MESSAGE_PRIORITY_MAX_LEAST = 85,
  MESSAGE_PRIORITY_MED_PLUS  = 70,
  MESSAGE_PRIORITY_MED       = 55,
  MESSAGE_PRIORITY_MED_LEAST = 40,
  MESSAGE_PRIORITY_MIN_PLUS  = 25,
  MESSAGE_PRIORITY_MIN       = 10,
64
} message_priorities_t;
Cedric Roux's avatar
Cedric Roux committed
65 66

typedef struct message_info_s {
67 68 69 70 71 72
  task_id_t id;
  message_priorities_t priority;
  /* Message payload size */
  MessageHeaderSize size;
  /* Printable name */
  const char * const name;
Cedric Roux's avatar
Cedric Roux committed
73 74
} message_info_t;

75
typedef enum task_priorities_e {
76 77 78 79 80 81 82
  TASK_PRIORITY_MAX       = 100,
  TASK_PRIORITY_MAX_LEAST = 85,
  TASK_PRIORITY_MED_PLUS  = 70,
  TASK_PRIORITY_MED       = 55,
  TASK_PRIORITY_MED_LEAST = 40,
  TASK_PRIORITY_MIN_PLUS  = 25,
  TASK_PRIORITY_MIN       = 10,
83
} task_priorities_t;
Cedric Roux's avatar
Cedric Roux committed
84

85
typedef struct task_info_s {
86 87 88 89 90 91
  thread_id_t thread;
  task_id_t   parent_task;
  task_priorities_t priority;
  unsigned int queue_size;
  /* Printable name */
  const char * const name;
92 93
} task_info_t;

94 95 96 97 98 99 100
/** \brief Update the itti LTE time reference for messages
 \param current reference frame
 \param current reference slot
 @returns < 0 on failure, 0 otherwise
 **/
void itti_update_lte_time(uint32_t frame, uint8_t slot);

Cedric Roux's avatar
Cedric Roux committed
101 102 103 104
/** \brief Send a broadcast message to every task
 \param message_p Pointer to the message to send
 @returns < 0 on failure, 0 otherwise
 **/
105
int itti_send_broadcast_message(MessageDef *message_p);
Cedric Roux's avatar
Cedric Roux committed
106 107 108 109 110 111 112

/** \brief Send a message to a task (could be itself)
 \param task_id Task ID
 \param instance Instance of the task used for virtualization
 \param message Pointer to the message to send
 @returns -1 on failure, 0 otherwise
 **/
113
int itti_send_msg_to_task(task_id_t task_id, instance_t instance, MessageDef *message);
Cedric Roux's avatar
Cedric Roux committed
114

115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134
/** \brief Add a new fd to monitor.
 * NOTE: it is up to the user to read data associated with the fd
 *  \param task_id Task ID of the receiving task
 *  \param fd The file descriptor to monitor
 **/
void itti_subscribe_event_fd(task_id_t task_id, int fd);

/** \brief Remove a fd from the list of fd to monitor
 *  \param task_id Task ID of the task
 *  \param fd The file descriptor to remove
 **/
void itti_unsubscribe_event_fd(task_id_t task_id, int fd);

/** \brief Return the list of events excluding the fd associated with itti
 *  \param task_id Task ID of the task
 *  \param events events list
 *  @returns number of events to handle
 **/
int itti_get_events(task_id_t task_id, struct epoll_event **events);

Cedric Roux's avatar
Cedric Roux committed
135 136 137 138 139
/** \brief Retrieves a message in the queue associated to task_id.
 * If the queue is empty, the thread is blocked till a new message arrives.
 \param task_id Task ID of the receiving task
 \param received_msg Pointer to the allocated message
 **/
140
void itti_receive_msg(task_id_t task_id, MessageDef **received_msg);
Cedric Roux's avatar
Cedric Roux committed
141

142
/** \brief Try to retrieves a message in the queue associated to task_id.
Cedric Roux's avatar
Cedric Roux committed
143 144 145
 \param task_id Task ID of the receiving task
 \param received_msg Pointer to the allocated message
 **/
146
void itti_poll_msg(task_id_t task_id, MessageDef **received_msg);
Cedric Roux's avatar
Cedric Roux committed
147 148 149 150 151 152 153

/** \brief Start thread associated to the task
 * \param task_id task to start
 * \param start_routine entry point for the task
 * \param args_p Optional argument to pass to the start routine
 * @returns -1 on failure, 0 otherwise
 **/
154
int itti_create_task(task_id_t task_id,
155 156
                     void *(*start_routine) (void *),
                     void *args_p);
Cedric Roux's avatar
Cedric Roux committed
157

knopp's avatar
knopp committed
158
//#ifdef RTAI
159 160 161 162
/** \brief Mark the task as a real time task
 * \param task_id task to mark as real time
 **/
void itti_set_task_real_time(task_id_t task_id);
knopp's avatar
knopp committed
163
//#endif
164

165 166 167 168 169
/** \brief Indicates to ITTI if newly created tasks should wait for all tasks to be ready
 * \param wait_tasks non 0 to make new created tasks to wait, 0 to let created tasks to run
 **/
void itti_wait_ready(int wait_tasks);

Cedric Roux's avatar
Cedric Roux committed
170 171 172
/** \brief Mark the task as in ready state
 * \param task_id task to mark as ready
 **/
173 174
void itti_mark_task_ready(task_id_t task_id);

175 176 177 178
/** \brief Exit the current task.
 **/
void itti_exit_task(void);

179 180 181 182
/** \brief Indicate that the task is completed and initiate termination of all tasks.
 * \param task_id task that is completed
 **/
void itti_terminate_tasks(task_id_t task_id);
Cedric Roux's avatar
Cedric Roux committed
183 184 185 186

/** \brief Return the printable string associated with the message
 * \param message_id Id of the message
 **/
187
const char *itti_get_message_name(MessagesIds message_id);
Cedric Roux's avatar
Cedric Roux committed
188

189 190 191
/** \brief Return the printable string associated with a task id
 * \param thread_id Id of the task
 **/
192
const char *itti_get_task_name(task_id_t task_id);
193

Cedric Roux's avatar
Cedric Roux committed
194
/** \brief Alloc and memset(0) a new itti message.
195 196 197
 * \param origin_task_id Task ID of the sending task
 * \param message_id Message ID
 * @returns NULL in case of failure or newly allocated mesage ref
Cedric Roux's avatar
Cedric Roux committed
198
 **/
199
MessageDef *itti_alloc_new_message(
200 201
  task_id_t         origin_task_id,
  MessagesIds       message_id);
202 203 204 205 206 207 208

/** \brief Alloc and memset(0) a new itti message.
 * \param origin_task_id Task ID of the sending task
 * \param message_id Message ID
 * \param size size of the payload to send
 * @returns NULL in case of failure or newly allocated mesage ref
 **/
209
MessageDef *itti_alloc_new_message_sized(
210 211 212
  task_id_t         origin_task_id,
  MessagesIds       message_id,
  MessageHeaderSize size);
Cedric Roux's avatar
Cedric Roux committed
213

214 215 216 217 218 219 220 221 222
/** \brief handle signals and wait for all threads to join when the process complete.
 * This function should be called from the main thread after having created all ITTI tasks.
 **/
void itti_wait_tasks_end(void);

/** \brief Send a termination message to all tasks.
 * \param task_id task that is broadcasting the message.
 **/
void itti_send_terminate_message(task_id_t task_id);
Cedric Roux's avatar
Cedric Roux committed
223

224
void *itti_malloc(task_id_t origin_task_id, task_id_t destination_task_id, ssize_t size);
225

226
int itti_free(task_id_t task_id, void *ptr);
227

Cedric Roux's avatar
Cedric Roux committed
228 229
#endif /* INTERTASK_INTERFACE_H_ */
/* @} */