diff options
author | Mauro Sardara <msardara@cisco.com> | 2020-03-24 17:34:14 +0000 |
---|---|---|
committer | Mauro Sardara <msardara@cisco.com> | 2020-09-14 17:31:15 +0000 |
commit | 88509fe353767cbde707c3e3b1f29392957819f3 (patch) | |
tree | cccd51bac7966cd3138c525e8075d90341184a66 /libtransport | |
parent | d875ae92a7fa1eaab3bc2616aeeedfc64a81fea4 (diff) |
[HICN-574] Host stack plugin for VPP.
Signed-off-by: Mauro Sardara <msardara@cisco.com>
Change-Id: I8d8fdffef31a7013265d6529c5f52f3d5ec70d18
Signed-off-by: Mauro Sardara <msardara@cisco.com>
Signed-off-by: Mauro <you@example.com>
Signed-off-by: Mauro Sardara <msardara@cisco.com>
Diffstat (limited to 'libtransport')
-rw-r--r-- | libtransport/includes/hicn/transport/protocols/CMakeLists.txt | 20 | ||||
-rw-r--r-- | libtransport/includes/hicn/transport/protocols/transport_algorithm.h (renamed from libtransport/src/protocols/transport_algorithm.h) | 24 | ||||
-rw-r--r-- | libtransport/src/CMakeLists.txt | 4 | ||||
-rw-r--r-- | libtransport/src/protocols/CMakeLists.txt | 1 | ||||
-rw-r--r-- | libtransport/src/protocols/raaqm_transport_algorithm.h | 2 | ||||
-rw-r--r-- | libtransport/src/protocols/transport_algorithm.cc | 19 |
6 files changed, 46 insertions, 24 deletions
diff --git a/libtransport/includes/hicn/transport/protocols/CMakeLists.txt b/libtransport/includes/hicn/transport/protocols/CMakeLists.txt new file mode 100644 index 000000000..5d8fc69b2 --- /dev/null +++ b/libtransport/includes/hicn/transport/protocols/CMakeLists.txt @@ -0,0 +1,20 @@ +# Copyright (c) 2017-2019 Cisco and/or its affiliates. +# 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. + +cmake_minimum_required(VERSION 3.5 FATAL_ERROR) + +list(APPEND HEADER_FILES + ${CMAKE_CURRENT_SOURCE_DIR}/transport_algorithm.h +) + +set(HEADER_FILES ${HEADER_FILES} PARENT_SCOPE)
\ No newline at end of file diff --git a/libtransport/src/protocols/transport_algorithm.h b/libtransport/includes/hicn/transport/protocols/transport_algorithm.h index 5dacdb3e0..f5c8cf415 100644 --- a/libtransport/src/protocols/transport_algorithm.h +++ b/libtransport/includes/hicn/transport/protocols/transport_algorithm.h @@ -17,7 +17,6 @@ #define transport_algorithm_h #include <hicn/header.h> -#include <hicn/transport/interfaces/socket_options_keys.h> #include <stddef.h> #include <stdint.h> @@ -38,7 +37,7 @@ class TransportAlgorithm { virtual void sessionEnd() = 0; }; -using transport::interface::TransportProtocolAlgorithms; +extern "C" { #else typedef void *TransportAlgorithm; @@ -47,22 +46,27 @@ typedef void *TransportAlgorithm; typedef void *(allocator_t)(size_t size); typedef void *(deallocator_t)(void *ptr); -extern "C" void transportAlgorithm_Init(allocator_t *allocator, - deallocator_t *deallocator); +void transportAlgorithm_Init(allocator_t *allocator, + deallocator_t *deallocator); -extern "C" TransportAlgorithm *transportAlgorithm_CreateRaaqm( +TransportAlgorithm *transportAlgorithm_CreateRaaqm( double drop_factor, double minimum_drop_probability, double gamma, double beta, uint32_t sample_number, uint32_t interest_lifetime, double beta_wifi, double drop_wifi, double beta_lte, double drop_lte, unsigned int wifi_delay, unsigned int lte_delay, double max_window, double min_window); -extern "C" void transportAlgorithm_Destroy(TransportAlgorithm *algorithm); +void transportAlgorithm_Destroy(TransportAlgorithm *algorithm); -extern "C" uint32_t transportAlgorithm_OnContentObject( - TransportAlgorithm *algorithm, uint32_t suffix, uint32_t path_label); +uint32_t transportAlgorithm_OnContentObject(TransportAlgorithm *algorithm, + uint32_t suffix, + uint32_t path_label); -extern "C" uint32_t transportAlgorithm_OnInterestTimeout( - TransportAlgorithm *algorithm, uint32_t suffix); +uint32_t transportAlgorithm_OnInterestTimeout(TransportAlgorithm *algorithm, + uint32_t suffix); + +#ifdef __cplusplus +} /* __cplusplus */ +#endif #endif /* transport_algorithm_h */
\ No newline at end of file diff --git a/libtransport/src/CMakeLists.txt b/libtransport/src/CMakeLists.txt index c10f3da5a..f1544cf8d 100644 --- a/libtransport/src/CMakeLists.txt +++ b/libtransport/src/CMakeLists.txt @@ -68,7 +68,7 @@ if (DISABLE_SHARED_LIBRARIES) DEPENDS ${DEPENDENCIES} COMPONENT lib${LIBTRANSPORT} INCLUDE_DIRS ${LIBTRANSPORT_INCLUDE_DIRS} ${LIBTRANSPORT_INTERNAL_INCLUDE_DIRS} - INSTALL_ROOT_DIR hicn/transport + HEADER_ROOT_DIR hicn/transport DEFINITIONS ${COMPILER_DEFINITIONS} ) else () @@ -80,7 +80,7 @@ else () DEPENDS ${DEPENDENCIES} COMPONENT lib${LIBTRANSPORT} INCLUDE_DIRS ${LIBTRANSPORT_INCLUDE_DIRS} ${LIBTRANSPORT_INTERNAL_INCLUDE_DIRS} - INSTALL_ROOT_DIR hicn/transport + HEADER_ROOT_DIR hicn/transport DEFINITIONS ${COMPILER_DEFINITIONS} ) endif () diff --git a/libtransport/src/protocols/CMakeLists.txt b/libtransport/src/protocols/CMakeLists.txt index 02e626840..6dc1a0737 100644 --- a/libtransport/src/protocols/CMakeLists.txt +++ b/libtransport/src/protocols/CMakeLists.txt @@ -33,7 +33,6 @@ list(APPEND HEADER_FILES ${CMAKE_CURRENT_SOURCE_DIR}/verification_manager.h ${CMAKE_CURRENT_SOURCE_DIR}/data_processing_events.h ${CMAKE_CURRENT_SOURCE_DIR}/raaqm_transport_algorithm.h - ${CMAKE_CURRENT_SOURCE_DIR}/transport_algorithm.h ) list(APPEND SOURCE_FILES diff --git a/libtransport/src/protocols/raaqm_transport_algorithm.h b/libtransport/src/protocols/raaqm_transport_algorithm.h index 5b0b5c05c..eaa65d2a6 100644 --- a/libtransport/src/protocols/raaqm_transport_algorithm.h +++ b/libtransport/src/protocols/raaqm_transport_algorithm.h @@ -17,11 +17,11 @@ #include <hicn/transport/interfaces/socket_options_default_values.h> #include <hicn/transport/interfaces/statistics.h> +#include <hicn/transport/protocols/transport_algorithm.h> #include <hicn/transport/utils/chrono_typedefs.h> #include <protocols/congestion_window_protocol.h> #include <protocols/raaqm_data_path.h> #include <protocols/rate_estimation.h> -#include <protocols/transport_algorithm.h> #include <array> #include <queue> diff --git a/libtransport/src/protocols/transport_algorithm.cc b/libtransport/src/protocols/transport_algorithm.cc index 2b8d60934..37dbf5453 100644 --- a/libtransport/src/protocols/transport_algorithm.cc +++ b/libtransport/src/protocols/transport_algorithm.cc @@ -13,9 +13,9 @@ * limitations under the License. */ +#include <hicn/transport/protocols/transport_algorithm.h> #include <hicn/transport/utils/log.h> #include <protocols/raaqm_transport_algorithm.h> -#include <protocols/transport_algorithm.h> #include <stdexcept> @@ -44,17 +44,17 @@ void custom_deallocate(void *p) { } // namespace -void transportAlgorithm_Init(allocator_t *allocator, - deallocator_t *deallocator) { +extern "C" void transportAlgorithm_Init(allocator_t *allocator, + deallocator_t *deallocator) { algorithm_allocator = allocator; algorithm_deallocator = deallocator; } -void transportAlgorithm_Destroy(TransportAlgorithm *algorithm) { +extern "C" void transportAlgorithm_Destroy(TransportAlgorithm *algorithm) { custom_deallocate(algorithm); } -TransportAlgorithm *transportAlgorithm_CreateRaaqm( +extern "C" TransportAlgorithm *transportAlgorithm_CreateRaaqm( double drop_factor, double minimum_drop_probability, double gamma, double beta, uint32_t sample_number, uint32_t interest_lifetime, double beta_wifi, double drop_wifi, double beta_lte, double drop_lte, @@ -71,13 +71,12 @@ TransportAlgorithm *transportAlgorithm_CreateRaaqm( return ret; } -uint32_t transportAlgorithm_OnContentObject(TransportAlgorithm *algorithm, - uint32_t suffix, - uint32_t path_label) { +extern "C" uint32_t transportAlgorithm_OnContentObject( + TransportAlgorithm *algorithm, uint32_t suffix, uint32_t path_label) { return algorithm->onContentObject(suffix, path_label); } -uint32_t transportAlgorithm_OnInterestTimeout(TransportAlgorithm *algorithm, - uint32_t suffix) { +extern "C" uint32_t transportAlgorithm_OnInterestTimeout( + TransportAlgorithm *algorithm, uint32_t suffix) { return algorithm->onInterestTimeout(suffix); }
\ No newline at end of file |