openssl.xml 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241
  1. <?xml version="1.0" encoding="ISO-8859-1"?>
  2. <!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
  3. "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
  4. <!ENTITY % general-entities SYSTEM "../general.ent">
  5. %general-entities;
  6. ]>
  7. <sect1 id="ch-system-openssl" role="wrap">
  8. <?dbhtml filename="openssl.html"?>
  9. <sect1info condition="script">
  10. <productname>openssl</productname>
  11. <productnumber>&openssl-version;</productnumber>
  12. <address>&openssl-url;</address>
  13. </sect1info>
  14. <title>OpenSSL-&openssl-version;</title>
  15. <indexterm zone="ch-system-openssl">
  16. <primary sortas="a-OpenSSL">OpenSSL</primary>
  17. </indexterm>
  18. <sect2 role="package">
  19. <title/>
  20. <para>The OpenSSL package contains management tools and libraries relating
  21. to cryptography. These are useful for providing cryptographic functions
  22. to other packages, such as OpenSSH, email applications and web browsers
  23. (for accessing HTTPS sites). </para>
  24. <segmentedlist>
  25. <segtitle>&buildtime;</segtitle>
  26. <segtitle>&diskspace;</segtitle>
  27. <seglistitem>
  28. <seg>&openssl-ch6-sbu;</seg>
  29. <seg>&openssl-ch6-du;</seg>
  30. </seglistitem>
  31. </segmentedlist>
  32. </sect2>
  33. <sect2 role="installation">
  34. <title>Installation of OpenSSL</title>
  35. <para>First, fix a problem identified upstream:</para>
  36. <screen><userinput remap="pre">sed -i '/\} data/s/ =.*$/;\n memset(\&amp;data, 0, sizeof(data));/' \
  37. crypto/rand/rand_lib.c</userinput></screen>
  38. <para>Prepare OpenSSL for compilation:</para>
  39. <screen><userinput remap="configure">./config --prefix=/usr \
  40. --openssldir=/etc/ssl \
  41. --libdir=lib \
  42. shared \
  43. zlib-dynamic</userinput></screen>
  44. <para>Compile the package:</para>
  45. <screen><userinput remap="make">make</userinput></screen>
  46. <para>To test the results, issue:</para>
  47. <screen><userinput remap="test">make test</userinput></screen>
  48. <!--
  49. <para>One subtest in the test 40-test_rehash.t fails in the lfs chroot
  50. environment, but passes when run as a regular user.</para>
  51. -->
  52. <para>Install the package:</para>
  53. <screen><userinput remap="install">sed -i '/INSTALL_LIBS/s/libcrypto.a libssl.a//' Makefile
  54. make MANSUFFIX=ssl install</userinput></screen>
  55. <para>If desired, install the documentation:</para>
  56. <screen><userinput remap="install">mv -v /usr/share/doc/openssl /usr/share/doc/openssl-&openssl-version;
  57. cp -vfr doc/* /usr/share/doc/openssl-&openssl-version;</userinput></screen>
  58. </sect2>
  59. <!-- ~~~~~~~~~~~~~~~~~~~~ ABI 32 ~~~~~~~~~~~~~~~~~~~~ -->
  60. <sect2 arch="ml_32,ml_all" role="installation">
  61. <title>Installation of OpenSSL - 32-bit</title>
  62. <para>Clean previous build:</para>
  63. <screen><userinput remap="pre">make distclean</userinput></screen>
  64. <para>Prepare OpenSSL for compilation:</para>
  65. <screen><userinput remap="configure">MACHINE="i686" \
  66. CC="gcc -m32 -march=i686" \
  67. CXX="g++ -m32 -march=i686" \
  68. ./config \
  69. --prefix=/usr \
  70. --libdir=/usr/lib32 \
  71. --openssldir=/etc/ssl \
  72. --libdir=lib32 \
  73. shared \
  74. zlib-dynamic</userinput></screen>
  75. <para>Compile the package:</para>
  76. <screen><userinput remap="make">make</userinput></screen>
  77. <para>Install the package:</para>
  78. <screen><userinput remap="install">make DESTDIR=$PWD/DESTDIR install
  79. cp -Rv DESTDIR/usr/lib32/* /usr/lib32
  80. rm -rf DESTDIR</userinput></screen>
  81. </sect2>
  82. <!-- ~~~~~~~~~~~~~~~~~~~~ ABI x32 ~~~~~~~~~~~~~~~~~~~~ -->
  83. <sect2 arch="ml_x32,ml_all" role="installation">
  84. <title>Installation of OpenSSL - x32-bit</title>
  85. <para>Clean previous build:</para>
  86. <screen><userinput remap="pre">make distclean</userinput></screen>
  87. <para>Prepare OpenSSL for compilation:</para>
  88. <screen><userinput remap="configure">MACHINE="x86_64" \
  89. CC="gcc -mx32" \
  90. CXX="g++ -mx32" \
  91. ./config \
  92. --prefix=/usr \
  93. --libdir=/usr/libx32 \
  94. --openssldir=/etc/ssl \
  95. --libdir=libx32 \
  96. shared \
  97. zlib-dynamic</userinput></screen>
  98. <para>Compile the package:</para>
  99. <screen><userinput remap="make">make</userinput></screen>
  100. <para>Install the package:</para>
  101. <screen><userinput remap="install">make DESTDIR=$PWD/DESTDIR install
  102. cp -Rv DESTDIR/usr/libx32/* /usr/libx32
  103. rm -rf DESTDIR</userinput></screen>
  104. </sect2>
  105. <sect2 id="contents-openssl" role="content">
  106. <title>Contents of OpenSSL</title>
  107. <segmentedlist>
  108. <segtitle>Installed programs</segtitle>
  109. <segtitle>Installed libraries</segtitle>
  110. <segtitle>Installed directories</segtitle>
  111. <seglistitem>
  112. <seg>
  113. c_rehash and openssl
  114. </seg>
  115. <seg>
  116. libcrypto.{so,a} and libssl.{so,a}
  117. </seg>
  118. <seg>
  119. /etc/ssl,
  120. /usr/include/openssl,
  121. /usr/lib/engines and
  122. /usr/share/doc/openssl-&openssl-version;
  123. </seg>
  124. </seglistitem>
  125. </segmentedlist>
  126. <variablelist>
  127. <bridgehead renderas="sect3">Short Descriptions</bridgehead>
  128. <?dbfo list-presentation="list"?>
  129. <?dbhtml list-presentation="table"?>
  130. <varlistentry id="c_rehash">
  131. <term><command>c_rehash</command></term>
  132. <listitem>
  133. <para>
  134. is a <application>Perl</application> script that scans all files in
  135. a directory and adds symbolic links to their hash values.
  136. </para>
  137. <indexterm zone="ch-system-openssl c_rehash">
  138. <primary sortas="b-c_rehash">c_rehash</primary>
  139. </indexterm>
  140. </listitem>
  141. </varlistentry>
  142. <varlistentry id="openssl-prog">
  143. <term><command>openssl</command></term>
  144. <listitem>
  145. <para>
  146. is a command-line tool for using the various cryptography functions
  147. of <application>OpenSSL</application>'s crypto library from the
  148. shell. It can be used for various functions which are documented in
  149. <command>man 1 openssl</command>.
  150. </para>
  151. <indexterm zone="ch-system-openssl openssl-prog">
  152. <primary sortas="b-openssl">openssl</primary>
  153. </indexterm>
  154. </listitem>
  155. </varlistentry>
  156. <varlistentry id="libcrypto">
  157. <term><filename class="libraryfile">libcrypto.so</filename></term>
  158. <listitem>
  159. <para>
  160. implements a wide range of cryptographic algorithms used in various
  161. Internet standards. The services provided by this library are used
  162. by the <application>OpenSSL</application> implementations of SSL,
  163. TLS and S/MIME, and they have also been used to implement
  164. <application>OpenSSH</application>,
  165. <application>OpenPGP</application>, and other cryptographic
  166. standards.
  167. </para>
  168. <indexterm zone="ch-system-openssl libcrypto">
  169. <primary sortas="c-libcrypto">libcrypto.so</primary>
  170. </indexterm>
  171. </listitem>
  172. </varlistentry>
  173. <varlistentry id="libssl">
  174. <term><filename class="libraryfile">libssl.so</filename></term>
  175. <listitem>
  176. <para>
  177. implements the Transport Layer Security (TLS v1) protocol.
  178. It provides a rich API, documentation
  179. on which can be found by running <command>man 3 ssl</command>.
  180. </para>
  181. <indexterm zone="ch-system-openssl libssl">
  182. <primary sortas="c-libssl">libssl.so</primary>
  183. </indexterm>
  184. </listitem>
  185. </varlistentry>
  186. </variablelist>
  187. </sect2>
  188. </sect1>