From 4c31b113a6deb4894b640e4989ae9ef1f8063c0e Mon Sep 17 00:00:00 2001 From: Simon Tatham Date: Wed, 1 Dec 2004 13:42:50 +0000 Subject: [PATCH] And now I look at it, the latest draft also says version strings should be followed by \r\n, not just \n. [originally from svn r4940] --- ssh.c | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/ssh.c b/ssh.c index 835a8579..cb8380ca 100644 --- a/ssh.c +++ b/ssh.c @@ -2184,13 +2184,13 @@ static int do_ssh_init(Ssh ssh, unsigned char c) /* * Construct a v2 version string. */ - verstring = dupprintf("SSH-2.0-%s\n", sshver); + verstring = dupprintf("SSH-2.0-%s\r\n", sshver); ssh->version = 2; } else { /* * Construct a v1 version string. */ - verstring = dupprintf("SSH-%s-%s\n", + verstring = dupprintf("SSH-%s-%s\r\n", (ssh_versioncmp(s->version, "1.5") <= 0 ? s->version : "1.5"), sshver); @@ -2204,8 +2204,10 @@ static int do_ssh_init(Ssh ssh, unsigned char c) * Hash our version string and their version string. */ SHA_Init(&ssh->exhashbase); - sha_string(&ssh->exhashbase, verstring, strlen(verstring)-1); - sha_string(&ssh->exhashbase, s->vstring, strcspn(s->vstring, "\r\n")); + sha_string(&ssh->exhashbase, verstring, + strcspn(verstring, "\r\n")); + sha_string(&ssh->exhashbase, s->vstring, + strcspn(s->vstring, "\r\n")); /* * Initialise SSHv2 protocol. @@ -2222,7 +2224,7 @@ static int do_ssh_init(Ssh ssh, unsigned char c) ssh->s_rdpkt = ssh1_rdpkt; } logeventf(ssh, "We claim version: %.*s", - strlen(verstring)-1, verstring); + strcspn(verstring, "\r\n"), verstring); sk_write(ssh->s, verstring, strlen(verstring)); sfree(verstring); }