|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| | If getrandom returns a temporary failure, make sure errno is not polluted when
it succeeds. Thanks to deraadt@ for pointing it out. | 
| | |  | 
| | 
| 
| 
| | options from the previous run stick in interactive mode. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | specify what its valid options are and where it wants them to be stored.
This also allows for usage to be generated, almost for free, ensuring
that the options and usage are automatically kept in sync.
This will allow for a single option parsing implementation, rather than the
current one-hand-rolled-option-parsing-and-random-usage-implementation per
application.
As a starting point, port the openssl(1) rand application to the new option
parsing and usage (along with associated code clean up).
With input from doug@.
ok bcook@ doug@ | 
| | 
| 
| 
| 
| 
| | non-standard ECDH curve by name or to disable it by passing NULL.
OK jsing@ | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| | a system/superuser binary. At the same time, move the source code from its
current lib/libssl/src/apps location to a more appropriate home under
usr.bin/openssl.
ok deraadt@ miod@ | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | There is no intention to modify the string returned by strerror and
doing so is forbidden by the standard.
from Jonas 'Sortie' Termansen
ok tedu@ deraadt@ | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | The crypto/bio/bss_dgram.c file assumes that another file indirectly
includes <stdlib.h> that includes <sys/time.h>.
from Jonas 'Sortie' Termansen
ok deraadt@ tedu@ | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | These files currently depends on the wrapper <stdlib.h> file indirectly
including a header that provides select().
from Jonas 'Sortie' Termansen
ok deraadt@ tedu@ | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | rather than passing in a fixed size buffer.
This is yet another example of a horribly designed API - if the given
buffer is NULL then SSL_CIPHER_description() allocates one for us (great!),
which we then need to free (no problem). However, if this allocation fails
it returns a pointer to a static string "OPENSSL_malloc Error" - obviously
bad things happen if we call free() with this pointer.
Unfortunately, there is no way of knowing that the function failed, other
than comparing the returned string against the string literal - so do that
before calling free()...
Joint work with beck@ during g2k14. | 
| | 
| 
| 
| 
| 
| 
| | ssl3_cipher_get_value() helper function, which returns the cipher suite
value for the given cipher.
ok miod@ | 
| | 
| 
| 
| 
| 
| | currently).
From Dmitry Eremin-Solenikov. | 
| | 
| 
| 
| 
| 
| | ssl3_get_cipher_by_id().
ok bcook@ | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| | Let the compiler optimize these. Even older versions of gcc generate
equal or better quality code than the inline asm.
ok miod@ | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | These macros and asm inlines simulate a function returning a value, but
nothing ever uses this return value. Remove the pseudo-returns and
(void) casts discarding the unused values.
This, maybe unsurprisingly, speeds things up a bit. It also removes the
GCC 4.9 warnings about unused values.
ok miod@ deraadt@ | 
| | 
| 
| 
| 
| 
| 
| | to hold the malloc lock across mmap syscalls in all cases. dropping it
allows another thread to access the existing chunk cache if necessary.
could be improved to be a bit more aggressive, but i've been testing this
simple diff for some time now with good results. | 
| | |  | 
| | 
| 
| 
| | like the sysctl path | 
| | 
| 
| 
| | this causes errors with stricter C compilers | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This enables support for the new getrandom(2) syscall in Linux 3.17.
If the call exists and fails, return a failure in getentropy(2) emulation as
well. This adds a EINTR check in case the urandom pool is not initialized.
Tested on Fedora Rawhide with 3.17rc0 and Ubuntu 14.04
ok deraadt@ | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | circular lists.  Amazingly, they managed to extend the requirements to no
longer match the behavior of the VAX instructions they were modeled after,
so the trivial VAX ASM versions have to go.  Nice job breaking it, X/Open!
Based on a diff from enh (at) google.com
ok miod@ | 
| | 
| 
| 
| | millert@ and jmc@ agree that "overriden" is wrong | 
| | 
| 
| 
| 
| | case of failing to map the 2nd object.
found by Paul Maurers | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | original OpenSSL commit message follows:
Fixed as shown; to be released post-1.0.2
commit bebbb11d132cc149f7713d6693703f8bfae10072
Author: Ingo Schwarze <schwarze@usta.de>
Date: Sat Jan 18 11:46:25 2014 +0100
RT3239: Extra comma in NAME lines of two manpages
In two OpenSSL manual pages, in the NAME section, the last word of the
name list is followed by a stray trailing comma. While this may seem
minor, it is worth fixing because it may confuse some makewhatis(8)
implementations.
While here, also add the missing word "size" to the one line
description in SSL_CTX_set_max_cert_list(3).
Reviewed by: Dr Stephen Henson <shenson@drh-consultancy.co.uk> | 
| | 
| 
| 
| 
| | Without the cast/mask, the compiler is allowed to optimize this directly
to the correct CPU intrinsic for rotate. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Most assembly blocks remain inactive if OPENSSL_NO_ASM is not defined,
only enabling inline assembly, but the RSA / RC4-5 blocks (used only in
amd64 systems) turn on implicitly. Guard these two as well.
This simplifies enabling just inline ASM in portable, no effective
change in OpenBSD. | 
| | 
| 
| 
| 
| 
| | memory and can return NULL.
ok miod@ | 
| | 
| 
| 
| 
| | ssl3_get_cert_verify().
ok guenther@ jsing@ | 
| | 
| 
| 
| | ok guenther@ jsing@ | 
| | 
| 
| 
| 
| 
| 
| 
| | of writing "2". Add a define for the SSL3_CIPHER_VALUE_SIZE (rather than
using a less-readable hardcoded constant everywhere) and replace the
ssl3_put_char_by_bytes(NULL, NULL) calls with it.
ok bcook@ miod@ | 
| | 
| 
| 
| 
| 
| 
| 
| | up by their ID. For one, this avoids an ugly mess in ssl_sess.c, where the
cipher value is manually written into a buffer, just so the cipher can be
located using ssl3_get_cipher_by_char().
ok bcook@ miod@ | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| | the cipher list. This reduces code size, saves data segment space and
prevents them from being turned back on at runtime by flipping a bit in
memory.
ok guenther@ | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | unravelling the maze of function pointers and callbacks by directly
calling ssl3_{get,put}_cipher_by_char() and removing the
ssl_{get,put}_cipher_by_char macros.
Prompted by similar changes in boringssl.
ok guenther. | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | structure when a zero-length fragment is received.
Based on
https://git.openssl.org/gitweb/?p=openssl.git;a=commitdiff;h=d0a4b7d1a2948fce38515b8d862f43e7ba0ebf74
diff by miod@, ok guenther@ bcook@ deraadt@ | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | - make sure the output buffer is always NUL terminated if buf_len
   was initially greater than zero.
 - reject OIDs that are too long, too short, or not in proper base-127
Based on
https://git.openssl.org/gitweb/?p=openssl.git;a=commit;h=0042fb5fd1c9d257d713b15a1f45da05cf5c1c87
ok bcook@ |