delorie.com/archives/browse.cgi   search  
Mail Archives: djgpp/2019/11/10/20:43:17

X-Authentication-Warning: delorie.com: mail set sender to djgpp-bounces using -f
Message-Id: <201911110134.xAB1YE26007754@delorie.com>
Date: Sat, 09 Nov 2019 14:32:33 +0100
From: "Juan Manuel Guerrero (juan DOT guerrero AT gmx DOT de) [via djgpp-announce AT delorie DOT com]" <djgpp-announce AT delorie DOT com>
To: djgpp-announce AT delorie DOT com
Subject: ANNOUNCE: DJGPP port of OpenSSL 1.0.2t uploaded.
Reply-To: djgpp AT delorie DOT com

This is a port of OpenSSL 1.0.2t to MSDOS/DJGPP.

   The OpenSSL Project is an Open Source toolkit implementing the Secure
   Sockets Layer (SSL v2/v3) and Transport Layer Security (TLS v1) protocols
   as well as a full-strength general purpose cryptography library.  OpenSSL
   is based on the excellent SSLeay library developed from Eric A. Young and
   Tim J. Hudson.  The OpenSSL toolkit is licensed under a dual-license (the
   OpenSSL license plus the SSLeay license) situation, which basically means
   that you are free to get and use it for commercial and non-commercial
   purposes as long as you fulfill the conditions of both licenses.



   DJGPP specific changes.
   =======================

   Fortunately, OpenSSL has been supporting DJGPP out-of-the-box so there
   is no need for major adjustments of the source code itself.  Neitherless
   there are made assumptions about the file system used and its capabilities
   that require some changes in the perl configuration scripts and in the way
   source package is unzipped.  This port has been created because 1.0.2 is
   the Long Term Support (LTS) version (support will be provided until 31st
   December 2019) and the 1.0.1 version is currently only receiving security
   bug fixes and all support will be discontinued for this version on 31st
   December 2016.


   - the configure script assumes that DJGPP provides termio so it defines
     TERMIO instead of TERMIOS as used to be.  This had to be reverted.

   - undefining the DEVRANDOM_EGD macro because neither MS-DOS nor FreeDOS
     provide 'egd' sockets.

   - all the adjustments required for the use of the DJGPP port of the
     current version of the Watt-32 library.

   - the new macro HAS_LFN_SUPPORT checks if underlying file system supports
     long file names or not.

   - the new function dosify_filename replaces leading dot in passed file
     name if file system does not support LFN.  It also replaces all leading
     dots in the dirname part and the basename part of the file name.

   - all these changes have found their way into the new OpenSSl 1.1.0 version
     but will not become part neither of version 1.0.1 nor version 1.0.2.
     That is because both versions are maintaining versions only and will
     not offer new OS/port specific features anymore.

   - all new DJGPP specific files are store in the /djgpp directory.

   - to install, configure and compile the sources LFN support is required.

   - as usual the /djgpp directory contains also the diffs file.  It shows how
     I have changed some of the perl scripts used during the configuration and
     building steps to check for the OS used and to copy the files instead of
     trying to create links even if this is possible.

   - the binaries, headers and libraries will be installed in the corresponding
     directories of the DJGPP installation tree.  All documentation will be
     installend in /dev/env/DJDIR/share/ssl/man.  This means that you will have
     to adjust your MANPATH in djgpp.env if you want that the man program finds
     these new manpages.

   - to be able to configure and compile this port, the DJGPP port of perl
     must be installed.  openssl uses a mix of perl scripts and Makefiles to
     configure and compile the sources.  I have used perl588b but the previous
     one may work as well but I have never tested this.

   - to be able to configure and compile this port, the DJGPP port of WATT-32
     must be installed.  It can be downloaded as:
       ftp://ftp.delorie.com/pub/djgpp/current/v2tk/wat3211b.zip
     After having installed the port make sure that the WATT_ROOT environment
     variable points to the directory where the headers and the library reside.
     This is:
       set WATT_ROOT=/dev/env/DJDIR/net/watt
     Due to the dependency of WATT-32 and the required value of the WATT_ROOT
     environment variable, the source package is not configured at all.  You
     have to install WATT-32 first and then you can configure and build openssl
     as described in the original INSTALL.DJGPP file.

   - the port has been configured and compiled to support for zlib compression.
     The zlib port used is
       ftp://ftp.delorie.com/pub/djgpp/current/v2tk/zlb1211b.zip
     but any other version of the port may work as well.

   - the test suite passes except for the last test that requires some
     certificate that needs to be requested.  For some test, it is also
     required that the port of GNU bc is installed.

   - the binary package of openssl ist not completely SFN clean.  But this
     concerns the manpages only.  Neither the libraries nor the headers are
     affected.  I do not have the time to invent SFN clean names for hundreds
     of manpages which names may change and become useless with the next
     openssl update.  Of course, the headers and libraries are 8.3 clean
     and the use of the libraries do not require LFN support at all.

   - as any cryptographic software, openssl needs a source of unpredictable
     data to work correctly.  Many open source operating systems provide a
     "randomness device" (/dev/urandom or /dev/random) that serves this
     purpose.  As of version 0.9.7f of openssl the DJGPP port checks upon
     /dev/urandom$ for a 3rd party "randomness" DOS driver.  One such driver,
     NOISE.SYS, can be obtained from "http://www.rahul.net/dkaufman/index.html"
     as:
        http://www.rahul.net/dkaufman/noise063a2.zip
     Please read the instructions carefully.  This driver works on DOS and
     may be on some versions of Windows but it does not work for all versions
     of Windows.  For XP it does not work and I have found no replacement.
     This means that for WinXP and probably for Win2K there is there is
     no "randomness" support for openssl available.

   - most but not all programs of the /examples directory can be successfully
     compiled but they may not work.  I have no intention to fix them, neither
     less they may serve as example how to use the library and how to compile
     and link your application with this library together with the WATT-32
     library and the zlib library.

   - the port has been configured and compiled on WinXP SP3 and on Win98SE.
     There is no guarantee that this may be possible with any other DOS-
     like OS.  Due to the use of long file names it will not be possible
     to configure and compile without LFN support.

   - the port has been compiled using gcc346b, bnu232b and djdev205 (CVS build).

   - configuring, compiling and running the test suite takes around 02:15 h
     on WinXP installed on a virtual machine.

   - configuring, compiling, running the test suite and installing takes
     around 20 min on Win98SE installed on a virtual machine.


   For further information about OpenSSL please read the man pages,
   various README files and NEWS file.  Also visit the home page of openssl.
   Please note that I am not an user of openssl.  I have only ported it because
   I needed it to create another port.  This means that I am not able to answer
   openssl specific questions.


   This is a verbatim extract of the CHANGES file:
