1
0
mirror of https://github.com/SoftEtherVPN/SoftEtherVPN.git synced 2024-11-22 17:39:53 +03:00

Merge pull request #248 from ajeecai/master

Fix that ParseTcpOption doesn't work correctly
This commit is contained in:
Daiyuu Nobori 2016-11-27 17:23:43 +09:00 committed by GitHub
commit 3292d83a62

View File

@ -5429,7 +5429,7 @@ SCAN_FIRST:
void ParseTcpOption(TCP_OPTION *o, void *data, UINT size) void ParseTcpOption(TCP_OPTION *o, void *data, UINT size)
{ {
UCHAR *buf = (UCHAR *)data; UCHAR *buf = (UCHAR *)data;
UINT i; UINT i = 0;
UINT value_size = 0; UINT value_size = 0;
UINT value_id = 0; UINT value_id = 0;
UCHAR value[128]; UCHAR value[128];
@ -5441,13 +5441,18 @@ void ParseTcpOption(TCP_OPTION *o, void *data, UINT size)
Zero(o, sizeof(TCP_OPTION)); Zero(o, sizeof(TCP_OPTION));
for (i = 0;i < size;i++) while(i < size)
{ {
if (buf[i] == 0) if (buf[i] == 0)
{ {
return; return;
} }
if (buf[i] != 1) else if (buf[i] == 1)
{
i++;
continue;
}
else
{ {
value_id = buf[i]; value_id = buf[i];
i++; i++;
@ -5466,12 +5471,14 @@ void ParseTcpOption(TCP_OPTION *o, void *data, UINT size)
return; return;
} }
value_size -= 2; value_size -= 2;
Copy(value, &buf[i], value_size); Copy(value, &buf[i], value_size);
i += value_size; i += value_size;
if (i >= size) if (i > size)
{ {
return; return;
} }
switch (value_id) switch (value_id)
{ {
case 2: // MSS case 2: // MSS
@ -5486,14 +5493,13 @@ void ParseTcpOption(TCP_OPTION *o, void *data, UINT size)
if (value_size == 1) if (value_size == 1)
{ {
UCHAR *wss = (UCHAR *)value; UCHAR *wss = (UCHAR *)value;
o->WindowScaling = Endian16(*wss); o->WindowScaling = *wss;
} }
break; break;
} }
} }
} }
} }
// Create a new NAT TCP session // Create a new NAT TCP session