Add DLL exports. #223
pull evoskuil wants to merge 3 commits into bitcoin-core:master from evoskuil:dll-exports changing 5 files +62 −0-
evoskuil commented at 10:34 pm on February 23, 2015: contributor
-
gmaxwell added this to the milestone initial release on Aug 31, 2015
-
Add visibility hidden attribute to non-MSVC statics, rebase. 36daecf5c6
-
in include/secp256k1.h: in d29e19bebe outdated
53+# endif 54+# endif 55+ 56+# if defined SECP256K1_STATIC 57+# define SECP256K1_API 58+# elif defined SECP256K1_DLL
chfast commented at 2:16 pm on September 14, 2015:CMake has a convention to add macroMyLibrary_EXPORTS
when building a DLL. Is it possible to renameSECP256K1_DLL
toSECP256K1_EXPORTS
?
evoskuil commented at 6:05 pm on September 14, 2015:Certainly, the symbol is otherwise arbitrary.
theuni commented at 10:45 pm on September 14, 2015:Sounds good to me.
I think this should be
__attribute__ ((visibility ("hidden")))
in theSECP256K1_STATIC
case though, since it wouldn’t need to be externally visible
evoskuil commented at 11:06 pm on September 14, 2015:Good idea…
0 define SECP256K1_HELPER_DLL_EXPORT __declspec(dllexport) 1else 2 if __GNUC__ >= 4 3 define SECP256K1_HELPER_DLL_IMPORT __attribute__ ((visibility ("default"))) 4 define SECP256K1_HELPER_DLL_EXPORT __attribute__ ((visibility ("default"))) 5 define SECP256K1_HELPER_STATIC __attribute__ ((visibility ("hidden"))) 6 else 7 define SECP256K1_HELPER_DLL_IMPORT 8 define SECP256K1_HELPER_DLL_EXPORT 9 define SECP256K1_HELPER_STATIC 10 endif 11endif 12 13if defined SECP256K1_STATIC 14 define SECP256K1_API SECP256K1_HELPER_STATIC 15elif defined SECP256K1_DLL
in include/secp256k1.h: in d29e19bebe outdated
39@@ -40,6 +40,26 @@ extern "C" { 40 # define SECP256K1_ARG_NONNULL(_x) 41 # endif 42 43+# if defined _MSC_VER || defined __CYGWIN__ 44+# define SECP256K1_HELPER_DLL_IMPORT __declspec(dllimport)
chfast commented at 10:49 pm on September 14, 2015:dllimport is only useful in case of global variables and C++ classes, not in case of functions. Removing dllimport support would simplify the patch.
evoskuil commented at 11:32 pm on September 14, 2015:I’m not sure this is the case. This is an old reference, but I have to assume it still holds:
You do not need to use __declspec(dllimport) for your code to compile correctly, but doing so allows the compiler to generate better code.
https://msdn.microsoft.com/en-us/library/aa271769(v=vs.60).aspx
evoskuil force-pushed on Sep 14, 2015Rename static export helpers and public export symbol, export extern vars. 5c571f3f72Export ecdh, recovery and schnorr APIs. 58fd107baain include/secp256k1.h: in 58fd107baa
152+# elif defined SECP256K1_EXPORTS 153+# define SECP256K1_API SECP256K1_HELPER_DLL_EXPORT 154+# else 155+# define SECP256K1_API SECP256K1_HELPER_DLL_IMPORT 156+# endif 157+
evoskuil commented at 0:14 am on September 15, 2015:The above matches closely the GCC example (bottom of page). There is deviation in the public symbolsSECP256K1_STATIC
andSECP256K1_EXPORTS
. The latter is modified for better CMake integration (see comment by @chfast). WRT the former I consider “static” more explicit than “local” and therefore better for publication.in src/secp256k1.c: in 58fd107baa
253@@ -254,7 +254,10 @@ static int nonce_function_rfc6979(unsigned char *nonce32, const unsigned char *m 254 return 1; 255 } 256 257+SECP256K1_API 258 const secp256k1_nonce_function_t secp256k1_nonce_function_rfc6979 = nonce_function_rfc6979; 259+ 260+SECP256K1_API 261 const secp256k1_nonce_function_t secp256k1_nonce_function_default = nonce_function_rfc6979;
evoskuil commented at 0:16 am on September 15, 2015:I have not had a chance to verify these two lines, but according to documentation it appears correct for both VC and GCC.theuni cross-referenced this on Sep 21, 2015 from issue Use explicit symbol visibility. by gmaxwellevoskuil commented at 2:20 am on September 23, 2015: contributorI prefer the readability of the gcc example layout, and the use ofdllimport
, but not a big deal in either case.sipa commented at 1:51 pm on September 23, 2015: contributorI also think that this fails to set dllexport/import when compiling with MinGW?evoskuil cross-referenced this on Sep 24, 2015 from issue Use explicit symbol visibility. by gmaxwellsipa closed this on Sep 25, 2015
github-metadata-mirror
This is a metadata mirror of the GitHub repository bitcoin-core/secp256k1. This site is not affiliated with GitHub. Content is generated from a GitHub metadata backup.
generated: 2024-12-23 06:15 UTC
This site is hosted by @0xB10C
More mirrored repositories can be found on mirror.b10c.me