diff options
author | Paul Kehrer <paul.l.kehrer@gmail.com> | 2013-12-31 08:56:58 -0800 |
---|---|---|
committer | Paul Kehrer <paul.l.kehrer@gmail.com> | 2013-12-31 08:56:58 -0800 |
commit | 7580acddc654ee5da73a7cd43023e07b6c92673e (patch) | |
tree | 76899b8174ed396df9834c0dc9d9ab40cf55242d /docs | |
parent | fbd7ffcdcda0269a654ebf373d4ec5f1e6d6d3f4 (diff) | |
parent | e68d73e37be57774246165a5d5263c89825e0864 (diff) | |
download | cryptography-7580acddc654ee5da73a7cd43023e07b6c92673e.tar.gz cryptography-7580acddc654ee5da73a7cd43023e07b6c92673e.tar.bz2 cryptography-7580acddc654ee5da73a7cd43023e07b6c92673e.zip |
Merge pull request #381 from public/compile-openssl-docs
Document compiling OpenSSL to avoid conflicts
Diffstat (limited to 'docs')
-rw-r--r-- | docs/hazmat/backends/openssl.rst | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/docs/hazmat/backends/openssl.rst b/docs/hazmat/backends/openssl.rst index 5e51c75e..99b327d9 100644 --- a/docs/hazmat/backends/openssl.rst +++ b/docs/hazmat/backends/openssl.rst @@ -21,5 +21,32 @@ These are `CFFI`_ bindings to the `OpenSSL`_ C library. and access constants. +Using your own OpenSSL on Linux +------------------------------- + +Python links to OpenSSL for its own purposes and this can sometimes cause +problems when you wish to use a different version of OpenSSL with cryptography. +If you want to use cryptography with your own build of OpenSSL you will need to +make sure that the build is configured correctly so that your version of +OpenSSL doesn't conflict with Python's. + +The options you need to add allow the linker to identify every symbol correctly +even when multiple versions of the library are linked into the same program. If +you are using your distribution's source packages these will probably be +patched in for you already, otherwise you'll need to use options something like +this when configuring OpenSSL:: + + ./config -Wl,--version-script=openssl.ld -Wl,-Bsymbolic-functions -fPIC shared + +You'll also need to generate your own ``openssl.ld`` file. For example:: + + OPENSSL_1.0.1F_CUSTOM { + global: + *; + }; + +You should replace the version string on the first line as appropriate for your +build. + .. _`CFFI`: https://cffi.readthedocs.org/ .. _`OpenSSL`: https://www.openssl.org/ |