-------------------------------------------------------------------------------
  Changes between 1.0.2s and 1.0.2t [10 Sep 2019]

    *) For built-in EC curves, ensure an EC_GROUP built from the curve name is
       used even when parsing explicit parameters, when loading a serialized key
       or calling `EC_GROUP_new_from_ecpkparameters()`/
       `EC_GROUP_new_from_ecparameters()`.
       This prevents bypass of security hardening and performance gains,
       especially for curves with specialized EC_METHODs.
       By default, if a key encoded with explicit parameters is loaded and later
       serialized, the output is still encoded with explicit parameters, even if
       internally a "named" EC_GROUP is used for computation.
       [Nicola Tuveri]

   *) Compute ECC cofactors if not provided during EC_GROUP construction. Before
      this change, EC_GROUP_set_generator would accept order and/or cofactor as
      NULL. After this change, only the cofactor parameter can be NULL. It also
      does some minimal sanity checks on the passed order.
      (CVE-2019-1547)
      [Billy Bob Brumley]

   *) Fixed a padding oracle in PKCS7_dataDecode and CMS_decrypt_set1_pkey.
      An attack is simple, if the first CMS_recipientInfo is valid but the
      second CMS_recipientInfo is chosen ciphertext. If the second
      recipientInfo decodes to PKCS #1 v1.5 form plaintext, the correct
      encryption key will be replaced by garbage, and the message cannot be
      decoded, but if the RSA decryption fails, the correct encryption key is
      used and the recipient will not notice the attack.
      As a work around for this potential attack the length of the decrypted
      key must be equal to the cipher default key length, in case the
      certifiate is not given and all recipientInfo are tried out.
      The old behaviour can be re-enabled in the CMS code by setting the
      CMS_DEBUG_DECRYPT flag.
      (CVE-2019-1563)
      [Bernd Edlinger]

   *) Document issue with installation paths in diverse Windows builds

      '/usr/local/ssl' is an unsafe prefix for location to install OpenSSL
      binaries and run-time config file.
      (CVE-2019-1552)
      [Richard Levitte]


-------------------------------------------------------------------------------




   The port has been compiled using djdev205 (repository code) and consists
   of two packages that can be downloaded from ftp.delorie.com and mirrors
   as (time stamp 2019-11-07):

     OpenSSL 1.0.2 binary, headers, libraries and man format documentation:
     ftp://ftp.delorie.com/pub/djgpp/current/v2tk/ssl102tb.zip

     OpenSSL 1.0.2 source:
     ftp://ftp.delorie.com/pub/djgpp/current/v2tk/ssl102ts.zip



   Send OpenSSL specific bug reports to <openssl-bugs AT openssl DOT org>.
   Send suggestions and bug reports concerning the DJGPP port to
   comp.os.msdos.djgpp or <djgpp AT delorie DOT com>.
   If you are not sure if the failure is really a openssl failure
   or a djgpp specific failure, report it here and *not* to
   <openssl-bugs AT openssl DOT org>.


Enjoy.

     Guerrero, Juan Manuel <juan DOT guerrero AT gmx DOT de>

- Raw text -


  webmaster     delorie software   privacy  
  Copyright © 2019   by DJ Delorie     Updated Jul 2019