2008-11-03 18:59:59 +00:00
/*
* Copyright ( C ) 2001 - 2004 Sistina Software , Inc . All rights reserved .
* Copyright ( C ) 2004 - 2007 Red Hat , Inc . All rights reserved .
*
* This file is part of LVM2 .
*
* This copyrighted material is made available to anyone wishing to use ,
* modify , copy , or redistribute it subject to the terms and conditions
* of the GNU Lesser General Public License v .2 .1 .
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program ; if not , write to the Free Software Foundation ,
2016-01-21 11:49:46 +01:00
* Inc . , 51 Franklin Street , Fifth Floor , Boston , MA 02110 - 1301 USA
2008-11-03 18:59:59 +00:00
*/
/*
2018-06-08 13:01:41 +01:00
* This file must be included first by every library source file .
2008-11-03 18:59:59 +00:00
*/
# ifndef _DM_LIB_H
# define _DM_LIB_H
2018-06-08 13:01:41 +01:00
/*
* Symbol export control macros
*
2021-04-03 21:49:37 +02:00
* DM_EXPORT_NEW_SYMBOL ( rettype , func , ver )
2018-06-08 13:01:41 +01:00
* DM_EXPORT_SYMBOL ( func , ver )
* DM_EXPORT_SYMBOL_BASE ( func , ver )
*
* For functions that have multiple implementations these macros control
* symbol export and versioning .
*
* Function definitions that exist in only one version never need to use
* these macros .
*
* Backwards compatible implementations must include a version tag of
* the form " _v1_02_104 " as a suffix to the function name and use the
* macro DM_EXPORT_SYMBOL to export the function and bind it to the
* specified version string .
*
* Since versioning is only available when compiling with GCC the entire
2021-03-29 21:46:12 +02:00
* compatibility version should be enclosed in ' # if defined ( GNU_SYMVER ) ' ,
2018-06-08 13:01:41 +01:00
* for example :
*
2021-04-03 21:49:37 +02:00
* DM_EXPORT_NEW_SYMBOL ( int , dm_foo , 1 _02_107 ) ( int bar )
2018-06-08 13:01:41 +01:00
* {
* return bar ;
* }
*
2021-04-03 21:49:37 +02:00
* # if defined ( GNU_SYMVER )
2018-06-08 13:01:41 +01:00
* // Backward compatible dm_foo() version 1.02.104
2021-04-03 21:49:37 +02:00
* DM_EXPORT_SYMBOL ( dm_foo , 1 _02_104 )
2018-06-08 13:01:41 +01:00
* int dm_foo_v1_02_104 ( void ) ;
* int dm_foo_v1_02_104 ( void )
* {
* return 0 ;
* }
* # endif
*
* A prototype for the compatibility version is required as these
* functions must not be declared static .
*
* The DM_EXPORT_SYMBOL_BASE macro is only used to export the base
* versions of library symbols prior to the introduction of symbol
* versioning : it must never be used for new symbols .
*/
2021-03-29 21:46:12 +02:00
# if defined(GNU_SYMVER)
2021-04-03 21:49:37 +02:00
# ifdef __has_attribute
# if __has_attribute(symver)
# define DM_EXPORT_NEW_SYMBOL(rettype, func, ver) \
__attribute__ ( ( __symver__ ( # func " @@DM_ " # ver ) ) ) \
__typeof__ ( func ) func # # _v # # ver ; \
rettype func # # _v # # ver
# define DM_EXPORT_SYMBOL(func, ver) \
__attribute__ ( ( __symver__ ( # func " @DM_ " # ver ) ) )
# define DM_EXPORT_SYMBOL_BASE(func) \
__attribute__ ( ( __symver__ ( # func " @Base " ) ) )
# endif
# endif
# ifndef DM_EXPORT_NEW_SYMBOL
2021-04-06 22:31:23 +02:00
# define DM_EXPORT_NEW_SYMBOL(rettype, func, ver) \
__typeof__ ( func ) func # # _v # # ver ; \
__asm__ ( " .symver " # func " _v " # ver " , " # func " @@DM_ " # ver ) ; \
rettype func # # _v # # ver
2018-06-08 13:01:41 +01:00
# define DM_EXPORT_SYMBOL(func, ver) \
2021-04-03 21:49:37 +02:00
__asm__ ( " .symver " # func " _v " # ver " , " # func " @DM_ " # ver ) ;
2018-06-08 13:01:41 +01:00
# define DM_EXPORT_SYMBOL_BASE(func) \
2021-04-03 21:49:37 +02:00
__asm__ ( " .symver " # func " _base, " # func " @Base " ) ;
# endif
2018-06-08 13:01:41 +01:00
# else
2021-04-03 21:49:37 +02:00
# define DM_EXPORT_NEW_SYMBOL(rettype, func, ver) rettype func
2018-06-08 13:01:41 +01:00
# define DM_EXPORT_SYMBOL(func, ver)
# define DM_EXPORT_SYMBOL_BASE(func)
# endif
2021-03-29 22:43:36 +02:00
# include "libdm/dm-tools/util.h"
2018-06-08 13:01:41 +01:00
# include "libdm/libdevmapper.h"
# include "libdm/misc/dm-logging.h"
# include <unistd.h>
2008-11-03 18:59:59 +00:00
# endif