2

我在我的固件中添加了 malloc 支持,我想我错过了一些东西!

我为 arm7tdmi 处理器使用代码源 g++ lite 库,我的代码基于此链接中的示例:http: //e2e.ti.com/support/microcontrollers/stellaris_arm_cortex-m3_microcontroller/f/473/t/44452。 aspx#539503

我添加了我的 _sbrk 版本:

char * _sbrk(int incr)
{
    //extern char _end; /* Defined by the linker */
    static char *heap_end;
    char *prev_heap_end;
    register char* stackPtr;

    if (heap_end == 0)
    {
        // first allocation
        heap_end =HEAP_END;
    }

    prev_heap_end = heap_end;

    // get current stack pointer
    asm ("mov %0, sp\n\t" : "=r" (stackPtr) );



    if (heap_end + incr > stackPtr) {
        return NULL;// error - no more memory
        //write (1, "Heap and stack collision\n", 25);
        //abort ();
    }
    heap_end += incr;
    return (char*) prev_heap_end;
}

sbrk 使用的一些定义:

#define SDRAM_SIZE 16*1024*1024        
#define HEAP_BASE  _ebss
#define HEAP_END ((_stext + SDRAM_SIZE) -1)
#define HEAP_SIZE HEAP_END - HEAP_BASE

(_ebss 和 _stext 来自我的链接器文件)

这是我进行简单 malloc/free 调用的主要内容:

void C_main ( void)
{
  char * testmalloc=0;
  /* Initialize "Heap Descriptor" pointer */
  pHeapDescriptor =  __rt_embeddedalloc_init ((void*)HEAP_BASE,HEAP_SIZE);
  testmalloc = malloc(2048);
  free(testmalloc);
}

我以步进模式运行这个程序。当我调用malloc时,它最终调用了我的_sbrk实现,返回值(prev_heap_end)有一个期望值,但是当程序返回main时,testmalloc值为NULL(在gcc库的某个地方,prev_heap_end丢失了)。

有人知道我做错了什么吗?

不知道这是否有帮助,但这是我的 gcc 编译参数:

arm-none-eabi-gcc  -march=armv4t -mcpu=arm7tdmi -dp -c 
-Wa,-adhlns="../../Base/Lib/Pa/main.o.lst" -fmessage-length=0 
-fno-zero-initialized-in-bss -MMD -MP -MF"../../Base/Lib/Pa/main.d" 
-MT"../../Base/Lib/Pa/main.d" -fpic -mlittle-endian -Wall -g3 -gdwarf-2  
../../Base/Hardintrf/Mezzanine/main.c -o"../../Base/Lib/Pa/main.o"

提前感谢您的帮助!

4

1 回答 1

1
if (heap_end == 0)
{
    // first allocation
    heap_end = HEAP_END;
}

这应该是:

if (heap_end == 0)
{
    // first allocation
    heap_end = HEAP_BASE;
}

所以你不要在堆的末尾开始你的堆......你可能想为那个变量想一个更好的名字然后是 heap_end 以避免首先出现这种混淆。

此外,您不需要使用 register 修饰符来使您的内联汇编正常工作。编译器足够聪明,可以为您做到这一点。

于 2012-06-30T04:14:41.490 回答