Added support for DPDK 19.05 / IPSec
[samplevnf.git] / VNFs / DPPD-PROX / prox_compat.h
1 /*
2 // Copyright (c) 2010-2017 Intel Corporation
3 //
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 #ifndef _PROX_COMPAT_H_
18 #define _PROX_COMPAT_H_
19 #include <rte_common.h>
20 #include <rte_table_hash.h>
21 #include <rte_hash_crc.h>
22 #include <rte_cryptodev.h>
23 #include "hash_utils.h"
24 #include "quit.h"
25
26 /* This is a copy of the rte_table_hash_params from DPDK 17.11  *
27  * So if DPDK decides to change the structure the modifications *
28  * to PROX code should mainly be limited to this file           *
29  */
30 struct prox_rte_table_params {
31         const char *name;
32         uint32_t key_size;
33         uint32_t key_offset;
34         uint8_t *key_mask;
35         uint32_t n_keys;
36         uint32_t n_buckets;
37         rte_table_hash_op_hash f_hash;
38         uint64_t seed;
39 };
40
41 #if RTE_VERSION < RTE_VERSION_NUM(17,11,0,0)
42
43 static void *prox_rte_table_create(struct prox_rte_table_params *params, int socket_id, uint32_t entry_size)
44 {
45         if (params->key_size == 8) {
46                 struct rte_table_hash_key8_ext_params dpdk17_08_params;
47                 dpdk17_08_params.n_entries = params->n_keys;
48                 dpdk17_08_params.n_entries_ext = params->n_keys >> 2;
49                 dpdk17_08_params.f_hash = (rte_table_hash_op_hash)rte_hash_crc;
50                 dpdk17_08_params.seed = params->seed;
51                 dpdk17_08_params.signature_offset = HASH_METADATA_OFFSET(8);  // Ignored for dosig
52                 dpdk17_08_params.key_offset = HASH_METADATA_OFFSET(0);
53                 dpdk17_08_params.key_mask = params->key_mask;
54                 return rte_table_hash_key8_ext_dosig_ops.f_create(&dpdk17_08_params, socket_id, entry_size);
55         } else {
56                 struct rte_table_hash_ext_params dpdk17_08_params;
57                 dpdk17_08_params.key_size = params->key_size;
58                 dpdk17_08_params.n_keys = params->n_keys;
59                 dpdk17_08_params.n_buckets = params->n_buckets;
60                 dpdk17_08_params.n_buckets_ext = params->n_buckets >> 1;
61                 dpdk17_08_params.seed = params->seed;
62                 dpdk17_08_params.f_hash = (rte_table_hash_op_hash)rte_hash_crc;
63                 dpdk17_08_params.signature_offset = HASH_METADATA_OFFSET(0);
64                 dpdk17_08_params.key_offset = HASH_METADATA_OFFSET(0);
65                 return rte_table_hash_ext_dosig_ops.f_create(&dpdk17_08_params, socket_id, entry_size);
66         }
67 };
68
69 #define prox_rte_table_free        rte_table_hash_ext_dosig_ops.f_free
70 #define prox_rte_table_add         rte_table_hash_ext_dosig_ops.f_add
71 #define prox_rte_table_delete      rte_table_hash_ext_dosig_ops.f_delete
72 #define prox_rte_table_add_bulk    rte_table_hash_ext_dosig_ops.f_add_bulk
73 #define prox_rte_table_delete_bulk rte_table_hash_ext_dosig_ops.f_delete_bulk
74 #define prox_rte_table_lookup      rte_table_hash_ext_dosig_ops.f_lookup
75 #define prox_rte_table_stats       rte_table_hash_ext_dosig_ops.f_stats
76
77 #define prox_rte_table_key8_free        rte_table_hash_key8_ext_dosig_ops.f_free
78 #define prox_rte_table_key8_add         rte_table_hash_key8_ext_dosig_ops.f_add
79 #define prox_rte_table_key8_delete      rte_table_hash_key8_ext_dosig_ops.f_delete
80 #define prox_rte_table_key8_add_bulk    rte_table_hash_key8_ext_dosig_ops.f_add_bulk
81 #define prox_rte_table_key8_delete_bulk rte_table_hash_key8_ext_dosig_ops.f_delete_bulk
82 #define prox_rte_table_key8_lookup      rte_table_hash_key8_ext_dosig_ops.f_lookup
83 #define prox_rte_table_key8_stats       rte_table_hash_key8_ext_dosig_ops.f_stats
84
85 #define rte_log_set_global_level rte_set_log_level
86
87 #else
88
89 static void *prox_rte_table_create(struct prox_rte_table_params *params, int socket_id, uint32_t entry_size)
90 {
91         struct rte_table_hash_params dpdk_17_11_params;
92         dpdk_17_11_params.name = params->name;
93         dpdk_17_11_params.key_size = params->key_size;
94         dpdk_17_11_params.key_offset = params->key_offset;
95         dpdk_17_11_params.key_mask = params->key_mask;
96         dpdk_17_11_params.n_keys = params->n_keys;
97         dpdk_17_11_params.n_buckets = rte_align32pow2(params->n_buckets);
98         dpdk_17_11_params.f_hash = params->f_hash;
99         dpdk_17_11_params.seed = params->seed;
100
101         if (params->key_size == 8) {
102                 return rte_table_hash_key8_ext_ops.f_create(&dpdk_17_11_params, socket_id, entry_size);
103         } else {
104                 return rte_table_hash_ext_ops.f_create(&dpdk_17_11_params, socket_id, entry_size);
105         }
106 }
107
108 #define prox_rte_table_free        rte_table_hash_ext_ops.f_free
109 #define prox_rte_table_add         rte_table_hash_ext_ops.f_add
110 #define prox_rte_table_delete      rte_table_hash_ext_ops.f_delete
111 #define prox_rte_table_add_bulk    rte_table_hash_ext_ops.f_add_bulk
112 #define prox_rte_table_delete_bulk rte_table_hash_ext_ops.f_delete_bulk
113 #define prox_rte_table_lookup      rte_table_hash_ext_ops.f_lookup
114 #define prox_rte_table_stats       rte_table_hash_ext_ops.f_stats
115
116 #define prox_rte_table_key8_free        rte_table_hash_key8_ext_ops.f_free
117 #define prox_rte_table_key8_add         rte_table_hash_key8_ext_ops.f_add
118 #define prox_rte_table_key8_delete      rte_table_hash_key8_ext_ops.f_delete
119 #define prox_rte_table_key8_add_bulk    rte_table_hash_key8_ext_ops.f_add_bulk
120 #define prox_rte_table_key8_delete_bulk rte_table_hash_key8_ext_ops.f_delete_bulk
121 #define prox_rte_table_key8_lookup      rte_table_hash_key8_ext_ops.f_lookup
122 #define prox_rte_table_key8_stats       rte_table_hash_key8_ext_ops.f_stats
123
124 #endif
125
126 #if RTE_VERSION < RTE_VERSION_NUM(18,8,0,0)
127 #define rte_cryptodev_sym_get_private_session_size rte_cryptodev_get_private_session_size
128 #endif
129
130 #ifndef DEV_RX_OFFLOAD_JUMBO_FRAME
131 #define DEV_RX_OFFLOAD_JUMBO_FRAME 0x00000800
132 #endif
133
134 #ifndef DEV_RX_OFFLOAD_KEEP_CRC
135 #ifndef DEV_RX_OFFLOAD_CRC_STRIP
136 #define DEV_RX_OFFLOAD_CRC_STRIP 0x00001000
137 #endif
138 #endif
139
140 #if RTE_VERSION < RTE_VERSION_NUM(19,2,0,0)
141 #define RTE_COLOR_GREEN e_RTE_METER_GREEN
142 #define RTE_COLOR_YELLOW e_RTE_METER_YELLOW
143 #define RTE_COLOR_RED e_RTE_METER_RED
144 #define prox_rte_color rte_meter_color
145 #define prox_rte_sched_port_pkt_read_tree_path(A,B,C,D,E,F) rte_sched_port_pkt_read_tree_path(B,C,D,E,F)
146 #define prox_rte_sched_port_pkt_write(A,B,C,D,E,F,G) rte_sched_port_pkt_write(B,C,D,E,F,G);
147 #else
148 #define prox_rte_color rte_color
149 #define prox_rte_sched_port_pkt_read_tree_path(A,B,C,D,E,F) rte_sched_port_pkt_read_tree_path(A,B,C,D,E,F)
150 #define prox_rte_sched_port_pkt_write(A,B,C,D,E,F,G) rte_sched_port_pkt_write(A,B,C,D,E,F,G);
151 #endif
152
153 static inline char *prox_strncpy(char * dest, const char * src, size_t count)
154 {
155 #pragma GCC diagnostic push
156 #pragma GCC diagnostic ignored "-Wpragmas"
157 #pragma GCC diagnostic ignored "-Wstringop-truncation"
158         strncpy(dest, src, count);
159 #pragma GCC diagnostic pop
160         PROX_PANIC(dest[count - 1] != 0, "\t\tError in strncpy: buffer overrun (%lu bytes)", count);
161         return dest;
162 }
163 #ifdef RTE_LIBRTE_PMD_AESNI_MB
164 #if RTE_VERSION < RTE_VERSION_NUM(19,5,0,0)
165 //RFC4303
166 struct prox_esp_hdr {
167         uint32_t spi;
168         uint32_t seq;
169 };
170 struct prox_rte_cryptodev_qp_conf {
171         uint32_t nb_descriptors; /**< Number of descriptors per queue pair */
172         struct rte_mempool *    mp_session;
173         struct rte_mempool *    mp_session_private;
174 };
175
176 static int prox_rte_cryptodev_queue_pair_setup(uint8_t dev_id, uint16_t queue_pair_id, struct prox_rte_cryptodev_qp_conf *qp_conf, int socket_id)
177 {
178         struct rte_mempool *session_pool = qp_conf->mp_session;
179         return rte_cryptodev_queue_pair_setup(dev_id, queue_pair_id, (struct rte_cryptodev_qp_conf *)qp_conf, socket_id, session_pool);
180 }
181
182 #else
183 #define prox_esp_hdr esp_hdr
184 #define prox_rte_cryptodev_qp_conf rte_cryptodev_qp_conf
185
186 static int prox_rte_cryptodev_queue_pair_setup(uint8_t dev_id, uint16_t queue_pair_id, struct prox_rte_cryptodev_qp_conf *qp_conf, int socket_id)
187 {
188         return rte_cryptodev_queue_pair_setup(dev_id, queue_pair_id, (struct rte_cryptodev_qp_conf *)qp_conf, socket_id);
189 }
190
191 #endif
192 #endif  // CONFIG_RTE_LIBRTE_PMD_AESNI_MB
193
194 #endif // _PROX_COMPAT_H