mirror of
https://sourceware.org/git/glibc.git
synced 2025-01-03 08:11:08 +00:00
* malloc/malloc.c (_int_realloc): Add parameter with old block
size. Remove duplicated test. Don't handle mmap'ed blocks here. Adjust all callers. * malloc/hooks.c (realloc_check): Adjust _int_realloc call.
This commit is contained in:
parent
cd57745bd8
commit
4c8b8cc332
@ -1,3 +1,10 @@
|
|||||||
|
2009-04-08 Ulrich Drepper <drepper@redhat.com>
|
||||||
|
|
||||||
|
* malloc/malloc.c (_int_realloc): Add parameter with old block
|
||||||
|
size. Remove duplicated test. Don't handle mmap'ed blocks here.
|
||||||
|
Adjust all callers.
|
||||||
|
* malloc/hooks.c (realloc_check): Adjust _int_realloc call.
|
||||||
|
|
||||||
2009-04-07 Ulrich Drepper <drepper@redhat.com>
|
2009-04-07 Ulrich Drepper <drepper@redhat.com>
|
||||||
|
|
||||||
* sysdeps/x86_64/strchrnul.S: New file.
|
* sysdeps/x86_64/strchrnul.S: New file.
|
||||||
|
@ -358,7 +358,7 @@ realloc_check(oldmem, bytes, caller)
|
|||||||
if (top_check() >= 0) {
|
if (top_check() >= 0) {
|
||||||
INTERNAL_SIZE_T nb;
|
INTERNAL_SIZE_T nb;
|
||||||
checked_request2size(bytes + 1, nb);
|
checked_request2size(bytes + 1, nb);
|
||||||
newmem = _int_realloc(&main_arena, oldp, nb);
|
newmem = _int_realloc(&main_arena, oldp, oldsize, nb);
|
||||||
}
|
}
|
||||||
#if 0 /* Erase freed memory. */
|
#if 0 /* Erase freed memory. */
|
||||||
if(newmem)
|
if(newmem)
|
||||||
@ -501,7 +501,7 @@ free_starter(mem, caller) Void_t* mem; const Void_t *caller;
|
|||||||
then the hooks are reset to 0. */
|
then the hooks are reset to 0. */
|
||||||
|
|
||||||
#define MALLOC_STATE_MAGIC 0x444c4541l
|
#define MALLOC_STATE_MAGIC 0x444c4541l
|
||||||
#define MALLOC_STATE_VERSION (0*0x100l + 3l) /* major*0x100 + minor */
|
#define MALLOC_STATE_VERSION (0*0x100l + 4l) /* major*0x100 + minor */
|
||||||
|
|
||||||
struct malloc_save_state {
|
struct malloc_save_state {
|
||||||
long magic;
|
long magic;
|
||||||
@ -521,6 +521,10 @@ struct malloc_save_state {
|
|||||||
unsigned long mmapped_mem;
|
unsigned long mmapped_mem;
|
||||||
unsigned long max_mmapped_mem;
|
unsigned long max_mmapped_mem;
|
||||||
int using_malloc_checking;
|
int using_malloc_checking;
|
||||||
|
unsigned long max_fast;
|
||||||
|
unsigned long arena_test;
|
||||||
|
unsigned long arena_max;
|
||||||
|
unsigned long narenas;
|
||||||
};
|
};
|
||||||
|
|
||||||
Void_t*
|
Void_t*
|
||||||
@ -568,6 +572,12 @@ public_gET_STATe(void)
|
|||||||
ms->mmapped_mem = mp_.mmapped_mem;
|
ms->mmapped_mem = mp_.mmapped_mem;
|
||||||
ms->max_mmapped_mem = mp_.max_mmapped_mem;
|
ms->max_mmapped_mem = mp_.max_mmapped_mem;
|
||||||
ms->using_malloc_checking = using_malloc_checking;
|
ms->using_malloc_checking = using_malloc_checking;
|
||||||
|
ms->max_fast = get_max_fast();
|
||||||
|
#ifdef PER_THREAD
|
||||||
|
ms->arena_test = mp_.arena_test;
|
||||||
|
ms->arena_max = mp_.arena_max;
|
||||||
|
ms->narenas = narenas;
|
||||||
|
#endif
|
||||||
(void)mutex_unlock(&main_arena.mutex);
|
(void)mutex_unlock(&main_arena.mutex);
|
||||||
return (Void_t*)ms;
|
return (Void_t*)ms;
|
||||||
}
|
}
|
||||||
@ -587,7 +597,10 @@ public_sET_STATe(Void_t* msptr)
|
|||||||
(void)mutex_lock(&main_arena.mutex);
|
(void)mutex_lock(&main_arena.mutex);
|
||||||
/* There are no fastchunks. */
|
/* There are no fastchunks. */
|
||||||
clear_fastchunks(&main_arena);
|
clear_fastchunks(&main_arena);
|
||||||
set_max_fast(DEFAULT_MXFAST);
|
if (ms->version >= 4)
|
||||||
|
set_max_fast(ms->max_fast);
|
||||||
|
else
|
||||||
|
set_max_fast(64); /* 64 used to be the value we always used. */
|
||||||
for (i=0; i<NFASTBINS; ++i)
|
for (i=0; i<NFASTBINS; ++i)
|
||||||
fastbin (&main_arena, i) = 0;
|
fastbin (&main_arena, i) = 0;
|
||||||
for (i=0; i<BINMAPSIZE; ++i)
|
for (i=0; i<BINMAPSIZE; ++i)
|
||||||
@ -663,6 +676,13 @@ public_sET_STATe(Void_t* msptr)
|
|||||||
using_malloc_checking = 0;
|
using_malloc_checking = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (ms->version >= 4) {
|
||||||
|
#ifdef PER_THREAD
|
||||||
|
mp_.arena_test = ms->arena_test;
|
||||||
|
mp_.arena_max = ms->arena_max;
|
||||||
|
narenas = ms->narenas;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
check_malloc_state(&main_arena);
|
check_malloc_state(&main_arena);
|
||||||
|
|
||||||
(void)mutex_unlock(&main_arena.mutex);
|
(void)mutex_unlock(&main_arena.mutex);
|
||||||
|
@ -1586,7 +1586,8 @@ static void _int_free(mstate, mchunkptr, int);
|
|||||||
#else
|
#else
|
||||||
static void _int_free(mstate, mchunkptr);
|
static void _int_free(mstate, mchunkptr);
|
||||||
#endif
|
#endif
|
||||||
static Void_t* _int_realloc(mstate, mchunkptr, INTERNAL_SIZE_T);
|
static Void_t* _int_realloc(mstate, mchunkptr, INTERNAL_SIZE_T,
|
||||||
|
INTERNAL_SIZE_T);
|
||||||
static Void_t* _int_memalign(mstate, size_t, size_t);
|
static Void_t* _int_memalign(mstate, size_t, size_t);
|
||||||
static Void_t* _int_valloc(mstate, size_t);
|
static Void_t* _int_valloc(mstate, size_t);
|
||||||
static Void_t* _int_pvalloc(mstate, size_t);
|
static Void_t* _int_pvalloc(mstate, size_t);
|
||||||
@ -3778,7 +3779,7 @@ public_rEALLOc(Void_t* oldmem, size_t bytes)
|
|||||||
tsd_setspecific(arena_key, (Void_t *)ar_ptr);
|
tsd_setspecific(arena_key, (Void_t *)ar_ptr);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
newp = _int_realloc(ar_ptr, oldp, nb);
|
newp = _int_realloc(ar_ptr, oldp, oldsize, nb);
|
||||||
|
|
||||||
(void)mutex_unlock(&ar_ptr->mutex);
|
(void)mutex_unlock(&ar_ptr->mutex);
|
||||||
assert(!newp || chunk_is_mmapped(mem2chunk(newp)) ||
|
assert(!newp || chunk_is_mmapped(mem2chunk(newp)) ||
|
||||||
@ -5102,7 +5103,8 @@ static void malloc_consolidate(av) mstate av;
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
Void_t*
|
Void_t*
|
||||||
_int_realloc(mstate av, mchunkptr oldp, INTERNAL_SIZE_T nb)
|
_int_realloc(mstate av, mchunkptr oldp, INTERNAL_SIZE_T oldsize,
|
||||||
|
INTERNAL_SIZE_T nb)
|
||||||
{
|
{
|
||||||
mchunkptr newp; /* chunk to return */
|
mchunkptr newp; /* chunk to return */
|
||||||
INTERNAL_SIZE_T newsize; /* its size */
|
INTERNAL_SIZE_T newsize; /* its size */
|
||||||
@ -5123,28 +5125,25 @@ _int_realloc(mstate av, mchunkptr oldp, INTERNAL_SIZE_T nb)
|
|||||||
|
|
||||||
const char *errstr = NULL;
|
const char *errstr = NULL;
|
||||||
|
|
||||||
/* Simple tests for old block integrity. */
|
/* oldmem size */
|
||||||
if (__builtin_expect (misaligned_chunk (oldp), 0))
|
if (__builtin_expect (oldp->size <= 2 * SIZE_SZ, 0)
|
||||||
|
|| __builtin_expect (oldsize >= av->system_mem, 0))
|
||||||
{
|
{
|
||||||
errstr = "realloc(): invalid pointer";
|
errstr = "realloc(): invalid old size";
|
||||||
errout:
|
errout:
|
||||||
malloc_printerr (check_action, errstr, chunk2mem(oldp));
|
malloc_printerr (check_action, errstr, chunk2mem(oldp));
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* oldmem size */
|
|
||||||
const INTERNAL_SIZE_T oldsize = chunksize(oldp);
|
|
||||||
|
|
||||||
if (__builtin_expect (oldp->size <= 2 * SIZE_SZ, 0)
|
|
||||||
|| __builtin_expect (oldsize >= av->system_mem, 0))
|
|
||||||
{
|
|
||||||
errstr = "realloc(): invalid old size";
|
|
||||||
goto errout;
|
|
||||||
}
|
|
||||||
|
|
||||||
check_inuse_chunk(av, oldp);
|
check_inuse_chunk(av, oldp);
|
||||||
|
|
||||||
if (!chunk_is_mmapped(oldp)) {
|
/* All callers already filter out mmap'ed chunks. */
|
||||||
|
#if 0
|
||||||
|
if (!chunk_is_mmapped(oldp))
|
||||||
|
#else
|
||||||
|
assert (!chunk_is_mmapped(oldp));
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
|
||||||
next = chunk_at_offset(oldp, oldsize);
|
next = chunk_at_offset(oldp, oldsize);
|
||||||
INTERNAL_SIZE_T nextsize = chunksize(next);
|
INTERNAL_SIZE_T nextsize = chunksize(next);
|
||||||
@ -5271,6 +5270,7 @@ _int_realloc(mstate av, mchunkptr oldp, INTERNAL_SIZE_T nb)
|
|||||||
return chunk2mem(newp);
|
return chunk2mem(newp);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if 0
|
||||||
/*
|
/*
|
||||||
Handle mmap cases
|
Handle mmap cases
|
||||||
*/
|
*/
|
||||||
@ -5339,6 +5339,7 @@ _int_realloc(mstate av, mchunkptr oldp, INTERNAL_SIZE_T nb)
|
|||||||
return 0;
|
return 0;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -518,7 +518,7 @@ _res_hconf_trim_domain (char *hostname)
|
|||||||
|
|
||||||
trim_len = strlen (trim);
|
trim_len = strlen (trim);
|
||||||
if (hostname_len > trim_len
|
if (hostname_len > trim_len
|
||||||
&& strcasecmp (&hostname[hostname_len - trim_len], trim) == 0)
|
&& __strcasecmp (&hostname[hostname_len - trim_len], trim) == 0)
|
||||||
{
|
{
|
||||||
hostname[hostname_len - trim_len] = '\0';
|
hostname[hostname_len - trim_len] = '\0';
|
||||||
break;
|
break;
|
||||||
|
@ -41,9 +41,8 @@ ENTRY (__strchrnul)
|
|||||||
shl %cl, %esi
|
shl %cl, %esi
|
||||||
pmovmskb %xmm0, %edx
|
pmovmskb %xmm0, %edx
|
||||||
pmovmskb %xmm3, %ecx
|
pmovmskb %xmm3, %ecx
|
||||||
andl %esi, %edx
|
|
||||||
andl %esi, %ecx
|
|
||||||
orl %edx, %ecx
|
orl %edx, %ecx
|
||||||
|
andl %esi, %ecx
|
||||||
jnz 1f
|
jnz 1f
|
||||||
|
|
||||||
2: movdqa (%rdi), %xmm0
|
2: movdqa (%rdi), %xmm0
|
||||||
|
Loading…
Reference in New Issue
Block a user