The OpenNET Project / Index page

[ новости /+++ | форум | теги | ]

форумы  помощь  поиск  регистрация  майллист  ВХОД  слежка  RSS
"Просто супер глюк malloc под FreeBSD 4.8!"
Вариант для распечатки Архивированная нить - только для чтения! 
Пред. тема | След. тема 
Форумы Программирование под UNIX (Public)
Изначальное сообщение [Проследить за развитием треда]

"Просто супер глюк malloc под FreeBSD 4.8!"
Сообщение от Daos emailИскать по авторуВ закладки on 16-Апр-04, 13:36  (MSK)
    swpsize += BUFINC;
if (!(newswp = (char *)realloc(buffer, swpsize*sizeof(char)))) errorz(" Memory allocation error...Sorry!\n");
    memcpy(newswp, buffer, swpsize-BUFINC);
    free(buffer);

   Существуют такие сочетания размеров буфера и приращений BUFINC, при которых
срабатывает assert на операторе free (возвращается ругать типа "modified (page-) pointer". IMHO это происходит потому,что рано или поздно размер буфера будет иметь величину, кратную размеру страницы (у меня это слетело уже при swpsize  = 4100). А в коде malloc.c (функция ifree) есть вот какое место :

#define malloc_pagemask ((malloc_pagesize)-1)

#ifndef malloc_pageshift
#define malloc_pageshift 12U
#endif
#if !defined(malloc_pagesize)
#define malloc_pagesize (1UL<<malloc_pageshift)
#endif

if (*mp == MALLOC_FIRST) { /* Page allocation */

/* Check the pointer */
if ((u_long)ptr & malloc_pagemask) {
    wrtwarning("modified (page-) pointer\n");
    return 0;
}
  

  Рекомендовать в FAQ | Cообщить модератору | Наверх

 Оглавление

Индекс форумов | Темы | Пред. тема | След. тема
Сообщения по теме

1. "Просто супер глюк в другом месте"
Сообщение от ed Искать по авторуВ закладки(??) on 16-Апр-04, 13:48  (MSK)
man realloc:

The realloc() function changes the size of the previously allocated
memory referenced by ptr to size bytes.  The contents of the memory are
unchanged up to the lesser of the new and old sizes.  If the new size is
larger, the value of the newly allocated portion of the memory is
undefined.  If the requested memory cannot be allocated, NULL is returned and the memory referenced by ptr is valid and unchanged.  If memory can be allocated, the memory referenced by ptr
is freed and a pointer to the newly allocated memory is returned.
^^^^^^^^

  Рекомендовать в FAQ | Cообщить модератору | Наверх

2. "Оказывается, НИЧЕГО ПОДОБНОГО! Вот такой код тоже не работае..."
Сообщение от Daos emailИскать по авторуВ закладки on 16-Апр-04, 13:58  (MSK)
    swpsize += BUFINC;
      
    if (!(newswp = new char[swpsize])) errorz(" Memory allocation error...Sorry!\n");
    memcpy(newswp, buffer, swpsize-BUFINC);
    delete[] buffer;
      
    //if (!(newswp = (char *)realloc(buffer, swpsize))) errorz(" Memory allocation error...Sorry!\n");
    
    if (!fread(newswp+swpsize-BUFINC, sizeof(char), BUFINC, fp)) myflock = 1;              
    return newswp;

И слетает оно тоже при swpsize=4100!..

  Рекомендовать в FAQ | Cообщить модератору | Наверх

3. "Re: Оказывается, НИЧЕГО ПОДОБНОГО! Вот такой код тоже не раб..."
Сообщение от ed Искать по авторуВ закладки(??) on 16-Апр-04, 17:12  (MSK)
а BUFINC - сколько ?

Можеш привести отдельную маленькую программу воспроизводящаю проблему, а не фрагмет кода.

  Рекомендовать в FAQ | Cообщить модератору | Наверх


Удалить

Индекс форумов | Темы | Пред. тема | След. тема
Пожалуйста, прежде чем написать сообщение, ознакомьтесь с данными рекомендациями.




Партнёры:
PostgresPro
Inferno Solutions
Hosting by Hoster.ru
Хостинг:

Закладки на сайте
Проследить за страницей
Created 1996-2024 by Maxim Chirkov
Добавить, Поддержать, Вебмастеру