Compare commits
37 Commits
main
...
OPENBSD_5_
Author | SHA1 | Date | |
---|---|---|---|
![]() |
9ce9c4d2e8 | ||
![]() |
5dacd8e02c | ||
![]() |
c0cb9e9ae1 | ||
![]() |
17bf566573 | ||
![]() |
fa41ca5182 | ||
![]() |
bb9c1f2838 | ||
![]() |
2169962cb4 | ||
![]() |
9092f35957 | ||
![]() |
92902f7040 | ||
![]() |
271ad075dd | ||
![]() |
248af93e3a | ||
![]() |
97478266ca | ||
![]() |
0e7a252d0d | ||
![]() |
0c125d1ee3 | ||
![]() |
e953fdbb96 | ||
![]() |
14fbc41003 | ||
![]() |
f927fc2a90 | ||
![]() |
5c164446dd | ||
![]() |
b8853fd092 | ||
![]() |
aad86fe1f9 | ||
![]() |
72039968e2 | ||
![]() |
9c2f0ef51c | ||
![]() |
e13a39a5a7 | ||
![]() |
9c9a9858e8 | ||
![]() |
90f851568a | ||
![]() |
6f7ad9c6d6 | ||
![]() |
52582562d8 | ||
![]() |
da424147c9 | ||
![]() |
61ad89df15 | ||
![]() |
b5002ca5ac | ||
![]() |
332b03c8b7 | ||
![]() |
83e3f22710 | ||
![]() |
b3f22d85e5 | ||
![]() |
ab1de85a42 | ||
![]() |
cd16a21cab | ||
![]() |
9caf754a59 | ||
![]() |
2f2f08e60c |
18
.gitignore
vendored
18
.gitignore
vendored
@ -45,6 +45,7 @@ Makefile.in
|
|||||||
test-driver
|
test-driver
|
||||||
*.log
|
*.log
|
||||||
*.trs
|
*.trs
|
||||||
|
!tests/optionstest.c
|
||||||
tests/aes_wrap*
|
tests/aes_wrap*
|
||||||
tests/arc4random_fork*
|
tests/arc4random_fork*
|
||||||
tests/cipher*
|
tests/cipher*
|
||||||
@ -60,7 +61,6 @@ tests/pbkdf2*
|
|||||||
tests/*.pem
|
tests/*.pem
|
||||||
tests/testssl
|
tests/testssl
|
||||||
tests/*.txt
|
tests/*.txt
|
||||||
!tests/optionstest.c
|
|
||||||
|
|
||||||
# ctags stuff
|
# ctags stuff
|
||||||
TAGS
|
TAGS
|
||||||
@ -70,8 +70,8 @@ autom4te.cache
|
|||||||
# Libtool adds these, at least sometimes
|
# Libtool adds these, at least sometimes
|
||||||
INSTALL
|
INSTALL
|
||||||
/COPYING
|
/COPYING
|
||||||
m4/l*
|
|
||||||
!m4/check*.m4
|
!m4/check*.m4
|
||||||
|
m4/l*
|
||||||
|
|
||||||
aclocal.m4
|
aclocal.m4
|
||||||
compile
|
compile
|
||||||
@ -106,17 +106,16 @@ tls/*.h
|
|||||||
include/pqueue.h
|
include/pqueue.h
|
||||||
include/tls.h
|
include/tls.h
|
||||||
include/openssl/*.h
|
include/openssl/*.h
|
||||||
include/openssl/*.he
|
|
||||||
|
|
||||||
/apps/*.h
|
|
||||||
/apps/*.c
|
|
||||||
/apps/openssl
|
|
||||||
/apps/openssl.cnf
|
|
||||||
!/apps/apps_win.c
|
!/apps/apps_win.c
|
||||||
!/apps/poll_win.c
|
!/apps/poll_win.c
|
||||||
!/apps/certhash_disabled.c
|
!/apps/certhash_disabled.c
|
||||||
|
/apps/*.h
|
||||||
|
/apps/*.c
|
||||||
|
/apps/*.cnf
|
||||||
|
/apps/*.pem
|
||||||
|
/apps/openssl
|
||||||
|
|
||||||
/crypto
|
|
||||||
!/crypto/Makefile.am.*
|
!/crypto/Makefile.am.*
|
||||||
!/crypto/compat/arc4random.h
|
!/crypto/compat/arc4random.h
|
||||||
!/crypto/compat/b_win.c
|
!/crypto/compat/b_win.c
|
||||||
@ -126,14 +125,15 @@ include/openssl/*.he
|
|||||||
!/crypto/compat/inet_pton.c
|
!/crypto/compat/inet_pton.c
|
||||||
!/crypto/compat/ui_openssl_win.c
|
!/crypto/compat/ui_openssl_win.c
|
||||||
!/crypto/CMakeLists.txt
|
!/crypto/CMakeLists.txt
|
||||||
|
/crypto
|
||||||
|
|
||||||
|
!/libtls-standalone/compat/Makefile.am
|
||||||
/libtls-standalone/include/*.h
|
/libtls-standalone/include/*.h
|
||||||
/libtls-standalone/src/*.c
|
/libtls-standalone/src/*.c
|
||||||
/libtls-standalone/src/*.h
|
/libtls-standalone/src/*.h
|
||||||
/libtls-standalone/src
|
/libtls-standalone/src
|
||||||
/libtls-standalone/tests/test
|
/libtls-standalone/tests/test
|
||||||
/libtls-standalone/compat
|
/libtls-standalone/compat
|
||||||
!/libtls-standalone/compat/Makefile.am
|
|
||||||
/libtls-standalone/VERSION
|
/libtls-standalone/VERSION
|
||||||
/libtls-standalone/m4
|
/libtls-standalone/m4
|
||||||
/libtls-standalone/man
|
/libtls-standalone/man
|
||||||
|
@ -1,11 +1,27 @@
|
|||||||
cmake_minimum_required (VERSION 2.8)
|
cmake_minimum_required (VERSION 2.8)
|
||||||
include(CheckFunctionExists)
|
include(CheckFunctionExists)
|
||||||
|
include(CheckLibraryExists)
|
||||||
include(CheckIncludeFiles)
|
include(CheckIncludeFiles)
|
||||||
|
|
||||||
project (LibreSSL)
|
project (LibreSSL)
|
||||||
|
|
||||||
enable_testing()
|
enable_testing()
|
||||||
|
|
||||||
|
file(READ ${CMAKE_SOURCE_DIR}/ssl/VERSION SSL_VERSION)
|
||||||
|
string(STRIP ${SSL_VERSION} SSL_VERSION)
|
||||||
|
string(REPLACE ":" "." SSL_VERSION ${SSL_VERSION})
|
||||||
|
string(REGEX REPLACE "\\..*" "" SSL_MAJOR_VERSION ${SSL_VERSION})
|
||||||
|
|
||||||
|
file(READ ${CMAKE_SOURCE_DIR}/crypto/VERSION CRYPTO_VERSION)
|
||||||
|
string(STRIP ${CRYPTO_VERSION} CRYPTO_VERSION)
|
||||||
|
string(REPLACE ":" "." CRYPTO_VERSION ${CRYPTO_VERSION})
|
||||||
|
string(REGEX REPLACE "\\..*" "" CRYPTO_MAJOR_VERSION ${CRYPTO_VERSION})
|
||||||
|
|
||||||
|
file(READ ${CMAKE_SOURCE_DIR}/tls/VERSION TLS_VERSION)
|
||||||
|
string(STRIP ${TLS_VERSION} TLS_VERSION)
|
||||||
|
string(REPLACE ":" "." TLS_VERSION ${TLS_VERSION})
|
||||||
|
string(REGEX REPLACE "\\..*" "" TLS_MAJOR_VERSION ${TLS_VERSION})
|
||||||
|
|
||||||
if(CMAKE_SYSTEM_NAME MATCHES "OpenBSD")
|
if(CMAKE_SYSTEM_NAME MATCHES "OpenBSD")
|
||||||
add_definitions(-DHAVE_ATTRIBUTE__BOUNDED__)
|
add_definitions(-DHAVE_ATTRIBUTE__BOUNDED__)
|
||||||
endif()
|
endif()
|
||||||
@ -21,6 +37,8 @@ add_definitions(-DLIBRESSL_INTERNAL)
|
|||||||
add_definitions(-DOPENSSL_NO_HW_PADLOCK)
|
add_definitions(-DOPENSSL_NO_HW_PADLOCK)
|
||||||
add_definitions(-DOPENSSL_NO_ASM)
|
add_definitions(-DOPENSSL_NO_ASM)
|
||||||
|
|
||||||
|
set(CMAKE_POSITION_INDEPENDENT_CODE true)
|
||||||
|
|
||||||
if (CMAKE_COMPILER_IS_GNUCC OR CMAKE_C_COMPILER_ID MATCHES "Clang")
|
if (CMAKE_COMPILER_IS_GNUCC OR CMAKE_C_COMPILER_ID MATCHES "Clang")
|
||||||
add_definitions(-Wno-pointer-sign)
|
add_definitions(-Wno-pointer-sign)
|
||||||
endif()
|
endif()
|
||||||
@ -142,11 +160,23 @@ set(OPENSSL_LIBS ssl crypto)
|
|||||||
if(CMAKE_HOST_WIN32)
|
if(CMAKE_HOST_WIN32)
|
||||||
set(OPENSSL_LIBS ${OPENSSL_LIBS} ws2_32)
|
set(OPENSSL_LIBS ${OPENSSL_LIBS} ws2_32)
|
||||||
endif()
|
endif()
|
||||||
|
if(CMAKE_SYSTEM_NAME MATCHES "Linux")
|
||||||
|
check_library_exists(rt clock_gettime "time.h" HAVE_CLOCK_GETTIME)
|
||||||
|
if (HAVE_CLOCK_GETTIME)
|
||||||
|
set(OPENSSL_LIBS ${OPENSSL_LIBS} rt)
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(NOT (CMAKE_SYSTEM_NAME MATCHES "Darwin" OR MSVC))
|
||||||
|
set(BUILD_SHARED true)
|
||||||
|
endif()
|
||||||
|
|
||||||
add_subdirectory(crypto)
|
add_subdirectory(crypto)
|
||||||
add_subdirectory(ssl)
|
add_subdirectory(ssl)
|
||||||
add_subdirectory(apps)
|
add_subdirectory(apps)
|
||||||
add_subdirectory(tls)
|
add_subdirectory(tls)
|
||||||
|
add_subdirectory(include)
|
||||||
if(NOT MSVC)
|
if(NOT MSVC)
|
||||||
|
add_subdirectory(man)
|
||||||
add_subdirectory(tests)
|
add_subdirectory(tests)
|
||||||
endif()
|
endif()
|
||||||
|
62
ChangeLog
62
ChangeLog
@ -28,6 +28,68 @@ history is also available from Git.
|
|||||||
|
|
||||||
LibreSSL Portable Release Notes:
|
LibreSSL Portable Release Notes:
|
||||||
|
|
||||||
|
2.2.9 - Security fix
|
||||||
|
|
||||||
|
* Correct a problem that prevents the DSA signing algorithm from
|
||||||
|
running in constant time even if the flag BN_FLG_CONSTTIME is set.
|
||||||
|
This issue was reported by Cesar Pereida (Aalto University), Billy
|
||||||
|
Brumley (Tampere University of Technology), and Yuval Yarom (The
|
||||||
|
University of Adelaide and NICTA). The fix was developed by Cesar
|
||||||
|
Pereida. See OpenBSD 5.8 errata 17, June 6, 2016
|
||||||
|
|
||||||
|
2.2.8 - Reliability fix
|
||||||
|
|
||||||
|
* Fixed an error in libcrypto when parsing some ASN.1 elements > 16k.
|
||||||
|
|
||||||
|
2.2.7 - Security Update
|
||||||
|
|
||||||
|
* Fix multiple vulnerabilities in libcrypto relating to ASN.1 and encoding.
|
||||||
|
From OpenSSL.
|
||||||
|
|
||||||
|
2.2.6 - Security Update
|
||||||
|
|
||||||
|
* Deprecated the SSL_OP_SINGLE_DH_USE flag.
|
||||||
|
|
||||||
|
2.2.5 - Reliability Update
|
||||||
|
|
||||||
|
* Fixes from OpenSSL 1.0.1q
|
||||||
|
- CVE-2015-3194 - NULL pointer dereference in client side certificate
|
||||||
|
validation.
|
||||||
|
- CVE-2015-3195 - Memory leak in PKCS7 - not reachable from TLS/SSL
|
||||||
|
|
||||||
|
* The following OpenSSL CVEs did not apply to LibreSSL
|
||||||
|
- CVE-2015-3193 - Carry propagating bug in the x86_64 Montgomery
|
||||||
|
squaring procedure.
|
||||||
|
- CVE-2015-3196 - Double free race condition of the identify hint
|
||||||
|
data.
|
||||||
|
|
||||||
|
See https://marc.info/?l=openbsd-announce&m=144925068504102
|
||||||
|
|
||||||
|
2.2.4 - Build and bug fixes
|
||||||
|
|
||||||
|
* Backported build fixes for CMake on Windows, OSX and Linux
|
||||||
|
|
||||||
|
* Fixes for a memory leak and out-of-bounds access in OBJ_obj2txt
|
||||||
|
reported by Qualys Security.
|
||||||
|
- CVE-2015-5333 - memory leak in OBJ_obj2txt
|
||||||
|
- CVE-2015-5334 - 1-byte buffer overflow in OBJ_obj2txt
|
||||||
|
|
||||||
|
See http://www.openwall.com/lists/oss-security/2015/10/16/1
|
||||||
|
|
||||||
|
2.2.3 - Bug fixes, build enhancements
|
||||||
|
|
||||||
|
* LibreSSL 2.2.2 incorrectly handles ClientHello messages that do not
|
||||||
|
include TLS extensions, resulting in such handshakes being aborted.
|
||||||
|
This release corrects the handling of such messages. Thanks to
|
||||||
|
Ligushka from github for reporting the issue.
|
||||||
|
|
||||||
|
* Added install target for cmake builds. Thanks to TheNietsnie from
|
||||||
|
github.
|
||||||
|
|
||||||
|
* Updated pkgconfig files to correctly report the release version
|
||||||
|
number, not the individual library ABI version numbers. Thanks to
|
||||||
|
Jan Engelhardt for reporting the issue.
|
||||||
|
|
||||||
2.2.2 - More TLS parser rework, bug fixes, expanded portable build support
|
2.2.2 - More TLS parser rework, bug fixes, expanded portable build support
|
||||||
|
|
||||||
* Switched 'openssl dhparam' default from 512 to 2048 bits
|
* Switched 'openssl dhparam' default from 512 to 2048 bits
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
AM_CFLAGS = -I$(top_srcdir)/include -I$(top_srcdir)/include/compat
|
AM_CFLAGS =
|
||||||
AM_CPPFLAGS = -DLIBRESSL_INTERNAL
|
AM_CPPFLAGS = -I$(top_srcdir)/include -I$(top_srcdir)/include/compat -DLIBRESSL_INTERNAL
|
||||||
|
@ -1 +1 @@
|
|||||||
master
|
OPENBSD_5_8
|
||||||
|
@ -13,7 +13,7 @@ LibreSSL is API compatible with OpenSSL 1.0.1, but does not yet include all
|
|||||||
new APIs from OpenSSL 1.0.2 and later. LibreSSL also includes APIs not yet
|
new APIs from OpenSSL 1.0.2 and later. LibreSSL also includes APIs not yet
|
||||||
present in OpenSSL. The current common API subset is OpenSSL 1.0.1.
|
present in OpenSSL. The current common API subset is OpenSSL 1.0.1.
|
||||||
|
|
||||||
LibreSSL it is not ABI compatible with any release of OpenSSL, or necessarily
|
LibreSSL is not ABI compatible with any release of OpenSSL, or necessarily
|
||||||
earlier releases of LibreSSL. You will need to relink your programs to
|
earlier releases of LibreSSL. You will need to relink your programs to
|
||||||
LibreSSL in order to use it, just as in moving between major versions of OpenSSL.
|
LibreSSL in order to use it, just as in moving between major versions of OpenSSL.
|
||||||
LibreSSL's installed library version numbers are incremented to account for
|
LibreSSL's installed library version numbers are incremented to account for
|
||||||
@ -62,7 +62,7 @@ If you have checked this source using Git, follow these initial steps to
|
|||||||
prepare the source tree for building:
|
prepare the source tree for building:
|
||||||
|
|
||||||
1. Ensure you have the following packages installed:
|
1. Ensure you have the following packages installed:
|
||||||
automake, autoconf, bash, git, libtool, perl, pod2man
|
automake, autoconf, git, libtool, perl, pod2man
|
||||||
2. Run './autogen.sh' to prepare the source tree for building or
|
2. Run './autogen.sh' to prepare the source tree for building or
|
||||||
run './dist.sh' to prepare a tarball.
|
run './dist.sh' to prepare a tarball.
|
||||||
|
|
||||||
|
@ -6,9 +6,8 @@ GCC or Clang as the compiler. Contrary to its name, mingw-w64 supports both
|
|||||||
then LibreSSL should integrate very nicely. Old versions of the mingw-w64
|
then LibreSSL should integrate very nicely. Old versions of the mingw-w64
|
||||||
toolchain, such as the one packaged with Ubuntu 12.04, may have trouble
|
toolchain, such as the one packaged with Ubuntu 12.04, may have trouble
|
||||||
building LibreSSL. Please try it with a recent toolchain if you encounter
|
building LibreSSL. Please try it with a recent toolchain if you encounter
|
||||||
troubles. If you are building under Cygwin, only builds with the mingw-w64
|
troubles. Cygwin provides an easy method of installing the latest mingw-w64
|
||||||
compiler are supported, though you can easily use Cygwin to drive the build
|
cross compilers on Windows.
|
||||||
process.
|
|
||||||
|
|
||||||
To configure and build LibreSSL for a 32-bit system, use the following
|
To configure and build LibreSSL for a 32-bit system, use the following
|
||||||
build steps:
|
build steps:
|
||||||
|
@ -77,3 +77,5 @@ endif()
|
|||||||
|
|
||||||
add_executable(openssl ${OPENSSL_SRC})
|
add_executable(openssl ${OPENSSL_SRC})
|
||||||
target_link_libraries(openssl ${OPENSSL_LIBS})
|
target_link_libraries(openssl ${OPENSSL_LIBS})
|
||||||
|
|
||||||
|
install(TARGETS openssl DESTINATION bin)
|
||||||
|
@ -638,4 +638,16 @@ if(NOT HAVE_TIMINGSAFE_MEMCMP)
|
|||||||
set(CRYPTO_SRC ${CRYPTO_SRC} compat/timingsafe_memcmp.c)
|
set(CRYPTO_SRC ${CRYPTO_SRC} compat/timingsafe_memcmp.c)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
add_library(crypto ${CRYPTO_SRC})
|
if (BUILD_SHARED)
|
||||||
|
add_library(crypto-objects OBJECT ${CRYPTO_SRC})
|
||||||
|
add_library(crypto STATIC $<TARGET_OBJECTS:crypto-objects>)
|
||||||
|
add_library(crypto-shared SHARED $<TARGET_OBJECTS:crypto-objects>)
|
||||||
|
set_target_properties(crypto-shared PROPERTIES OUTPUT_NAME crypto)
|
||||||
|
set_target_properties(crypto-shared PROPERTIES VERSION
|
||||||
|
${CRYPTO_VERSION} SOVERSION ${CRYPTO_MAJOR_VERSION})
|
||||||
|
install(TARGETS crypto crypto-shared DESTINATION lib)
|
||||||
|
else()
|
||||||
|
add_library(crypto STATIC ${CRYPTO_SRC})
|
||||||
|
install(TARGETS crypto DESTINATION lib)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
@ -1,17 +1,22 @@
|
|||||||
include $(top_srcdir)/Makefile.am.common
|
include $(top_srcdir)/Makefile.am.common
|
||||||
|
|
||||||
AM_CFLAGS += -I$(top_srcdir)/crypto/asn1
|
AM_CPPFLAGS += -I$(top_srcdir)/crypto/asn1
|
||||||
AM_CFLAGS += -I$(top_srcdir)/crypto/evp
|
AM_CPPFLAGS += -I$(top_srcdir)/crypto/evp
|
||||||
AM_CFLAGS += -I$(top_srcdir)/crypto/modes
|
AM_CPPFLAGS += -I$(top_srcdir)/crypto/modes
|
||||||
|
AM_CPPFLAGS += -I$(top_srcdir)/crypto
|
||||||
|
|
||||||
lib_LTLIBRARIES = libcrypto.la
|
lib_LTLIBRARIES = libcrypto.la
|
||||||
|
|
||||||
EXTRA_DIST = VERSION
|
EXTRA_DIST = VERSION
|
||||||
EXTRA_DIST += CMakeLists.txt
|
EXTRA_DIST += CMakeLists.txt
|
||||||
|
|
||||||
|
# needed for a CMake target
|
||||||
|
EXTRA_DIST += compat/strcasecmp.c
|
||||||
|
|
||||||
libcrypto_la_LDFLAGS = -version-info @LIBCRYPTO_VERSION@ -no-undefined
|
libcrypto_la_LDFLAGS = -version-info @LIBCRYPTO_VERSION@ -no-undefined
|
||||||
libcrypto_la_LIBADD = libcompat.la libcompatnoopt.la
|
libcrypto_la_LIBADD = libcompat.la libcompatnoopt.la
|
||||||
libcrypto_la_CPPFLAGS = -DLIBRESSL_INTERNAL
|
libcrypto_la_CPPFLAGS = $(AM_CPPFLAGS)
|
||||||
|
libcrypto_la_CPPFLAGS += -DLIBRESSL_INTERNAL
|
||||||
libcrypto_la_CPPFLAGS += -DOPENSSL_NO_HW_PADLOCK
|
libcrypto_la_CPPFLAGS += -DOPENSSL_NO_HW_PADLOCK
|
||||||
if OPENSSL_NO_ASM
|
if OPENSSL_NO_ASM
|
||||||
libcrypto_la_CPPFLAGS += -DOPENSSL_NO_ASM
|
libcrypto_la_CPPFLAGS += -DOPENSSL_NO_ASM
|
||||||
@ -115,6 +120,7 @@ libcrypto_la_SOURCES += mem_dbg.c
|
|||||||
libcrypto_la_SOURCES += o_init.c
|
libcrypto_la_SOURCES += o_init.c
|
||||||
libcrypto_la_SOURCES += o_str.c
|
libcrypto_la_SOURCES += o_str.c
|
||||||
libcrypto_la_SOURCES += o_time.c
|
libcrypto_la_SOURCES += o_time.c
|
||||||
|
noinst_HEADERS += constant_time_locl.h
|
||||||
noinst_HEADERS += cryptlib.h
|
noinst_HEADERS += cryptlib.h
|
||||||
noinst_HEADERS += md32_common.h
|
noinst_HEADERS += md32_common.h
|
||||||
noinst_HEADERS += o_time.h
|
noinst_HEADERS += o_time.h
|
||||||
|
@ -22,7 +22,7 @@ for ARCH in X86 X64; do
|
|||||||
|
|
||||||
echo Building for $HOST
|
echo Building for $HOST
|
||||||
|
|
||||||
CC=$HOST-gcc ./configure --host=$HOST
|
CC=$HOST-gcc ./configure --host=$HOST --with-openssldir=c:/libressl/ssl
|
||||||
make clean
|
make clean
|
||||||
PATH=$PATH:/usr/$HOST/sys-root/mingw/bin \
|
PATH=$PATH:/usr/$HOST/sys-root/mingw/bin \
|
||||||
make -j 4 check
|
make -j 4 check
|
||||||
|
2
dist.sh
2
dist.sh
@ -1,7 +1,7 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
rm -f man/*.1 man/*.3
|
rm -f man/*.1 man/*.3 include/openssl/*.h
|
||||||
./autogen.sh
|
./autogen.sh
|
||||||
./configure
|
./configure
|
||||||
make distcheck
|
make distcheck
|
||||||
|
5
include/CMakeLists.txt
Normal file
5
include/CMakeLists.txt
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
install(DIRECTORY .
|
||||||
|
DESTINATION include
|
||||||
|
PATTERN "CMakeLists.txt" EXCLUDE
|
||||||
|
PATTERN "compat" EXCLUDE
|
||||||
|
PATTERN "Makefile.*" EXCLUDE)
|
@ -1,5 +1,7 @@
|
|||||||
include $(top_srcdir)/Makefile.am.common
|
include $(top_srcdir)/Makefile.am.common
|
||||||
|
|
||||||
|
EXTRA_DIST = CMakeLists.txt
|
||||||
|
|
||||||
SUBDIRS = openssl
|
SUBDIRS = openssl
|
||||||
|
|
||||||
noinst_HEADERS = pqueue.h
|
noinst_HEADERS = pqueue.h
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -7,7 +7,13 @@
|
|||||||
#define LIBCRYPTOCOMPAT_STDIO_H
|
#define LIBCRYPTOCOMPAT_STDIO_H
|
||||||
|
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
|
#if _MSC_VER >= 1900
|
||||||
|
#include <../ucrt/stdlib.h>
|
||||||
|
#include <../ucrt/corecrt_io.h>
|
||||||
|
#include <../ucrt/stdio.h>
|
||||||
|
#else
|
||||||
#include <../include/stdio.h>
|
#include <../include/stdio.h>
|
||||||
|
#endif
|
||||||
#else
|
#else
|
||||||
#include_next <stdio.h>
|
#include_next <stdio.h>
|
||||||
#endif
|
#endif
|
||||||
|
@ -4,7 +4,11 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
|
#if _MSC_VER >= 1900
|
||||||
|
#include <../ucrt/stdlib.h>
|
||||||
|
#else
|
||||||
#include <../include/stdlib.h>
|
#include <../include/stdlib.h>
|
||||||
|
#endif
|
||||||
#else
|
#else
|
||||||
#include_next <stdlib.h>
|
#include_next <stdlib.h>
|
||||||
#endif
|
#endif
|
||||||
|
@ -7,7 +7,11 @@
|
|||||||
#define LIBCRYPTOCOMPAT_STRING_H
|
#define LIBCRYPTOCOMPAT_STRING_H
|
||||||
|
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
|
#if _MSC_VER >= 1900
|
||||||
|
#include <../ucrt/string.h>
|
||||||
|
#else
|
||||||
#include <../include/string.h>
|
#include <../include/string.h>
|
||||||
|
#endif
|
||||||
#else
|
#else
|
||||||
#include_next <string.h>
|
#include_next <string.h>
|
||||||
#endif
|
#endif
|
||||||
|
@ -11,7 +11,11 @@
|
|||||||
#else
|
#else
|
||||||
|
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
|
#if _MSC_VER >= 1900
|
||||||
|
#include <../ucrt/sys/stat.h>
|
||||||
|
#else
|
||||||
#include <../include/sys/stat.h>
|
#include <../include/sys/stat.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
/* File type and permission flags for stat() */
|
/* File type and permission flags for stat() */
|
||||||
#if !defined(S_IFMT)
|
#if !defined(S_IFMT)
|
||||||
|
@ -4,7 +4,11 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
|
#if _MSC_VER >= 1900
|
||||||
|
#include <../ucrt/sys/types.h>
|
||||||
|
#else
|
||||||
#include <../include/sys/types.h>
|
#include <../include/sys/types.h>
|
||||||
|
#endif
|
||||||
#else
|
#else
|
||||||
#include_next <sys/types.h>
|
#include_next <sys/types.h>
|
||||||
#endif
|
#endif
|
||||||
|
@ -4,7 +4,11 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
|
#if _MSC_VER >= 1900
|
||||||
|
#include <../ucrt/time.h>
|
||||||
|
#else
|
||||||
#include <../include/time.h>
|
#include <../include/time.h>
|
||||||
|
#endif
|
||||||
#define gmtime_r(tp, tm) ((gmtime_s((tm), (tp)) == 0) ? (tm) : NULL)
|
#define gmtime_r(tp, tm) ((gmtime_s((tm), (tp)) == 0) ? (tm) : NULL)
|
||||||
#else
|
#else
|
||||||
#include_next <time.h>
|
#include_next <time.h>
|
||||||
|
@ -7,7 +7,7 @@ includedir=@includedir@
|
|||||||
|
|
||||||
Name: LibreSSL-libssl
|
Name: LibreSSL-libssl
|
||||||
Description: Secure Sockets Layer and cryptography libraries
|
Description: Secure Sockets Layer and cryptography libraries
|
||||||
Version: @LIBCRYPTO_VERSION@
|
Version: @VERSION@
|
||||||
Requires:
|
Requires:
|
||||||
Conflicts:
|
Conflicts:
|
||||||
Libs: -L${libdir} -lcrypto
|
Libs: -L${libdir} -lcrypto
|
||||||
|
@ -7,7 +7,7 @@ includedir=@includedir@
|
|||||||
|
|
||||||
Name: LibreSSL-libssl
|
Name: LibreSSL-libssl
|
||||||
Description: Secure Sockets Layer and cryptography libraries
|
Description: Secure Sockets Layer and cryptography libraries
|
||||||
Version: @LIBSSL_VERSION@
|
Version: @VERSION@
|
||||||
Requires:
|
Requires:
|
||||||
Requires.private: libcrypto
|
Requires.private: libcrypto
|
||||||
Conflicts:
|
Conflicts:
|
||||||
|
@ -7,7 +7,11 @@
|
|||||||
#define LIBCRYPTOCOMPAT_STRING_H
|
#define LIBCRYPTOCOMPAT_STRING_H
|
||||||
|
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
|
#if _MSC_VER >= 1900
|
||||||
|
#include <../ucrt/string.h>
|
||||||
|
#else
|
||||||
#include <../include/string.h>
|
#include <../include/string.h>
|
||||||
|
#endif
|
||||||
#else
|
#else
|
||||||
#include_next <string.h>
|
#include_next <string.h>
|
||||||
#endif
|
#endif
|
||||||
|
@ -7,7 +7,7 @@ includedir=@includedir@
|
|||||||
|
|
||||||
Name: LibreSSL-libtls
|
Name: LibreSSL-libtls
|
||||||
Description: Secure communications using the TLS socket protocol.
|
Description: Secure communications using the TLS socket protocol.
|
||||||
Version: @LIBTLS_VERSION@
|
Version: @VERSION@
|
||||||
Requires:
|
Requires:
|
||||||
Requires.private: libcrypto libssl
|
Requires.private: libcrypto libssl
|
||||||
Conflicts:
|
Conflicts:
|
||||||
|
9
man/CMakeLists.txt
Normal file
9
man/CMakeLists.txt
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
install(DIRECTORY .
|
||||||
|
DESTINATION share/man/man3
|
||||||
|
FILES_MATCHING PATTERN "*.3"
|
||||||
|
)
|
||||||
|
|
||||||
|
install(DIRECTORY .
|
||||||
|
DESTINATION share/man/man1
|
||||||
|
FILES_MATCHING PATTERN "*.1"
|
||||||
|
)
|
@ -4,12 +4,29 @@ set -e
|
|||||||
./autogen.sh
|
./autogen.sh
|
||||||
|
|
||||||
if [ "x$ARCH" = "xnative" ]; then
|
if [ "x$ARCH" = "xnative" ]; then
|
||||||
|
# test autotools
|
||||||
./configure
|
./configure
|
||||||
|
make -j 4 check
|
||||||
|
|
||||||
|
# make distribution
|
||||||
|
make dist
|
||||||
|
tar zxvf libressl-*.tar.gz
|
||||||
|
cd libressl-*
|
||||||
|
mkdir build
|
||||||
|
cd build
|
||||||
|
|
||||||
|
# test cmake and ninja
|
||||||
if [ `uname` = "Darwin" ]; then
|
if [ `uname` = "Darwin" ]; then
|
||||||
# OS X runs out of resources if we run 'make -j check'
|
cmake ..
|
||||||
make check
|
make
|
||||||
else
|
else
|
||||||
make -j distcheck
|
sudo apt-get update
|
||||||
|
sudo apt-get install -y python-software-properties
|
||||||
|
sudo apt-add-repository -y ppa:kalakris/cmake
|
||||||
|
sudo apt-get update
|
||||||
|
sudo apt-get install -y cmake ninja-build
|
||||||
|
cmake -GNinja ..
|
||||||
|
ninja
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
CPU=i686
|
CPU=i686
|
||||||
|
@ -4,9 +4,8 @@ include_directories(
|
|||||||
../include/compat
|
../include/compat
|
||||||
)
|
)
|
||||||
|
|
||||||
add_library(
|
set(
|
||||||
ssl
|
SSL_SRC
|
||||||
|
|
||||||
bio_ssl.c
|
bio_ssl.c
|
||||||
bs_ber.c
|
bs_ber.c
|
||||||
bs_cbb.c
|
bs_cbb.c
|
||||||
@ -51,3 +50,16 @@ add_library(
|
|||||||
t1_reneg.c
|
t1_reneg.c
|
||||||
t1_srvr.c
|
t1_srvr.c
|
||||||
)
|
)
|
||||||
|
|
||||||
|
if (BUILD_SHARED)
|
||||||
|
add_library(ssl-objects OBJECT ${SSL_SRC})
|
||||||
|
add_library(ssl STATIC $<TARGET_OBJECTS:ssl-objects>)
|
||||||
|
add_library(ssl-shared SHARED $<TARGET_OBJECTS:ssl-objects>)
|
||||||
|
set_target_properties(ssl-shared PROPERTIES OUTPUT_NAME ssl)
|
||||||
|
set_target_properties(ssl-shared PROPERTIES VERSION ${SSL_VERSION}
|
||||||
|
SOVERSION ${SSL_MAJOR_VERSION})
|
||||||
|
install(TARGETS ssl ssl-shared DESTINATION lib)
|
||||||
|
else()
|
||||||
|
add_library(ssl STATIC ${SSL_SRC})
|
||||||
|
install(TARGETS ssl DESTINATION lib)
|
||||||
|
endif()
|
||||||
|
@ -19,4 +19,16 @@ if(NOT HAVE_STRCASECMP)
|
|||||||
set(TLS_SRC ${TLS_SRC} strsep.c)
|
set(TLS_SRC ${TLS_SRC} strsep.c)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
add_library(tls ${TLS_SRC})
|
if (BUILD_SHARED)
|
||||||
|
add_library(tls-objects OBJECT ${TLS_SRC})
|
||||||
|
add_library(tls STATIC $<TARGET_OBJECTS:tls-objects>)
|
||||||
|
add_library(tls-shared SHARED $<TARGET_OBJECTS:tls-objects>)
|
||||||
|
set_target_properties(tls-shared PROPERTIES OUTPUT_NAME tls)
|
||||||
|
set_target_properties(tls-shared PROPERTIES VERSION ${TLS_VERSION}
|
||||||
|
SOVERSION ${TLS_MAJOR_VERSION})
|
||||||
|
install(TARGETS tls tls-shared DESTINATION lib)
|
||||||
|
else()
|
||||||
|
add_library(tls STATIC ${TLS_SRC})
|
||||||
|
install(TARGETS tls DESTINATION lib)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
41
update.sh
41
update.sh
@ -1,4 +1,4 @@
|
|||||||
#!/usr/bin/env bash
|
#!/bin/sh
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
openbsd_branch=`cat OPENBSD_BRANCH`
|
openbsd_branch=`cat OPENBSD_BRANCH`
|
||||||
@ -28,17 +28,17 @@ libtls_src=$CWD/openbsd/src/lib/libtls
|
|||||||
openssl_app_src=$CWD/openbsd/src/usr.bin/openssl
|
openssl_app_src=$CWD/openbsd/src/usr.bin/openssl
|
||||||
|
|
||||||
# load library versions
|
# load library versions
|
||||||
source $libcrypto_src/crypto/shlib_version
|
. $libcrypto_src/crypto/shlib_version
|
||||||
libcrypto_version=$major:$minor:0
|
libcrypto_version=$major:$minor:0
|
||||||
echo "libcrypto version $libcrypto_version"
|
echo "libcrypto version $libcrypto_version"
|
||||||
echo $libcrypto_version > crypto/VERSION
|
echo $libcrypto_version > crypto/VERSION
|
||||||
|
|
||||||
source $libssl_src/ssl/shlib_version
|
. $libssl_src/ssl/shlib_version
|
||||||
libssl_version=$major:$minor:0
|
libssl_version=$major:$minor:0
|
||||||
echo "libssl version $libssl_version"
|
echo "libssl version $libssl_version"
|
||||||
echo $libssl_version > ssl/VERSION
|
echo $libssl_version > ssl/VERSION
|
||||||
|
|
||||||
source $libtls_src/shlib_version
|
. $libtls_src/shlib_version
|
||||||
libtls_version=$major:$minor:0
|
libtls_version=$major:$minor:0
|
||||||
echo "libtls version $libtls_version"
|
echo "libtls version $libtls_version"
|
||||||
echo $libtls_version > tls/VERSION
|
echo $libtls_version > tls/VERSION
|
||||||
@ -67,19 +67,19 @@ $CP $libtls_src/tls.h libtls-standalone/include
|
|||||||
|
|
||||||
for i in crypto/compat libtls-standalone/compat; do
|
for i in crypto/compat libtls-standalone/compat; do
|
||||||
$CP $libc_src/crypt/arc4random.c \
|
$CP $libc_src/crypt/arc4random.c \
|
||||||
$libc_src/crypt/chacha_private.h \
|
$libc_src/crypt/chacha_private.h \
|
||||||
$libc_src/string/explicit_bzero.c \
|
$libc_src/string/explicit_bzero.c \
|
||||||
$libc_src/stdlib/reallocarray.c \
|
$libc_src/stdlib/reallocarray.c \
|
||||||
$libc_src/string/strcasecmp.c \
|
$libc_src/string/strcasecmp.c \
|
||||||
$libc_src/string/strlcpy.c \
|
$libc_src/string/strlcpy.c \
|
||||||
$libc_src/string/strlcat.c \
|
$libc_src/string/strlcat.c \
|
||||||
$libc_src/string/strndup.c \
|
$libc_src/string/strndup.c \
|
||||||
$libc_src/string/strnlen.c \
|
$libc_src/string/strnlen.c \
|
||||||
$libc_src/string/timingsafe_bcmp.c \
|
$libc_src/string/timingsafe_bcmp.c \
|
||||||
$libc_src/string/timingsafe_memcmp.c \
|
$libc_src/string/timingsafe_memcmp.c \
|
||||||
$libcrypto_src/crypto/getentropy_*.c \
|
$libcrypto_src/crypto/getentropy_*.c \
|
||||||
$libcrypto_src/crypto/arc4random_*.h \
|
$libcrypto_src/crypto/arc4random_*.h \
|
||||||
$i
|
$i
|
||||||
done
|
done
|
||||||
|
|
||||||
$CP include/compat/stdlib.h \
|
$CP include/compat/stdlib.h \
|
||||||
@ -143,7 +143,7 @@ $CP crypto/compat/ui_openssl_win.c crypto/ui
|
|||||||
asm_src=$libssl_src/src/crypto
|
asm_src=$libssl_src/src/crypto
|
||||||
gen_asm_stdout() {
|
gen_asm_stdout() {
|
||||||
perl $asm_src/$2 $1 > $3.tmp
|
perl $asm_src/$2 $1 > $3.tmp
|
||||||
[[ $1 == "elf" ]] && cat <<-EOF >> $3.tmp
|
[ $1 = "elf" ] && cat <<-EOF >> $3.tmp
|
||||||
#if defined(HAVE_GNU_STACK)
|
#if defined(HAVE_GNU_STACK)
|
||||||
.section .note.GNU-stack,"",%progbits
|
.section .note.GNU-stack,"",%progbits
|
||||||
#endif
|
#endif
|
||||||
@ -152,7 +152,7 @@ gen_asm_stdout() {
|
|||||||
}
|
}
|
||||||
gen_asm() {
|
gen_asm() {
|
||||||
perl $asm_src/$2 $1 $3.tmp
|
perl $asm_src/$2 $1 $3.tmp
|
||||||
[[ $1 == "elf" ]] && cat <<-EOF >> $3.tmp
|
[ $1 = "elf" ] && cat <<-EOF >> $3.tmp
|
||||||
#if defined(HAVE_GNU_STACK)
|
#if defined(HAVE_GNU_STACK)
|
||||||
.section .note.GNU-stack,"",%progbits
|
.section .note.GNU-stack,"",%progbits
|
||||||
#endif
|
#endif
|
||||||
@ -280,7 +280,8 @@ done
|
|||||||
|
|
||||||
# copy manpages
|
# copy manpages
|
||||||
echo "copying manpages"
|
echo "copying manpages"
|
||||||
echo dist_man_MANS= > man/Makefile.am
|
echo EXTRA_DIST = CMakeLists.txt > man/Makefile.am
|
||||||
|
echo dist_man_MANS = >> man/Makefile.am
|
||||||
|
|
||||||
$CP $openssl_app_src/openssl.1 man
|
$CP $openssl_app_src/openssl.1 man
|
||||||
echo "dist_man_MANS += openssl.1" >> man/Makefile.am
|
echo "dist_man_MANS += openssl.1" >> man/Makefile.am
|
||||||
|
Loading…
x
Reference in New Issue
Block a user