diff options
author | Damien Miller <djm@mindrot.org> | 2008-05-19 14:59:37 +1000 |
---|---|---|
committer | Damien Miller <djm@mindrot.org> | 2008-05-19 14:59:37 +1000 |
commit | db255cad0531047a3e35a95af74ad2e03b054412 (patch) | |
tree | 7452c18135999436612dcb4e6e7d9c9f2abfe90f /channels.c | |
parent | e9890193032b4bba7afa40d4fc003bbf629afba2 (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.c | 9 |
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 */ |