Portable OpenSSH
Go to file
deraadt@openbsd.org aabd75ec76 upstream commit
time_t printing needs %lld and (long long) casts ok djm

OpenBSD-Commit-ID: 4a93bc2b0d42a39b8f8de8bb74d07ad2e5e83ef7
2017-12-12 10:32:04 +11:00
contrib Replace mkinstalldirs with mkdir -p. 2017-12-01 17:13:34 +11:00
openbsd-compat Include string.h for explicit_bzero. 2017-11-24 16:24:31 +11:00
regress upstream commit 2017-10-31 09:08:52 +11:00
.depend Add autogenerated dependency info to Makefile. 2017-12-11 14:38:33 +11:00
.gitignore Fuzzer harnesses for sig verify and pubkey parsing 2017-09-08 12:44:13 +10:00
.skipped-commit-ids Switch upstream git repository. 2017-10-31 09:05:16 +11:00
CREDITS Remove now-obsolete CVS $Id tags from text files. 2016-08-17 13:40:58 +10:00
INSTALL Add autogenerated dependency info to Makefile. 2017-12-11 14:38:33 +11:00
LICENCE upstream commit 2017-05-01 10:05:04 +10:00
Makefile.in Add autogenerated dependency info to Makefile. 2017-12-11 14:38:33 +11:00
OVERVIEW
PROTOCOL upstream commit 2017-05-27 15:35:52 +10:00
PROTOCOL.agent update URL again 2017-10-01 10:32:25 +11:00
PROTOCOL.certkeys upstream commit 2017-11-03 16:20:41 +11:00
PROTOCOL.chacha20poly1305 upstream commit 2016-05-04 00:55:21 +10:00
PROTOCOL.key
PROTOCOL.krl
PROTOCOL.mux
README sync release notes URL 2017-10-01 10:01:56 +11:00
README.dns
README.platform Remove now-obsolete CVS $Id tags from text files. 2016-08-17 13:40:58 +10:00
README.privsep Remove portability support for mmap 2016-09-29 03:19:23 +10:00
README.tun
TODO Remove portability support for mmap 2016-09-29 03:19:23 +10:00
aclocal.m4 Test multiplying two long long ints. 2016-08-17 13:35:43 +10:00
addrmatch.c upstream commit 2016-09-22 03:14:59 +10:00
atomicio.c upstream commit 2016-08-03 15:38:43 +10:00
atomicio.h
audit-bsm.c Remove obsolete CVS $Id from source files. 2016-08-17 14:08:42 +10:00
audit-linux.c Remove obsolete CVS $Id from source files. 2016-08-17 14:08:42 +10:00
audit.c Remove obsolete CVS $Id from source files. 2016-08-17 14:08:42 +10:00
audit.h Remove obsolete CVS $Id from source files. 2016-08-17 14:08:42 +10:00
auth-bsdauth.c
auth-krb5.c upstream commit 2016-05-19 17:48:34 +10:00
auth-options.c upstream commit 2017-09-12 17:37:02 +10:00
auth-options.h upstream commit 2017-06-01 14:55:23 +10:00
auth-pam.c Expose list of completed auth methods to PAM 2017-07-28 15:04:00 +10:00
auth-pam.h Remove do_pam_set_tty which is dead code. 2016-10-15 04:34:46 +11:00
auth-passwd.c upstream commit 2016-07-22 13:36:40 +10:00
auth-rhosts.c upstream commit 2016-08-14 11:19:14 +10:00
auth-shadow.c
auth-sia.c
auth-sia.h
auth-skey.c
auth.c upstream commit 2017-09-12 17:37:02 +10:00
auth.h upstream commit 2017-08-23 19:47:06 +10:00
auth2-chall.c upstream commit 2017-05-31 10:50:33 +10:00
auth2-gss.c upstream commit 2017-06-24 16:56:11 +10:00
auth2-hostbased.c upstream commit 2017-06-24 16:56:11 +10:00
auth2-kbdint.c upstream commit 2017-05-31 10:50:33 +10:00
auth2-none.c upstream commit 2017-05-31 10:50:33 +10:00
auth2-passwd.c upstream commit 2017-05-31 10:50:33 +10:00
auth2-pubkey.c upstream commit 2017-09-12 16:42:20 +10:00
auth2.c upstream commit 2017-06-24 16:56:11 +10:00
authfd.c upstream commit 2017-07-21 14:17:32 +10:00
authfd.h upstream commit 2017-06-28 11:13:19 +10:00
authfile.c upstream commit 2017-07-21 14:17:32 +10:00
authfile.h
bitmap.c upstream commit 2017-10-20 12:58:35 +11:00
bitmap.h upstream commit 2017-10-20 12:58:35 +11:00
blocks.c
bufaux.c
bufbn.c upstream commit 2017-05-01 10:05:02 +10:00
bufec.c
buffer.c
buffer.h upstream commit 2017-05-01 10:05:02 +10:00
buildpkg.sh.in Update links to https. 2016-10-21 06:55:58 +11:00
canohost.c
canohost.h
chacha.c
chacha.h upstream commit 2016-08-29 11:20:28 +10:00
channels.c upstream commit 2017-12-07 11:46:35 +11:00
channels.h upstream commit 2017-09-22 09:14:53 +10:00
cipher-aes.c
cipher-aesctr.c
cipher-aesctr.h
cipher-chachapoly.c upstream commit 2016-08-09 09:06:52 +10:00
cipher-chachapoly.h
cipher-ctr.c
cipher.c upstream commit 2017-11-03 13:24:59 +11:00
cipher.h upstream commit 2017-05-08 09:21:00 +10:00
cleanup.c
clientloop.c upstream commit 2017-11-28 11:39:13 +11:00
clientloop.h upstream commit 2017-10-23 16:14:30 +11:00
compat.c upstream commit 2017-07-28 13:08:37 +10:00
compat.h upstream commit 2017-05-01 09:42:37 +10:00
config.guess update config.guess and config.sub to current 2016-08-02 10:48:04 +10:00
config.sub update config.guess and config.sub to current 2016-08-02 10:48:04 +10:00
configure.ac Add autogenerated dependency info to Makefile. 2017-12-11 14:38:33 +11:00
crc32.c
crc32.h
crypto_api.h
defines.h portability for sftp globbed ls sort by mtime 2017-06-10 23:41:25 +10:00
dh.c only enable functions in dh.c when openssl is used 2017-11-03 13:13:54 +11:00
dh.h upstream commit 2016-05-02 20:39:32 +10:00
digest-libc.c upstream commit 2017-05-10 11:41:21 +10:00
digest-openssl.c upstream commit 2017-05-10 11:41:21 +10:00
digest.h upstream commit 2017-05-10 11:41:21 +10:00
dispatch.c upstream commit 2017-06-01 14:53:33 +10:00
dispatch.h upstream commit 2017-06-01 14:53:33 +10:00
dns.c upstream commit 2017-09-14 14:33:06 +10:00
dns.h upstream commit 2017-09-14 14:33:06 +10:00
ed25519.c
entropy.c
entropy.h Remove obsolete CVS $Id from source files. 2016-08-17 14:08:42 +10:00
fatal.c
fe25519.c
fe25519.h
fixalgorithms
fixpaths
fixprogs
ge25519.c
ge25519.h
ge25519_base.data
groupaccess.c
groupaccess.h
gss-genr.c upstream commit 2016-09-12 13:46:29 +10:00
gss-serv-krb5.c
gss-serv.c upstream commit 2017-06-24 16:56:11 +10:00
hash.c
hmac.c
hmac.h
hostfile.c upstream commit 2017-06-01 14:55:22 +10:00
hostfile.h
includes.h portability for sftp globbed ls sort by mtime 2017-06-10 23:41:25 +10:00
install-sh Pull in newer install-sh from autoconf-2.69. 2017-12-01 17:07:08 +11:00
kex.c upstream commit 2017-06-13 22:15:08 +10:00
kex.h upstream commit 2017-05-31 10:50:05 +10:00
kexc25519.c upstream commit 2016-05-02 20:35:04 +10:00
kexc25519c.c upstream commit 2017-05-31 14:17:41 +10:00
kexc25519s.c upstream commit 2017-10-20 12:58:18 +11:00
kexdh.c upstream commit 2016-05-02 20:39:32 +10:00
kexdhc.c upstream commit 2017-05-31 10:50:05 +10:00
kexdhs.c upstream commit 2017-05-31 10:50:05 +10:00
kexecdh.c
kexecdhc.c upstream commit 2017-05-31 10:50:05 +10:00
kexecdhs.c upstream commit 2017-05-31 10:50:05 +10:00
kexgex.c
kexgexc.c upstream commit 2017-05-31 10:50:05 +10:00
kexgexs.c upstream commit 2017-05-31 10:50:05 +10:00
key.c upstream commit 2017-05-31 10:49:50 +10:00
key.h upstream commit 2017-05-31 10:49:50 +10:00
krl.c upstream commit 2017-06-01 14:55:22 +10:00
krl.h
log.c upstream commit 2017-05-17 11:25:22 +10:00
log.h upstream commit 2017-05-17 11:25:22 +10:00
loginrec.c
loginrec.h
logintest.c
mac.c upstream commit 2017-05-10 11:41:21 +10:00
mac.h upstream commit 2016-07-08 13:50:03 +10:00
match.c upstream commit 2017-03-10 15:35:40 +11:00
match.h upstream commit 2017-02-04 10:08:15 +11:00
md5crypt.c
md5crypt.h Remove obsolete CVS $Id from source files. 2016-08-17 14:08:42 +10:00
mdoc2man.awk fix mdoc2man.awk formatting for top-level lists 2016-09-28 07:40:33 +10:00
misc.c upstream commit 2017-12-12 10:32:04 +11:00
misc.h upstream commit 2017-12-07 11:49:00 +11:00
mkinstalldirs
moduli upstream commit 2017-12-07 11:40:38 +11:00
moduli.5
moduli.c upstream commit 2017-12-12 10:32:04 +11:00
monitor.c upstream commit 2017-10-20 12:01:02 +11:00
monitor.h upstream commit 2016-09-29 03:11:32 +10:00
monitor_fdpass.c
monitor_fdpass.h
monitor_wrap.c upstream commit 2017-10-20 12:01:02 +11:00
monitor_wrap.h upstream commit 2017-06-01 14:54:46 +10:00
msg.c
msg.h
mux.c upstream commit 2017-09-22 09:14:53 +10:00
myproposal.h upstream commit 2017-05-08 09:21:11 +10:00
nchan.c upstream commit 2017-09-12 17:37:03 +10:00
nchan.ms
nchan2.ms
opacket.c upstream commit 2017-10-20 12:58:35 +11:00
opacket.h upstream commit 2017-10-20 12:58:35 +11:00
openssh.xml.in
opensshd.init.in Remove RSA1 host key generation. 2017-12-01 16:55:35 +11:00
packet.c upstream commit 2017-11-28 12:01:49 +11:00
packet.h upstream commit 2017-10-25 12:26:13 +11:00
pathnames.h upstream commit 2017-05-08 09:18:27 +10:00
pkcs11.h
platform-misc.c Split platform_sys_dir_uid into its own file 2017-08-25 13:25:01 +10:00
platform-pledge.c
platform-tracing.c Use ptrace(PT_DENY_ATTACH, ..) on OS X. 2016-11-01 08:12:33 +11:00
platform.c Split platform_sys_dir_uid into its own file 2017-08-25 13:25:01 +10:00
platform.h Remove obsolete CVS $Id from source files. 2016-08-17 14:08:42 +10:00
poly1305.c
poly1305.h
progressmeter.c upstream commit 2016-07-08 13:46:59 +10:00
progressmeter.h
readconf.c upstream commit 2017-12-07 11:49:00 +11:00
readconf.h upstream commit 2017-10-23 16:10:08 +11:00
readpass.c
rijndael.c
rijndael.h
sandbox-capsicum.c Switch Capsicum header to sys/capsicum.h. 2017-08-28 16:48:27 +10:00
sandbox-darwin.c Add missing monitor.h include. 2016-12-16 15:02:24 +11:00
sandbox-null.c
sandbox-pledge.c
sandbox-rlimit.c upstream commit 2016-09-12 13:46:29 +10:00
sandbox-seccomp-filter.c Fix typo in "socketcall". 2017-04-25 08:32:27 +10:00
sandbox-solaris.c drop two more privileges in the Solaris sandbox 2017-06-09 14:44:43 +10:00
sandbox-systrace.c
sc25519.c
sc25519.h
scp.1 upstream commit 2017-10-31 09:08:50 +11:00
scp.c upstream commit 2017-10-23 16:10:08 +11:00
servconf.c upstream commit 2017-12-07 11:49:00 +11:00
servconf.h upstream commit 2017-10-25 12:26:21 +11:00
serverloop.c upstream commit 2017-10-23 16:14:30 +11:00
serverloop.h upstream commit 2017-09-12 17:37:02 +10:00
session.c upstream commit 2017-10-23 16:14:30 +11:00
session.h upstream commit 2017-09-12 17:37:02 +10:00
sftp-client.c upstream commit 2017-12-07 11:38:50 +11:00
sftp-client.h
sftp-common.c upstream commit 2017-06-10 16:40:11 +10:00
sftp-common.h
sftp-glob.c
sftp-server-main.c
sftp-server.8
sftp-server.c upstream commit 2017-04-04 10:26:01 +10:00
sftp.1 upstream commit 2017-11-03 16:20:41 +11:00
sftp.c upstream commit 2017-11-03 16:20:41 +11:00
sftp.h
smult_curve25519_ref.c
ssh-add.1 upstream commit 2017-09-04 09:38:57 +10:00
ssh-add.c upstream commit 2017-09-04 09:38:57 +10:00
ssh-agent.1 upstream commit 2016-11-30 19:44:25 +11:00
ssh-agent.c upstream commit 2017-11-15 13:25:16 +11:00
ssh-dss.c upstream commit 2016-04-21 16:30:11 +10:00
ssh-ecdsa.c upstream commit 2016-04-21 16:30:11 +10:00
ssh-ed25519.c upstream commit 2016-04-21 16:30:11 +10:00
ssh-gss.h upstream commit 2017-06-24 16:56:11 +10:00
ssh-keygen.1 upstream commit 2017-11-03 16:20:41 +11:00
ssh-keygen.c upstream commit 2017-11-03 16:20:41 +11:00
ssh-keyscan.1 upstream commit 2017-05-08 09:18:05 +10:00
ssh-keyscan.c upstream commit 2017-11-28 12:01:49 +11:00
ssh-keysign.8
ssh-keysign.c
ssh-pkcs11-client.c upstream commit 2017-05-31 10:47:31 +10:00
ssh-pkcs11-helper.8
ssh-pkcs11-helper.c upstream commit 2017-05-31 10:47:31 +10:00
ssh-pkcs11.c upstream commit 2017-06-01 14:55:22 +10:00
ssh-pkcs11.h
ssh-rsa.c upstream commit 2017-07-21 14:17:32 +10:00
ssh-sandbox.h
ssh.1 upstream commit 2017-11-03 16:20:41 +11:00
ssh.c upstream commit 2017-11-01 11:08:56 +11:00
ssh.h upstream commit 2017-05-08 09:21:22 +10:00
ssh2.h upstream commit 2016-05-19 17:48:34 +10:00
ssh_api.c upstream commit 2017-05-01 09:42:37 +10:00
ssh_api.h
ssh_config upstream commit 2017-05-08 09:21:00 +10:00
ssh_config.5 upstream commit 2017-10-25 11:22:23 +11:00
sshbuf-getput-basic.c upstream commit 2017-06-01 14:55:23 +10:00
sshbuf-getput-crypto.c
sshbuf-misc.c upstream commit 2016-05-02 20:35:04 +10:00
sshbuf.c upstream commit 2017-06-07 11:31:15 +10:00
sshbuf.h upstream commit 2017-09-12 17:37:02 +10:00
sshconnect.c upstream commit 2017-12-07 11:49:00 +11:00
sshconnect.h upstream commit 2017-09-12 17:37:02 +10:00
sshconnect2.c upstream commit 2017-09-04 09:38:57 +10:00
sshd.8 upstream commit 2017-11-03 16:20:41 +11:00
sshd.c upstream commit 2017-11-14 11:46:38 +11:00
sshd_config upstream commit 2017-03-15 11:09:18 +11:00
sshd_config.5 upstream commit 2017-10-31 09:08:50 +11:00
ssherr.c upstream commit 2017-09-12 17:37:02 +10:00
ssherr.h upstream commit 2017-09-12 17:37:02 +10:00
sshkey.c upstream commit 2017-10-20 12:01:03 +11:00
sshkey.h upstream commit 2017-07-21 14:17:32 +10:00
sshlogin.c
sshlogin.h
sshpty.c upstream commit 2016-11-29 16:51:27 +11:00
sshpty.h upstream commit 2016-11-29 16:51:27 +11:00
sshtty.c
survey.sh.in
ttymodes.c upstream commit 2017-05-01 10:05:04 +10:00
ttymodes.h upstream commit 2017-05-01 10:05:04 +10:00
uidswap.c
uidswap.h
umac.c upstream commit 2017-11-28 17:19:06 +11:00
umac.h
utf8.c upstream commit 2017-06-01 14:55:22 +10:00
utf8.h Force Turkish locales back to C/POSIX; bz#2643 2016-12-12 13:58:59 +11:00
uuencode.c
uuencode.h
verify.c
version.h upstream commit 2017-10-01 09:27:30 +11:00
xmalloc.c upstream commit 2017-06-01 14:55:22 +10:00
xmalloc.h upstream commit 2017-06-01 14:55:22 +10:00

