summaryrefslogtreecommitdiff
path: root/mysys/my_compress.c
diff options
context:
space:
mode:
authorunknown <monty@mashka.mysql.fi>2003-01-04 15:17:16 +0200
committerunknown <monty@mashka.mysql.fi>2003-01-04 15:17:16 +0200
commit2d89861033074d5f801d7fc3a5720f20f9e03e6c (patch)
treee7bb6542649b4462645d81fcac99546b763041a0 /mysys/my_compress.c
parent62b38d20ddcf4fb0f519e8b647916d7b367e894c (diff)
downloadmariadb-git-2d89861033074d5f801d7fc3a5720f20f9e03e6c.tar.gz
Added support for max_allowed_packet in option files read by mysql_option()
Extended max_allowed_packet for clients to 1G Fixed bug in sending compressed rows >= 16M Fix bug in skiping too long packets from clients. Added checking of wrong command number sent by client. include/mysql.h: Added max_allowed_packet as option parameter. include/mysql_com.h: Added COM_END to be able to check for wrong commands. libmysql/libmysql.c: Extended max_allowed_packet for clients to 1G Added support for max_allowed_packet in option files read by mysql_option() mysys/my_compress.c: Debugging output sql/net_pkg.cc: Fixed wrong handling of blobs >= 16M sql/net_serv.cc: Changed MAX_THREE_BYTES -> MAX_PACKET_LENGTH More DEBUG output and more comments Fixed bug in sending compressed rows >= 16M Optimized sending of big packets (fewer memcpy and compress data in bigger blocks) Fix bug in skiping too long packets from clients. (old code didn't always work for big packets) sql/sql_class.h: Changed type of variable sql/sql_parse.cc: Added checking of wrong command number sent by client. Changed handling of too big packets to make code safer tests/big_record.pl: E
Diffstat (limited to 'mysys/my_compress.c')
-rw-r--r--mysys/my_compress.c41
1 files changed, 25 insertions, 16 deletions
diff --git a/mysys/my_compress.c b/mysys/my_compress.c
index 1e46584d525..dd076311188 100644
--- a/mysys/my_compress.c
+++ b/mysys/my_compress.c
@@ -32,24 +32,28 @@
my_bool my_compress(byte *packet, ulong *len, ulong *complen)
{
+ DBUG_ENTER("my_compress");
if (*len < MIN_COMPRESS_LENGTH)
+ {
*complen=0;
+ DBUG_PRINT("note",("Packet too short: Not compressed"));
+ }
else
{
byte *compbuf=my_compress_alloc(packet,len,complen);
if (!compbuf)
- return *complen ? 0 : 1;
+ DBUG_RETURN(*complen ? 0 : 1);
memcpy(packet,compbuf,*len);
my_free(compbuf,MYF(MY_WME)); }
- return 0;
+ DBUG_RETURN(0);
}
byte *my_compress_alloc(const byte *packet, ulong *len, ulong *complen)
{
byte *compbuf;
- *complen = *len * 120 / 100 + 12;
- if (!(compbuf = (byte *) my_malloc(*complen,MYF(MY_WME))))
+ *complen= *len * 120 / 100 + 12;
+ if (!(compbuf= (byte *) my_malloc(*complen,MYF(MY_WME))))
return 0; /* Not enough memory */
if (compress((Bytef*) compbuf,(ulong *) complen, (Bytef*) packet,
(uLong) *len ) != Z_OK)
@@ -59,31 +63,36 @@ byte *my_compress_alloc(const byte *packet, ulong *len, ulong *complen)
}
if (*complen >= *len)
{
- *complen=0;
- my_free(compbuf,MYF(MY_WME));
+ *complen= 0;
+ my_free(compbuf, MYF(MY_WME));
+ DBUG_PRINT("note",("Packet got longer on compression; Not compressed"));
return 0;
}
- swap(ulong,*len,*complen); /* *len is now packet length */
+ swap(ulong, *len, *complen); /* *len is now packet length */
return compbuf;
}
my_bool my_uncompress (byte *packet, ulong *len, ulong *complen)
{
+ DBUG_ENTER("my_uncompress");
if (*complen) /* If compressed */
{
- byte *compbuf = (byte *) my_malloc (*complen,MYF(MY_WME));
+ byte *compbuf= (byte *) my_malloc(*complen,MYF(MY_WME));
+ int error;
if (!compbuf)
- return 1; /* Not enough memory */
- if (uncompress((Bytef*) compbuf, complen, (Bytef*) packet, *len) != Z_OK)
+ DBUG_RETURN(1); /* Not enough memory */
+ if ((error=uncompress((Bytef*) compbuf, complen, (Bytef*) packet, *len))
+ != Z_OK)
{ /* Probably wrong packet */
- my_free (compbuf,MYF(MY_WME));
- return 1;
+ DBUG_PRINT("error",("Can't uncompress packet, error: %d",error));
+ my_free(compbuf, MYF(MY_WME));
+ DBUG_RETURN(1);
}
- *len = *complen;
- memcpy(packet,compbuf,*len);
- my_free(compbuf,MYF(MY_WME));
+ *len= *complen;
+ memcpy(packet, compbuf, *len);
+ my_free(compbuf, MYF(MY_WME));
}
- return 0;
+ DBUG_RETURN(0);
}
#endif /* HAVE_COMPRESS */