| 
									
										
										
										
											2021-02-02 01:57:40 +08:00
										 |  |  | Notes for UNIX-like platforms | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  | ============================= | 
					
						
							| 
									
										
										
										
											2017-03-02 06:43:03 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  |  For Unix/POSIX runtime systems on Windows, | 
					
						
							| 
									
										
										
										
											2021-02-02 01:57:40 +08:00
										 |  |  |  please see the [Notes for Windows platforms](NOTES-WINDOWS.md). | 
					
						
							| 
									
										
										
										
											2017-03-02 06:43:03 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-19 19:03:55 +08:00
										 |  |  |  OpenSSL uses the compiler to link programs and shared libraries | 
					
						
							|  |  |  |  --------------------------------------------------------------- | 
					
						
							| 
									
										
										
										
											2017-03-02 06:43:03 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-19 19:03:55 +08:00
										 |  |  |  OpenSSL's generated Makefile uses the C compiler command line to | 
					
						
							|  |  |  |  link programs, shared libraries and dynamically loadable shared | 
					
						
							|  |  |  |  objects.  Because of this, any linking option that's given to the | 
					
						
							|  |  |  |  configuration scripts MUST be in a form that the compiler can accept. | 
					
						
							|  |  |  |  This varies between systems, where some have compilers that accept | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  |  linker flags directly, while others take them in `-Wl,` form.  You need | 
					
						
							| 
									
										
										
										
											2018-06-19 19:03:55 +08:00
										 |  |  |  to read your compiler documentation to figure out what is acceptable, | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  |  and `ld(1)` to figure out what linker options are available. | 
					
						
							| 
									
										
										
										
											2017-03-02 06:43:03 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-19 19:03:55 +08:00
										 |  |  |  Shared libraries and installation in non-default locations | 
					
						
							|  |  |  |  ---------------------------------------------------------- | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  Every Unix system has its own set of default locations for shared | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  |  libraries, such as `/lib`, `/usr/lib` or possibly `/usr/local/lib`.  If | 
					
						
							| 
									
										
										
										
											2018-06-19 19:03:55 +08:00
										 |  |  |  libraries are installed in non-default locations, dynamically linked | 
					
						
							| 
									
										
										
										
											2018-06-22 20:13:59 +08:00
										 |  |  |  binaries will not find them and therefore fail to run, unless they get | 
					
						
							|  |  |  |  a bit of help from a defined runtime shared library search path. | 
					
						
							| 
									
										
										
										
											2018-06-19 19:03:55 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  |  For OpenSSL's application (the `openssl` command), our configuration | 
					
						
							| 
									
										
										
										
											2018-06-19 19:03:55 +08:00
										 |  |  |  scripts do NOT generally set the runtime shared library search path for | 
					
						
							| 
									
										
										
										
											2018-06-22 20:13:59 +08:00
										 |  |  |  you.  It's therefore advisable to set it explicitly when configuring, | 
					
						
							| 
									
										
										
										
											2018-06-19 19:03:55 +08:00
										 |  |  |  unless the libraries are to be installed in directories that you know | 
					
						
							|  |  |  |  to be in the default list. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  Runtime shared library search paths are specified with different | 
					
						
							|  |  |  |  linking options depending on operating system and versions thereof, and | 
					
						
							|  |  |  |  are talked about differently in their respective documentation; | 
					
						
							|  |  |  |  variations of RPATH are the most usual (note: ELF systems have two such | 
					
						
							|  |  |  |  tags, more on that below). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  Possible options to set the runtime shared library search path include | 
					
						
							|  |  |  |  the following: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  |     -Wl,-rpath,/whatever/path   # Linux, *BSD, etc. | 
					
						
							|  |  |  |     -R /whatever/path           # Solaris | 
					
						
							|  |  |  |     -Wl,-R,/whatever/path       # AIX (-bsvr4 is passed internally) | 
					
						
							|  |  |  |     -Wl,+b,/whatever/path       # HP-UX | 
					
						
							|  |  |  |     -rpath /whatever/path       # Tru64, IRIX | 
					
						
							| 
									
										
										
										
											2018-02-15 17:06:15 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-19 19:03:55 +08:00
										 |  |  |  OpenSSL's configuration scripts recognise all these options and pass | 
					
						
							| 
									
										
										
										
											2018-06-22 20:13:59 +08:00
										 |  |  |  them to the Makefile that they build. (In fact, all arguments starting | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  |  with `-Wl,` are recognised as linker options.) | 
					
						
							| 
									
										
										
										
											2018-06-19 19:03:55 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |  Please do not use verbatim directories in your runtime shared library | 
					
						
							|  |  |  |  search path!  Some OpenSSL config targets add an extra directory level | 
					
						
							|  |  |  |  for multilib installations.  To help with that, the produced Makefile | 
					
						
							|  |  |  |  includes the variable LIBRPATH, which is a convenience variable to be | 
					
						
							|  |  |  |  used with the runtime shared library search path options, as shown in | 
					
						
							|  |  |  |  this example: | 
					
						
							| 
									
										
										
										
											2018-02-15 17:06:15 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-04 00:20:07 +08:00
										 |  |  |     $ ./Configure --prefix=/usr/local/ssl --openssldir=/usr/local/ssl \ | 
					
						
							| 
									
										
										
										
											2018-06-19 19:03:55 +08:00
										 |  |  |         '-Wl,-rpath,$(LIBRPATH)' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  On modern ELF based systems, there are two runtime search paths tags to | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  |  consider, `DT_RPATH` and `DT_RUNPATH`.  Shared objects are searched for in | 
					
						
							| 
									
										
										
										
											2018-06-19 19:03:55 +08:00
										 |  |  |  this order: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  |   1. Using directories specified in DT_RPATH, unless DT_RUNPATH is also set. | 
					
						
							|  |  |  |   2. Using the environment variable LD_LIBRARY_PATH | 
					
						
							|  |  |  |   3. Using directories specified in DT_RUNPATH. | 
					
						
							|  |  |  |   4. Using system shared object caches and default directories. | 
					
						
							| 
									
										
										
										
											2018-06-19 19:03:55 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  |  This means that the values in the environment variable `LD_LIBRARY_PATH` | 
					
						
							|  |  |  |  won't matter if the library is found in the paths given by `DT_RPATH` | 
					
						
							|  |  |  |  (and `DT_RUNPATH` isn't set). | 
					
						
							| 
									
										
										
										
											2018-02-15 17:06:15 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  |  Exactly which of `DT_RPATH` or `DT_RUNPATH` is set by default appears to | 
					
						
							| 
									
										
										
										
											2018-06-19 19:03:55 +08:00
										 |  |  |  depend on the system.  For example, according to documentation, | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  |  `DT_RPATH` appears to be deprecated on Solaris in favor of `DT_RUNPATH`, | 
					
						
							|  |  |  |  while on Debian GNU/Linux, either can be set, and `DT_RPATH` is the | 
					
						
							| 
									
										
										
										
											2018-06-19 19:03:55 +08:00
										 |  |  |  default at the time of writing. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  How to choose which runtime search path tag is to be set depends on | 
					
						
							|  |  |  |  your system, please refer to ld(1) for the exact information on your | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  |  system.  As an example, the way to ensure the `DT_RUNPATH` is set on | 
					
						
							| 
									
										
										
										
											2018-06-19 19:03:55 +08:00
										 |  |  |  Debian GNU/Linux systems rather than DT_RPATH is to tell the linker to | 
					
						
							|  |  |  |  set new dtags, like this: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-04 00:20:07 +08:00
										 |  |  |     $ ./Configure --prefix=/usr/local/ssl --openssldir=/usr/local/ssl \ | 
					
						
							| 
									
										
										
										
											2018-06-19 19:03:55 +08:00
										 |  |  |         '-Wl,--enable-new-dtags,-rpath,$(LIBRPATH)' | 
					
						
							| 
									
										
										
										
											2018-06-22 20:13:59 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |  It might be worth noting that some/most ELF systems implement support | 
					
						
							|  |  |  |  for runtime search path relative to the directory containing current | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  |  executable, by interpreting `$ORIGIN` along with some other internal | 
					
						
							| 
									
										
										
										
											2018-06-22 20:13:59 +08:00
										 |  |  |  variables. Consult your system documentation. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  Linking your application | 
					
						
							|  |  |  |  ------------------------ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  Third-party applications dynamically linked with OpenSSL (or any other) | 
					
						
							|  |  |  |  shared library face exactly the same problem with non-default locations. | 
					
						
							|  |  |  |  The OpenSSL config options mentioned above might or might not have bearing | 
					
						
							|  |  |  |  on linking of the target application. "Might" means that under some | 
					
						
							|  |  |  |  circumstances it would be sufficient to link with OpenSSL shared library | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  |  "naturally", i.e. with `-L/whatever/path -lssl -lcrypto`. But there are | 
					
						
							| 
									
										
										
										
											2018-06-22 20:13:59 +08:00
										 |  |  |  also cases when you'd have to explicitly specify runtime search path | 
					
						
							|  |  |  |  when linking your application. Consult your system documentation and use | 
					
						
							|  |  |  |  above section as inspiration... | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  Shared OpenSSL builds also install static libraries. Linking with the | 
					
						
							|  |  |  |  latter is likely to require special care, because linkers usually look | 
					
						
							|  |  |  |  for shared libraries first and tend to remain "blind" to static OpenSSL | 
					
						
							|  |  |  |  libraries. Referring to system documentation would suffice, if not for | 
					
						
							|  |  |  |  a corner case. On AIX static libraries (in shared build) are named | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  |  differently, add `_a` suffix to link with them, e.g. `-lcrypto_a`. |