README

See https://www.openssh.com/releasenotes.html#7.6p1 for the release notes.

Please read https://www.openssh.com/report.html for bug reporting
instructions and note that we do not use Github for bug reporting or
patch/pull-request management.

- A Japanese translation of this document and of the release notes is
- available at http://www.unixuser.org/~haruyama/security/openssh/index.html
- Thanks to HARUYAMA Seigo <haruyama@unixuser.org>

This is the port of OpenBSD's excellent OpenSSH[0] to Linux and other
Unices.

OpenSSH is based on the last free version of Tatu Ylonen's sample
implementation with all patent-encumbered algorithms removed (to
external libraries), all known security bugs fixed, new features
reintroduced and many other clean-ups.  OpenSSH has been created by
Aaron Campbell, Bob Beck, Markus Friedl, Niels Provos, Theo de Raadt,
and Dug Song. It has a homepage at https://www.openssh.com/

This port consists of the re-introduction of autoconf support, PAM
support, EGD[1]/PRNGD[2] support and replacements for OpenBSD library
functions that are (regrettably) absent from other unices. This port
has been best tested on AIX, Cygwin, HP-UX, Linux, MacOS/X,
NetBSD, OpenBSD, OpenServer, Solaris, Unicos, and UnixWare.

This version actively tracks changes in the OpenBSD CVS repository.

