mirror of
https://github.com/SoftEtherVPN/SoftEtherVPN.git
synced 2024-11-23 01:49:53 +03:00
Merge pull request #248 from ajeecai/master
Fix that ParseTcpOption doesn't work correctly
This commit is contained in:
commit
3292d83a62
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user