blob: 49c041769d029769f58394bc7ce8d370acd545db [file] [log] [blame]
Klement Sekera8f2a4ea2017-05-04 06:15:18 +02001/*
2 *------------------------------------------------------------------
3 * Copyright (c) 2017 Cisco and/or its affiliates.
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at:
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 *------------------------------------------------------------------
16 */
17
18#ifndef VAPI_INTERNAL_H
19#define VAPI_INTERNAL_H
20
Klement Sekeradc15be22017-06-12 06:49:33 +020021#include <endian.h>
Klement Sekera8f2a4ea2017-05-04 06:15:18 +020022#include <string.h>
23#include <vppinfra/types.h>
24
25/**
26 * @file vapi_internal.h
27 *
28 * internal vpp api C declarations
29 *
30 * This file contains internal vpp api C declarations. It's not intended to be
31 * used by the client programmer and the API defined here might change at any
32 * time..
33 */
34
Klement Sekeradc15be22017-06-12 06:49:33 +020035#ifdef __cplusplus
36extern "C" {
37#endif
38
Klement Sekera8f2a4ea2017-05-04 06:15:18 +020039struct vapi_ctx_s;
40
41typedef struct __attribute__ ((__packed__))
42{
43 u16 _vl_msg_id;
44 u32 context;
45} vapi_type_msg_header1_t;
46
47typedef struct __attribute__ ((__packed__))
48{
49 u16 _vl_msg_id;
50 u32 client_index;
51 u32 context;
52} vapi_type_msg_header2_t;
53
54static inline void
55vapi_type_msg_header1_t_hton (vapi_type_msg_header1_t * h)
56{
57 h->_vl_msg_id = htobe16 (h->_vl_msg_id);
58}
59
60static inline void
61vapi_type_msg_header1_t_ntoh (vapi_type_msg_header1_t * h)
62{
63 h->_vl_msg_id = be16toh (h->_vl_msg_id);
64}
65
66static inline void
67vapi_type_msg_header2_t_hton (vapi_type_msg_header2_t * h)
68{
69 h->_vl_msg_id = htobe16 (h->_vl_msg_id);
70}
71
72static inline void
73vapi_type_msg_header2_t_ntoh (vapi_type_msg_header2_t * h)
74{
75 h->_vl_msg_id = be16toh (h->_vl_msg_id);
76}
77
78
Klement Sekeradc15be22017-06-12 06:49:33 +020079#include <vapi/vapi.h>
Klement Sekera8f2a4ea2017-05-04 06:15:18 +020080
81typedef vapi_error_e (*vapi_cb_t) (struct vapi_ctx_s *, void *, vapi_error_e,
82 bool, void *);
83
84typedef void (*generic_swap_fn_t) (void *payload);
Klement Sekeraa25ce962021-11-15 15:52:37 +010085typedef int (*verify_msg_size_fn_t) (void *msg, uword buf_size);
Klement Sekera8f2a4ea2017-05-04 06:15:18 +020086
87typedef struct
88{
89 const char *name;
90 size_t name_len;
91 const char *name_with_crc;
92 size_t name_with_crc_len;
93 bool has_context;
Neale Rannsfd67ece2017-11-02 11:59:14 -070094 unsigned int context_offset;
95 unsigned int payload_offset;
Klement Sekeraa25ce962021-11-15 15:52:37 +010096 verify_msg_size_fn_t verify_msg_size;
Klement Sekera8f2a4ea2017-05-04 06:15:18 +020097 generic_swap_fn_t swap_to_be;
98 generic_swap_fn_t swap_to_host;
99 vapi_msg_id_t id; /* assigned at run-time */
100} vapi_message_desc_t;
101
102typedef struct
103{
104 const char *name;
105 int payload_offset;
106 size_t size;
107 void (*swap_to_be) (void *payload);
108 void (*swap_to_host) (void *payload);
109} vapi_event_desc_t;
110
Klement Sekera8f2a4ea2017-05-04 06:15:18 +0200111vapi_msg_id_t vapi_register_msg (vapi_message_desc_t * msg);
112u16 vapi_lookup_vl_msg_id (vapi_ctx_t ctx, vapi_msg_id_t id);
Klement Sekeradc15be22017-06-12 06:49:33 +0200113vapi_msg_id_t vapi_lookup_vapi_msg_id_t (vapi_ctx_t ctx, u16 vl_msg_id);
Klement Sekera8f2a4ea2017-05-04 06:15:18 +0200114int vapi_get_client_index (vapi_ctx_t ctx);
115bool vapi_is_nonblocking (vapi_ctx_t ctx);
Klement Sekeradc15be22017-06-12 06:49:33 +0200116bool vapi_requests_empty (vapi_ctx_t ctx);
Klement Sekera8f2a4ea2017-05-04 06:15:18 +0200117bool vapi_requests_full (vapi_ctx_t ctx);
118size_t vapi_get_request_count (vapi_ctx_t ctx);
119size_t vapi_get_max_request_count (vapi_ctx_t ctx);
120u32 vapi_gen_req_context (vapi_ctx_t ctx);
121void vapi_store_request (vapi_ctx_t ctx, u32 context, bool is_dump,
122 vapi_cb_t callback, void *callback_ctx);
123int vapi_get_payload_offset (vapi_msg_id_t id);
124void (*vapi_get_swap_to_host_func (vapi_msg_id_t id)) (void *payload);
125void (*vapi_get_swap_to_be_func (vapi_msg_id_t id)) (void *payload);
Klement Sekera8f2a4ea2017-05-04 06:15:18 +0200126size_t vapi_get_context_offset (vapi_msg_id_t id);
Klement Sekeradc15be22017-06-12 06:49:33 +0200127bool vapi_msg_is_with_context (vapi_msg_id_t id);
128size_t vapi_get_message_count();
129const char *vapi_get_msg_name(vapi_msg_id_t id);
Klement Sekera8f2a4ea2017-05-04 06:15:18 +0200130
131vapi_error_e vapi_producer_lock (vapi_ctx_t ctx);
132vapi_error_e vapi_producer_unlock (vapi_ctx_t ctx);
133
Klement Sekeradc15be22017-06-12 06:49:33 +0200134#ifdef __cplusplus
135}
136#endif
137
Klement Sekera8f2a4ea2017-05-04 06:15:18 +0200138#endif