The PAM support is now more functional than the popular packages of
commercial ssh-1.2.x. It checks "account" and "session" modules for
all logins, not just when using password authentication.

OpenSSH depends on Zlib[3], OpenSSL[4], and optionally PAM[5] and
libedit[6]

There is now several mailing lists for this port of OpenSSH. Please
refer to https://www.openssh.com/list.html for details on how to join.

Please send bug reports and patches to the mailing list
openssh-unix-dev@mindrot.org. The list is open to posting by unsubscribed
users.  Code contribution are welcomed, but please follow the OpenBSD
style guidelines[7].

Please refer to the INSTALL document for information on how to install
OpenSSH on your system.

Damien Miller <djm@mindrot.org>

Miscellania -

This version of OpenSSH is based upon code retrieved from the OpenBSD
CVS repository which in turn was based on the last free sample
implementation released by Tatu Ylonen.

References -

[0] https://www.openssh.com/
[1] http://www.lothar.com/tech/crypto/
[2] http://www.aet.tu-cottbus.de/personen/jaenicke/postfix_tls/prngd.html
[3] http://www.gzip.org/zlib/
[4] http://www.openssl.org/
[5] http://www.openpam.org
    http://www.kernel.org/pub/linux/libs/pam/
    (PAM also is standard on Solaris and HP-UX 11)
[6] http://thrysoee.dk/editline/ (portable version)
[7] http://man.openbsd.org/style.9