summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJay Sorg <jay.sorg@gmail.com>2014-03-05 12:38:17 -0800
committerJay Sorg <jay.sorg@gmail.com>2014-03-05 12:38:17 -0800
commitfe042b0c61db1a06078800079bb7ea4cc50146e3 (patch)
tree61e4156a25f96c5181c9367e9407f8d1b39f4ee5
parent98c9b8b692999a37e06e5d20349a49e1d99ca981 (diff)
downloadxrdp-proprietary-fe042b0c61db1a06078800079bb7ea4cc50146e3.tar.gz
xrdp-proprietary-fe042b0c61db1a06078800079bb7ea4cc50146e3.zip
minor fastpath changes
-rw-r--r--libxrdp/libxrdp.c15
-rw-r--r--libxrdp/xrdp_rdp.c4
2 files changed, 15 insertions, 4 deletions
diff --git a/libxrdp/libxrdp.c b/libxrdp/libxrdp.c
index ea1e7f25..85d5312e 100644
--- a/libxrdp/libxrdp.c
+++ b/libxrdp/libxrdp.c
@@ -206,7 +206,17 @@ libxrdp_process_data(struct xrdp_session *session, struct stream *s)
if (do_read)
{
- s = libxrdp_force_read(session->trans);
+ if (s == 0)
+ {
+ s = libxrdp_force_read(session->trans);
+ }
+ else
+ {
+ if ((s->next_packet == 0) || (s->next_packet >= s->end))
+ {
+ s = libxrdp_force_read(session->trans);
+ }
+ }
if (s == 0)
{
g_writeln("libxrdp_process_data: libxrdp_force_read failed");
@@ -281,8 +291,7 @@ libxrdp_process_data(struct xrdp_session *session, struct stream *s)
if (cont)
{
- cont = (s->next_packet != 0) &&
- (s->next_packet < s->end);
+ cont = (s->next_packet != 0) && (s->next_packet < s->end);
}
}
diff --git a/libxrdp/xrdp_rdp.c b/libxrdp/xrdp_rdp.c
index 729a2f29..ccc4f8b5 100644
--- a/libxrdp/xrdp_rdp.c
+++ b/libxrdp/xrdp_rdp.c
@@ -304,13 +304,14 @@ xrdp_rdp_recv(struct xrdp_rdp *self, struct stream *s, int *code)
if (s->next_packet == 0 || s->next_packet >= s->end)
{
/* check for fastpath first */
- header = (const tui8 *) (self->session->trans->in_s->p);
+ header = (const tui8 *) (s->p);
if ((header[0] != 0x3) && (header[0] != 0x3c))
{
if (xrdp_sec_recv_fastpath(self->sec_layer, s) != 0)
{
return 1;
}
+ s->next_packet = 0;
*code = 2; // special code for fastpath input
DEBUG(("out (fastpath) xrdp_rdp_recv"));
return 0;
@@ -387,6 +388,7 @@ xrdp_rdp_recv(struct xrdp_rdp *self, struct stream *s, int *code)
return 0;
}
}
+
/*****************************************************************************/
int APP_CC
xrdp_rdp_send(struct xrdp_rdp *self, struct stream *s, int pdu_type)