summaryrefslogtreecommitdiff
path: root/channels.c
diff options
context:
space:
mode:
authorDamien Miller <djm@mindrot.org>2008-05-19 14:59:37 +1000
committerDamien Miller <djm@mindrot.org>2008-05-19 14:59:37 +1000
commitdb255cad0531047a3e35a95af74ad2e03b054412 (patch)
tree7452c18135999436612dcb4e6e7d9c9f2abfe90f /channels.c
parente9890193032b4bba7afa40d4fc003bbf629afba2 (diff)
- markus@cvs.openbsd.org 2008/05/08 06:59:01
[bufaux.c buffer.h channels.c packet.c packet.h] avoid extra malloc/copy/free when receiving data over the net; ~10% speedup for localhost-scp; ok djm@
Diffstat (limited to 'channels.c')
-rw-r--r--channels.c9
1 files changed, 3 insertions, 6 deletions
diff --git a/channels.c b/channels.c
index b6bd901f0..05c23e59c 100644
--- a/channels.c
+++ b/channels.c
@@ -1,4 +1,4 @@
1/* $OpenBSD: channels.c,v 1.273 2008/04/02 21:36:51 markus Exp $ */ 1/* $OpenBSD: channels.c,v 1.274 2008/05/08 06:59:01 markus Exp $ */
2/* 2/*
3 * Author: Tatu Ylonen <ylo@cs.hut.fi> 3 * Author: Tatu Ylonen <ylo@cs.hut.fi>
4 * Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland 4 * Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
@@ -2012,7 +2012,7 @@ channel_input_data(int type, u_int32_t seq, void *ctxt)
2012 return; 2012 return;
2013 2013
2014 /* Get the data. */ 2014 /* Get the data. */
2015 data = packet_get_string(&data_len); 2015 data = packet_get_string_ptr(&data_len);
2016 2016
2017 /* 2017 /*
2018 * Ignore data for protocol > 1.3 if output end is no longer open. 2018 * Ignore data for protocol > 1.3 if output end is no longer open.
@@ -2026,7 +2026,6 @@ channel_input_data(int type, u_int32_t seq, void *ctxt)
2026 c->local_window -= data_len; 2026 c->local_window -= data_len;
2027 c->local_consumed += data_len; 2027 c->local_consumed += data_len;
2028 } 2028 }
2029 xfree(data);
2030 return; 2029 return;
2031 } 2030 }
2032 2031
@@ -2038,17 +2037,15 @@ channel_input_data(int type, u_int32_t seq, void *ctxt)
2038 if (data_len > c->local_window) { 2037 if (data_len > c->local_window) {
2039 logit("channel %d: rcvd too much data %d, win %d", 2038 logit("channel %d: rcvd too much data %d, win %d",
2040 c->self, data_len, c->local_window); 2039 c->self, data_len, c->local_window);
2041 xfree(data);
2042 return; 2040 return;
2043 } 2041 }
2044 c->local_window -= data_len; 2042 c->local_window -= data_len;
2045 } 2043 }
2046 packet_check_eom();
2047 if (c->datagram) 2044 if (c->datagram)
2048 buffer_put_string(&c->output, data, data_len); 2045 buffer_put_string(&c->output, data, data_len);
2049 else 2046 else
2050 buffer_append(&c->output, data, data_len); 2047 buffer_append(&c->output, data, data_len);
2051 xfree(data); 2048 packet_check_eom();
2052} 2049}
2053 2050
2054/* ARGSUSED */ 2051/* ARGSUSED */