aboutsummaryrefslogtreecommitdiff
path: root/platform/linux-generic/include/odp_queue_scalable_internal.h
blob: 05932a36af32538297da91bbab3ada5a7aa8a89b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
/* Copyright (c) 2017, ARM Limited. All rights reserved.
 *
 * Copyright (c) 2017-2018, Linaro Limited
 * All rights reserved.
 *
 * SPDX-License-Identifier: BSD-3-Clause
 */

#ifndef ODP_QUEUE_SCALABLE_INTERNAL_H_
#define ODP_QUEUE_SCALABLE_INTERNAL_H_

#ifdef __cplusplus
extern "C" {
#endif

#include <odp/api/plat/strong_types.h>
#include <odp/api/queue.h>
#include <odp_forward_typedefs_internal.h>
#include <odp_queue_if.h>
#include <odp_buffer_internal.h>
#include <odp_align_internal.h>
#include <odp/api/packet_io.h>
#include <odp/api/align.h>
#include <odp/api/hints.h>
#include <odp/api/ticketlock.h>
#include <odp_config_internal.h>
#include <odp_schedule_scalable.h>
#include <odp_schedule_scalable_ordered.h>

#define QUEUE_STATUS_FREE         0
#define QUEUE_STATUS_DESTROYED    1
#define QUEUE_STATUS_READY        2

struct queue_entry_s {
	sched_elem_t     sched_elem;

	odp_ticketlock_t ODP_ALIGNED_CACHE lock;
	int              status;

	queue_enq_fn_t       ODP_ALIGNED_CACHE enqueue;
	queue_deq_fn_t       dequeue;
	queue_enq_multi_fn_t enqueue_multi;
	queue_deq_multi_fn_t dequeue_multi;
	queue_deq_multi_fn_t orig_dequeue_multi;

	uint32_t           index;
	odp_queue_t        handle;
	odp_queue_type_t   type;
	odp_queue_param_t  param;
	odp_pktin_queue_t  pktin;
	odp_pktout_queue_t pktout;
	char               name[ODP_QUEUE_NAME_LEN];
};

union queue_entry_u {
	struct queue_entry_s s;
	uint8_t pad[ROUNDUP_CACHE_LINE(sizeof(struct queue_entry_s))];
};

int _odp_queue_deq(sched_elem_t *q, odp_buffer_hdr_t *buf_hdr[], int num);
int _odp_queue_deq_sc(sched_elem_t *q, odp_event_t *evp, int num);
int _odp_queue_deq_mc(sched_elem_t *q, odp_event_t *evp, int num);
int _odp_queue_enq_sp(sched_elem_t *q, odp_buffer_hdr_t *buf_hdr[], int num);
queue_entry_t *qentry_from_ext(odp_queue_t handle);

/* Round up memory size to next cache line size to
 * align all memory addresses on cache line boundary.
 */
static inline void *shm_pool_alloc_align(_odp_ishm_pool_t *pool, uint32_t size)
{
	void *addr;

	addr = _odp_ishm_pool_alloc(pool, ROUNDUP_CACHE_LINE(size));
	ODP_ASSERT(((uintptr_t)addr & (ODP_CACHE_LINE_SIZE - 1)) == 0);

	return addr;
}

static inline uint32_t queue_to_id(odp_queue_t handle)
{
	return qentry_from_ext(handle)->s.index;
}

static inline queue_entry_t *qentry_from_int(odp_queue_t handle)
{
	return (queue_entry_t *)(uintptr_t)handle;
}

static inline odp_queue_t qentry_to_int(queue_entry_t *qentry)
{
	return (odp_queue_t)qentry;
}

static inline odp_queue_t queue_get_handle(queue_entry_t *queue)
{
	return queue->s.handle;
}

static inline reorder_window_t *queue_get_rwin(queue_entry_t *queue)
{
	return queue->s.sched_elem.rwin;
}

#ifdef __cplusplus
}
#endif

#endif