FreeBSD src
Go to file
Allan Jude 1780e40715 Implement SHA-512 truncated (224 and 256 bits)
This implements SHA-512/256, which generates a 256 bit hash by
calculating the SHA-512 then truncating the result. A different initial
value is used, making the result different from the first 256 bits of
the SHA-512 of the same input. SHA-512 is ~50% faster than SHA-256 on
64bit platforms, so the result is a faster 256 bit hash.

The main goal of this implementation is to enable support for this
faster hashing algorithm in ZFS. The feature was introduced into ZFS
in r289422, but is disconnected because SHA-512/256 support was missing.
A further commit will enable it in ZFS.

This is the follow on to r292782

Reviewed by:	cem
Sponsored by:	ScaleEngine Inc.
Differential Revision:	https://reviews.freebsd.org/D6061
2016-05-28 16:06:07 +00:00
bin Close the input FILE * in read_file() and the output FILE * in write_file() 2016-05-25 18:38:30 +00:00
cddl Add initial DTrace support for RISC-V. 2016-05-24 16:41:37 +00:00
contrib gcc42: Fix minor C99 parse bug 2016-05-27 03:40:52 +00:00
crypto libkrb5: Fix potential double-free 2016-05-11 23:25:59 +00:00
etc Always create loopback routes on every fib 2016-05-27 22:40:40 +00:00
gnu gcc42: Fix minor C99 parse bug 2016-05-27 03:40:52 +00:00
include WITH_META_MODE: Disable cookie handling for include installation. 2016-05-21 01:31:57 +00:00
kerberos5 Remove the old depend (mkdep) code and make FAST_DEPEND the one true way. 2016-03-30 23:50:23 +00:00
lib Implement SHA-512 truncated (224 and 256 bits) 2016-05-28 16:06:07 +00:00
libexec Fix issues found by Coverity in the rtld-elf.c:gethints(). 2016-05-25 18:10:44 +00:00
release Replace linux-f10 packages with updated linux-c6. 2016-05-27 18:20:07 +00:00
rescue DIRDEPS_BUILD: Fix and hookup rescue/rescue to the build. 2016-05-26 23:20:40 +00:00
sbin Implement SHA-512 truncated (224 and 256 bits) 2016-05-28 16:06:07 +00:00
secure Regen x86 assembly files for r299480. 2016-05-11 20:11:21 +00:00
share Move external GCC compiler hacks to bsd.sys.mk. 2016-05-27 23:03:44 +00:00
sys Implement SHA-512 truncated (224 and 256 bits) 2016-05-28 16:06:07 +00:00
targets DIRDEPS_BUILD: Fix and hookup rescue/rescue to the build. 2016-05-26 23:20:40 +00:00
tests Always create loopback routes on every fib 2016-05-27 22:40:40 +00:00
tools Update usage(..) 2016-05-27 21:12:25 +00:00
usr.bin Do libxo cleanup even in case of errors. 2016-05-26 14:21:02 +00:00
usr.sbin Only expose hint_uaddr in the ND_DEBUG case 2016-05-27 19:30:13 +00:00
.arcconfig Remove project.name which is a product of a bygone era. 2016-04-21 04:33:07 +00:00
.arclint phabricator related changes: 2015-04-20 20:33:22 +00:00
COPYRIGHT Bump copyright year. 2015-12-31 11:21:45 +00:00
LOCKS Explicitly require Security Officer's approval for kernel PRNG bits. 2013-09-17 14:19:05 +00:00
MAINTAINERS Add myself to MAINTAINERS. 2016-03-14 16:27:43 +00:00
Makefile Make armv6 hard float abi by default. Kill armv6hf. 2016-05-18 06:01:18 +00:00
Makefile.inc1 Move external GCC compiler hacks to bsd.sys.mk. 2016-05-27 23:03:44 +00:00
Makefile.libcompat Move external GCC compiler hacks to bsd.sys.mk. 2016-05-27 23:03:44 +00:00
ObsoleteFiles.inc Drop trailing asterisks. 2016-05-20 17:41:12 +00:00
README README: remove nonexistent 'games' directory. 2016-05-18 10:43:13 +00:00
UPDATING Fix typo from r300880 2016-05-27 22:44:33 +00:00

This is the top level of the FreeBSD source directory.  This file
was last revised on:
$FreeBSD$

For copyright information, please see the file COPYRIGHT in this
directory (additional copyright information also exists for some
sources in this tree - please see the specific source directories for
more information).

The Makefile in this directory supports a number of targets for
building components (or all) of the FreeBSD source tree.  See build(7)
and http://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/makeworld.html
for more information, including setting make(1) variables.

The `buildkernel` and `installkernel` targets build and install
the kernel and the modules (see below).  Please see the top of
the Makefile in this directory for more information on the
standard build targets and compile-time flags.

Building a kernel is a somewhat more involved process.  See build(7), config(8),
and http://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/kernelconfig.html
for more information.

Note: If you want to build and install the kernel with the
`buildkernel` and `installkernel` targets, you might need to build
world before.  More information is available in the handbook.

The kernel configuration files reside in the sys/<arch>/conf
sub-directory.  GENERIC is the default configuration used in release builds.
NOTES contains entries and documentation for all possible
devices, not just those commonly used.


Source Roadmap:
---------------

bin		System/user commands.

cddl		Various commands and libraries under the Common Development
		and Distribution License.

contrib		Packages contributed by 3rd parties.

crypto		Cryptography stuff (see crypto/README).

etc		Template files for /etc.

gnu		Various commands and libraries under the GNU Public License.
		Please see gnu/COPYING* for more information.

include		System include files.

kerberos5	Kerberos5 (Heimdal) package.

lib		System libraries.

libexec		System daemons.

release		Release building Makefile & associated tools.

rescue		Build system for statically linked /rescue utilities.

sbin		System commands.

secure		Cryptographic libraries and commands.

share		Shared resources.

sys		Kernel sources.

tests		Regression tests which can be run by Kyua.  See tests/README
		for additional information.

tools		Utilities for regression testing and miscellaneous tasks.

usr.bin		User commands.

usr.sbin	System administration commands.


For information on synchronizing your source tree with one or more of
the FreeBSD Project's development branches, please see:

  http://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/synching.html