@@ -13,6 +13,7 @@
#ifndef ODP_API_ALIGN_H_
#define ODP_API_ALIGN_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -74,4 +75,5 @@ extern "C" {
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,6 +13,7 @@
#ifndef ODP_API_ATOMIC_H_
#define ODP_API_ATOMIC_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -628,4 +629,5 @@ int odp_atomic_lock_free_u64(odp_atomic_op_t *atomic_op);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,6 +13,7 @@
#ifndef ODP_API_BARRIER_H_
#define ODP_API_BARRIER_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -63,4 +64,5 @@ void odp_barrier_wait(odp_barrier_t *barr);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,12 +13,12 @@
#ifndef ODP_API_BUFFER_H_
#define ODP_API_BUFFER_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
#endif
-
/** @defgroup odp_buffer ODP BUFFER
* Operations on a buffer.
* @{
@@ -167,4 +167,5 @@ uint64_t odp_buffer_to_u64(odp_buffer_t hdl);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,6 +13,7 @@
#ifndef ODP_API_BYTEORDER_H_
#define ODP_API_BYTEORDER_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -177,4 +178,5 @@ odp_u64le_t odp_cpu_to_le_64(uint64_t cpu64);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,12 +13,12 @@
#ifndef ODP_API_CLASSIFY_H_
#define ODP_API_CLASSIFY_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
#endif
-
/** @defgroup odp_classification ODP CLASSIFICATION
* Classification operations.
* @{
@@ -396,4 +396,5 @@ uint64_t odp_pmr_to_u64(odp_pmr_t hdl);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,6 +13,7 @@
#ifndef ODP_API_COMPILER_H_
#define ODP_API_COMPILER_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -48,4 +49,5 @@ extern "C" {
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,6 +13,7 @@
#ifndef ODP_API_CONFIG_H_
#define ODP_API_CONFIG_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -161,4 +162,5 @@ int odp_config_shm_blocks(void);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,6 +13,7 @@
#ifndef ODP_CPU_H_
#define ODP_CPU_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -176,4 +177,5 @@ void odp_cpu_pause(void);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,6 +13,7 @@
#ifndef ODP_API_CPUMASK_H_
#define ODP_API_CPUMASK_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -251,4 +252,5 @@ int odp_cpumask_all_available(odp_cpumask_t *mask);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,6 +13,7 @@
#ifndef ODP_API_CRYPTO_H_
#define ODP_API_CRYPTO_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -371,4 +372,5 @@ uint64_t odp_crypto_compl_to_u64(odp_crypto_compl_t hdl);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -11,7 +11,7 @@
#ifndef ODP_API_DEBUG_H_
#define ODP_API_DEBUG_H_
-
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -32,4 +32,5 @@ extern "C" {
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -12,6 +12,7 @@
#ifndef ODP_ERRNO_H_
#define ODP_ERRNO_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -82,4 +83,5 @@ const char *odp_errno_str(int errnum);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,12 +13,12 @@
#ifndef ODP_API_EVENT_H_
#define ODP_API_EVENT_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
#endif
-
/** @defgroup odp_event ODP EVENT
* Operations on an event.
* @{
@@ -83,4 +83,5 @@ void odp_event_free(odp_event_t event);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -12,6 +12,7 @@
#ifndef ODP_API_HASH_H_
#define ODP_API_HASH_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -95,4 +96,5 @@ int odp_hash_crc_gen64(const void *data, uint32_t data_len,
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,6 +13,7 @@
#ifndef ODP_API_HINTS_H_
#define ODP_API_HINTS_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -113,4 +114,5 @@ extern "C" {
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -21,13 +21,12 @@
#ifndef ODP_API_INIT_H_
#define ODP_API_INIT_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
#endif
-
-
#include <odp/api/std_types.h>
#include <odp/api/hints.h>
#include <odp/api/thread.h>
@@ -278,4 +277,5 @@ int odp_term_local(void);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,6 +13,7 @@
#ifndef ODP_API_PACKET_H_
#define ODP_API_PACKET_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -1181,4 +1182,5 @@ uint64_t odp_packet_seg_to_u64(odp_packet_seg_t hdl);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,6 +13,7 @@
#ifndef ODP_API_PACKET_FLAGS_H_
#define ODP_API_PACKET_FLAGS_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -493,4 +494,5 @@ void odp_packet_has_ts_clr(odp_packet_t pkt);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,6 +13,7 @@
#ifndef ODP_API_PACKET_IO_H_
#define ODP_API_PACKET_IO_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -1038,4 +1039,5 @@ odp_time_t odp_pktin_ts_from_ns(odp_pktio_t pktio, uint64_t ns);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -12,6 +12,7 @@
#ifndef ODP_API_PACKET_IO_STATS_H_
#define ODP_API_PACKET_IO_STATS_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -138,4 +139,5 @@ int odp_pktio_stats_reset(odp_pktio_t pktio);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,13 +13,12 @@
#ifndef ODP_API_POOL_H_
#define ODP_API_POOL_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
#endif
-
-
#include <odp/api/std_types.h>
/** @defgroup odp_pool ODP POOL
@@ -210,4 +209,5 @@ void odp_pool_param_init(odp_pool_param_t *param);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,6 +13,7 @@
#ifndef ODP_API_QUEUE_H_
#define ODP_API_QUEUE_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -374,4 +375,5 @@ int odp_queue_info(odp_queue_t queue, odp_queue_info_t *info);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,6 +13,7 @@
#ifndef ODP_API_RANDOM_H_
#define ODP_API_RANDOM_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -22,7 +23,6 @@ extern "C" {
* @{
*/
-
/**
* Generate random byte data
*
@@ -45,4 +45,5 @@ int32_t odp_random_data(uint8_t *buf, int32_t size, odp_bool_t use_entropy);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -6,6 +6,7 @@
#ifndef ODP_API_RWLOCK_H_
#define ODP_API_RWLOCK_H_
+#include <odp/api/abi_begin.h>
/**
* @file
@@ -99,4 +100,5 @@ void odp_rwlock_write_unlock(odp_rwlock_t *rwlock);
}
#endif
+#include <odp/api/abi_end.h>
#endif /* ODP_RWLOCK_H_ */
@@ -12,6 +12,7 @@
#ifndef ODP_API_RWLOCK_RECURSIVE_H_
#define ODP_API_RWLOCK_RECURSIVE_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -117,4 +118,5 @@ void odp_rwlock_recursive_write_unlock(odp_rwlock_recursive_t *lock);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,12 +13,12 @@
#ifndef ODP_API_SCHEDULE_H_
#define ODP_API_SCHEDULE_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
#endif
-
#include <odp/api/std_types.h>
#include <odp/api/event.h>
#include <odp/api/queue.h>
@@ -375,4 +375,5 @@ void odp_schedule_order_unlock(unsigned lock_index);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -12,6 +12,7 @@
#ifndef ODP_API_SCHEDULE_TYPES_H_
#define ODP_API_SCHEDULE_TYPES_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -156,4 +157,5 @@ typedef struct odp_schedule_param_t {
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,12 +13,12 @@
#ifndef ODP_API_SHARED_MEMORY_H_
#define ODP_API_SHARED_MEMORY_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
#endif
-
/** @defgroup odp_shared_memory ODP SHARED MEMORY
* Operations on shared memory.
* @{
@@ -152,4 +152,5 @@ uint64_t odp_shm_to_u64(odp_shm_t hdl);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,6 +13,7 @@
#ifndef ODP_API_SPINLOCK_H_
#define ODP_API_SPINLOCK_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -88,4 +89,5 @@ int odp_spinlock_is_locked(odp_spinlock_t *splock);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -12,6 +12,7 @@
#ifndef ODP_API_SPINLOCK_RECURSIVE_H_
#define ODP_API_SPINLOCK_RECURSIVE_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -82,4 +83,5 @@ int odp_spinlock_recursive_is_locked(odp_spinlock_recursive_t *lock);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -12,6 +12,7 @@
#ifndef ODP_API_STD_CLIB_H_
#define ODP_API_STD_CLIB_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -79,4 +80,5 @@ int odp_memcmp(const void *ptr1, const void *ptr2, size_t num);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -14,12 +14,12 @@
#ifndef ODP_API_STD_TYPES_H_
#define ODP_API_STD_TYPES_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
#endif
-
/** @addtogroup odp_system ODP SYSTEM
* @{
*/
@@ -39,4 +39,5 @@ extern "C" {
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,6 +13,7 @@
#ifndef ODP_API_SYNC_H_
#define ODP_API_SYNC_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -87,4 +88,5 @@ void odp_mb_full(void);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,12 +13,12 @@
#ifndef ODP_API_SYSTEM_INFO_H_
#define ODP_API_SYSTEM_INFO_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
#endif
-
/** @defgroup odp_system ODP SYSTEM
* @{
*/
@@ -52,4 +52,5 @@ int odp_sys_cache_line_size(void);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,6 +13,7 @@
#ifndef ODP_API_THREAD_H_
#define ODP_API_THREAD_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -109,4 +110,5 @@ odp_thread_type_t odp_thread_type(void);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -12,6 +12,7 @@
#ifndef ODP_API_THRMASK_H_
#define ODP_API_THRMASK_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -236,4 +237,5 @@ int odp_thrmask_control(odp_thrmask_t *mask);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,6 +13,7 @@
#ifndef ODP_API_TICKETLOCK_H_
#define ODP_API_TICKETLOCK_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -87,4 +88,5 @@ int odp_ticketlock_is_locked(odp_ticketlock_t *tklock);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,12 +13,12 @@
#ifndef ODP_API_TIME_H_
#define ODP_API_TIME_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
#endif
-
/** @defgroup odp_time ODP TIME
* @{
*/
@@ -178,4 +178,5 @@ uint64_t odp_time_to_u64(odp_time_t time);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,6 +13,7 @@
#ifndef ODP_API_TIMER_H_
#define ODP_API_TIMER_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -412,4 +413,5 @@ uint64_t odp_timeout_to_u64(odp_timeout_t hdl);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -6,6 +6,7 @@
#ifndef ODP_TRAFFIC_MNGR_H_
#define ODP_TRAFFIC_MNGR_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -1371,4 +1372,5 @@ void odp_tm_stats_print(odp_tm_t odp_tm);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -13,6 +13,7 @@
#ifndef ODP_API_VERSION_H_
#define ODP_API_VERSION_H_
+#include <odp/api/abi_begin.h>
#ifdef __cplusplus
extern "C" {
@@ -102,4 +103,5 @@ const char *odp_version_impl_str(void);
}
#endif
+#include <odp/api/abi_end.h>
#endif
@@ -15,6 +15,7 @@ AM_LDFLAGS += -version-number '$(ODP_LIBSO_VERSION)'
GIT_DESC = `$(top_srcdir)/scripts/get_impl_str.sh $(top_srcdir)`
AM_CFLAGS += "-DGIT_HASH=$(GIT_DESC)"
AM_CFLAGS += -DPLATFORM=${with_platform}
+AM_CFLAGS += $(VISIBILITY_CFLAGS)
#The implementation will need to retain the deprecated implementation
AM_CFLAGS += -Wno-deprecated-declarations
new file mode 100644
@@ -0,0 +1,3 @@
+#if __GNUC__ >= 4
+#pragma GCC visibility push(default)
+#endif
new file mode 100644
@@ -0,0 +1,3 @@
+#if __GNUC__ >= 4
+#pragma GCC visibility pop
+#endif
@@ -1,3 +1,15 @@
+# Enable -fvisibility=hidden if using a gcc that supports it
+OLD_CFLAGS="$CFLAGS"
+AC_MSG_CHECKING([whether $CC supports -fvisibility=hidden])
+VISIBILITY_CFLAGS="-fvisibility=hidden"
+CFLAGS="$CFLAGS $VISIBILITY_CFLAGS"
+AC_LINK_IFELSE([AC_LANG_PROGRAM()], AC_MSG_RESULT([yes]),
+ [VISIBILITY_CFLAGS=""; AC_MSG_RESULT([no])]);
+
+AC_SUBST(VISIBILITY_CFLAGS)
+# Restore CFLAGS; VISIBILITY_CFLAGS are added to it where needed.
+CFLAGS=$OLD_CFLAGS
+
AC_MSG_CHECKING(for GCC atomic builtins)
AC_LINK_IFELSE(
[AC_LANG_SOURCE(