mirror of
https://github.com/MariaDB/server.git
synced 2025-01-21 22:34:18 +01:00
Bug#35616: memory overrun on 64-bit linux on setting large values for keybuffer-size
add'l portability fixes
This commit is contained in:
commit
8ab01e5ce0
1 changed files with 27 additions and 26 deletions
|
@ -151,9 +151,10 @@ void *_mymalloc(size_t size, const char *filename, uint lineno, myf MyFlags)
|
||||||
my_errno=errno;
|
my_errno=errno;
|
||||||
sprintf(buff,"Out of memory at line %d, '%s'", lineno, filename);
|
sprintf(buff,"Out of memory at line %d, '%s'", lineno, filename);
|
||||||
my_message(EE_OUTOFMEMORY, buff, MYF(ME_BELL+ME_WAITTANG+ME_NOREFRESH));
|
my_message(EE_OUTOFMEMORY, buff, MYF(ME_BELL+ME_WAITTANG+ME_NOREFRESH));
|
||||||
sprintf(buff,"needed %u byte (%ldk), memory in use: %ld bytes (%ldk)",
|
sprintf(buff,"needed %lu byte (%luk), memory in use: %lu bytes (%luk)",
|
||||||
(uint) size, (uint) (size + 1023L) / 1024L,
|
(ulong) size, (ulong) (size + 1023L) / 1024L,
|
||||||
sf_malloc_max_memory, (sf_malloc_max_memory + 1023L) / 1024L);
|
(ulong) sf_malloc_max_memory,
|
||||||
|
(ulong) (sf_malloc_max_memory + 1023L) / 1024L);
|
||||||
my_message(EE_OUTOFMEMORY, buff, MYF(ME_BELL+ME_WAITTANG+ME_NOREFRESH));
|
my_message(EE_OUTOFMEMORY, buff, MYF(ME_BELL+ME_WAITTANG+ME_NOREFRESH));
|
||||||
}
|
}
|
||||||
DBUG_PRINT("error",("Out of memory, in use: %ld at line %d, '%s'",
|
DBUG_PRINT("error",("Out of memory, in use: %ld at line %d, '%s'",
|
||||||
|
@ -193,7 +194,7 @@ void *_mymalloc(size_t size, const char *filename, uint lineno, myf MyFlags)
|
||||||
if ((MyFlags & MY_ZEROFILL) || !sf_malloc_quick)
|
if ((MyFlags & MY_ZEROFILL) || !sf_malloc_quick)
|
||||||
bfill(data, size, (char) (MyFlags & MY_ZEROFILL ? 0 : ALLOC_VAL));
|
bfill(data, size, (char) (MyFlags & MY_ZEROFILL ? 0 : ALLOC_VAL));
|
||||||
/* Return a pointer to the real data */
|
/* Return a pointer to the real data */
|
||||||
DBUG_PRINT("exit",("ptr: 0x%lx", (long) data));
|
DBUG_PRINT("exit",("ptr: %p", data));
|
||||||
if (sf_min_adress > data)
|
if (sf_min_adress > data)
|
||||||
sf_min_adress= data;
|
sf_min_adress= data;
|
||||||
if (sf_max_adress < data)
|
if (sf_max_adress < data)
|
||||||
|
@ -258,7 +259,7 @@ void _myfree(void *ptr, const char *filename, uint lineno, myf myflags)
|
||||||
{
|
{
|
||||||
struct st_irem *irem;
|
struct st_irem *irem;
|
||||||
DBUG_ENTER("_myfree");
|
DBUG_ENTER("_myfree");
|
||||||
DBUG_PRINT("enter",("ptr: 0x%lx", (long) ptr));
|
DBUG_PRINT("enter",("ptr: %p", ptr));
|
||||||
|
|
||||||
if (!sf_malloc_quick)
|
if (!sf_malloc_quick)
|
||||||
(void) _sanity (filename, lineno);
|
(void) _sanity (filename, lineno);
|
||||||
|
@ -391,12 +392,12 @@ void TERMINATE(FILE *file, uint flag)
|
||||||
{
|
{
|
||||||
if (file)
|
if (file)
|
||||||
{
|
{
|
||||||
fprintf(file, "Warning: Memory that was not free'ed (%ld bytes):\n",
|
fprintf(file, "Warning: Memory that was not free'ed (%lu bytes):\n",
|
||||||
sf_malloc_cur_memory);
|
(ulong) sf_malloc_cur_memory);
|
||||||
(void) fflush(file);
|
(void) fflush(file);
|
||||||
}
|
}
|
||||||
DBUG_PRINT("safe",("Memory that was not free'ed (%ld bytes):",
|
DBUG_PRINT("safe",("Memory that was not free'ed (%lu bytes):",
|
||||||
sf_malloc_cur_memory));
|
(ulong) sf_malloc_cur_memory));
|
||||||
while (irem)
|
while (irem)
|
||||||
{
|
{
|
||||||
char *data= (((char*) irem) + ALIGN_SIZE(sizeof(struct st_irem)) +
|
char *data= (((char*) irem) + ALIGN_SIZE(sizeof(struct st_irem)) +
|
||||||
|
@ -404,27 +405,29 @@ void TERMINATE(FILE *file, uint flag)
|
||||||
if (file)
|
if (file)
|
||||||
{
|
{
|
||||||
fprintf(file,
|
fprintf(file,
|
||||||
"\t%6u bytes at 0x%09lx, allocated at line %4u in '%s'",
|
"\t%6lu bytes at %p, allocated at line %4u in '%s'",
|
||||||
irem->datasize, (long) data, irem->linenum, irem->filename);
|
(ulong) irem->datasize, data, irem->linenum, irem->filename);
|
||||||
fprintf(file, "\n");
|
fprintf(file, "\n");
|
||||||
(void) fflush(file);
|
(void) fflush(file);
|
||||||
}
|
}
|
||||||
DBUG_PRINT("safe",
|
DBUG_PRINT("safe",
|
||||||
("%6u bytes at 0x%09lx, allocated at line %4d in '%s'",
|
("%6lu bytes at %p, allocated at line %4d in '%s'",
|
||||||
irem->datasize, (long) data, irem->linenum, irem->filename));
|
(ulong) irem->datasize,
|
||||||
|
data, irem->linenum, irem->filename));
|
||||||
irem= irem->next;
|
irem= irem->next;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/* Report the memory usage statistics */
|
/* Report the memory usage statistics */
|
||||||
if (file && flag)
|
if (file && flag)
|
||||||
{
|
{
|
||||||
fprintf(file, "Maximum memory usage: %ld bytes (%ldk)\n",
|
fprintf(file, "Maximum memory usage: %lu bytes (%luk)\n",
|
||||||
sf_malloc_max_memory, (sf_malloc_max_memory + 1023L) / 1024L);
|
(ulong) sf_malloc_max_memory,
|
||||||
|
(ulong) (sf_malloc_max_memory + 1023L) / 1024L);
|
||||||
(void) fflush(file);
|
(void) fflush(file);
|
||||||
}
|
}
|
||||||
DBUG_PRINT("safe",("Maximum memory usage: %ld bytes (%ldk)",
|
DBUG_PRINT("safe",("Maximum memory usage: %lu bytes (%luk)",
|
||||||
sf_malloc_max_memory, (sf_malloc_max_memory + 1023L) /
|
(ulong) sf_malloc_max_memory,
|
||||||
1024L));
|
(ulong) (sf_malloc_max_memory + 1023L) /1024L));
|
||||||
pthread_mutex_unlock(&THR_LOCK_malloc);
|
pthread_mutex_unlock(&THR_LOCK_malloc);
|
||||||
DBUG_VOID_RETURN;
|
DBUG_VOID_RETURN;
|
||||||
}
|
}
|
||||||
|
@ -446,8 +449,8 @@ void sf_malloc_report_allocated(void *memory)
|
||||||
sf_malloc_prehunc);
|
sf_malloc_prehunc);
|
||||||
if (data <= (char*) memory && (char*) memory <= data + irem->datasize)
|
if (data <= (char*) memory && (char*) memory <= data + irem->datasize)
|
||||||
{
|
{
|
||||||
printf("%u bytes at 0x%lx, allocated at line %u in '%s'\n",
|
printf("%lu bytes at %p, allocated at line %u in '%s'\n",
|
||||||
irem->datasize, (long) data, irem->linenum, irem->filename);
|
(ulong) irem->datasize, data, irem->linenum, irem->filename);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -470,8 +473,8 @@ static int _checkchunk(register struct st_irem *irem, const char *filename,
|
||||||
irem->filename, irem->linenum);
|
irem->filename, irem->linenum);
|
||||||
fprintf(stderr, " discovered at %s:%d\n", filename, lineno);
|
fprintf(stderr, " discovered at %s:%d\n", filename, lineno);
|
||||||
(void) fflush(stderr);
|
(void) fflush(stderr);
|
||||||
DBUG_PRINT("safe",("Underrun at 0x%lx, allocated at %s:%d",
|
DBUG_PRINT("safe",("Underrun at %p, allocated at %s:%d",
|
||||||
(long) data, irem->filename, irem->linenum));
|
data, irem->filename, irem->linenum));
|
||||||
flag=1;
|
flag=1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -486,10 +489,8 @@ static int _checkchunk(register struct st_irem *irem, const char *filename,
|
||||||
irem->filename, irem->linenum);
|
irem->filename, irem->linenum);
|
||||||
fprintf(stderr, " discovered at '%s:%d'\n", filename, lineno);
|
fprintf(stderr, " discovered at '%s:%d'\n", filename, lineno);
|
||||||
(void) fflush(stderr);
|
(void) fflush(stderr);
|
||||||
DBUG_PRINT("safe",("Overrun at 0x%lx, allocated at %s:%d",
|
DBUG_PRINT("safe",("Overrun at %p, allocated at %s:%d",
|
||||||
(long) data,
|
data, irem->filename, irem->linenum));
|
||||||
irem->filename,
|
|
||||||
irem->linenum));
|
|
||||||
flag=1;
|
flag=1;
|
||||||
}
|
}
|
||||||
return(flag);
|
return(flag);
|
||||||
|
|
Loading…
Add table
Reference in a new issue