Commit 5bd50b80 authored by Dmitry Shulga's avatar Dmitry Shulga

Fixed Bug#58887 - server not throwing "Packet too large" error

if max_allowed_packet >= 16M.

This bug was introduced by patch for bug#42503.

This patch restores behaviour that there was before patch
for bug#42503 was applied.
parent 409f7db2
...@@ -170,17 +170,7 @@ my_bool net_realloc(NET *net, size_t length) ...@@ -170,17 +170,7 @@ my_bool net_realloc(NET *net, size_t length)
DBUG_ENTER("net_realloc"); DBUG_ENTER("net_realloc");
DBUG_PRINT("enter",("length: %lu", (ulong) length)); DBUG_PRINT("enter",("length: %lu", (ulong) length));
/* if (length >= net->max_packet_size)
When compression is off, net->where_b is always 0.
With compression turned on, net->where_b may indicate
that we still have a piece of the previous logical
packet in the buffer, unprocessed. Take it into account
when checking that max_allowed_packet is not exceeded.
This ensures that the client treats max_allowed_packet
limit identically, regardless of compression being on
or off.
*/
if (length >= (net->max_packet_size + net->where_b))
{ {
DBUG_PRINT("error", ("Packet too large. Max size: %lu", DBUG_PRINT("error", ("Packet too large. Max size: %lu",
net->max_packet_size)); net->max_packet_size));
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment