我正在使用gnu sparc工具链。我有sparc-ab-elf-gcc和sparc-ab-linux-gcc。 (“ ab”是处理器名称)。我想编译一个在裸机(没有os)上使用malloc和free(该程序应该在linux上运行)的程序。所以我应该使用sparc-ab-elf-gcc进行编译。我听说我可以在这种情况下使用dlmalloc。 (请参见stdlib-like library on bare metal environment? (memory management and hopefully pthread support)),但是我看到一些简单的测试程序会出现编译错误,该程序只执行malloc并每次释放一次。

// test malloc, realloc and free
#include <aldebaran.h>
#include <malloc.h>


int main()
{
int i;

ab_printf("%s\n",CKIM_XX);
char *buff = dlmalloc(100);
for(i = 0; i < 100; i++) {
    buff[i] = (char) i;
}
ab_printf("buff = %x\n'");
for(i=0; i<100; i++) {
    ab_printf("%d ", buff[i]);
}
ab_printf("\n");
dlfree(buff);
return 0;
}


ckim@stph45:~/prj2/abts/yolo-bare/darknet] make test3
sparc-ab-elf-gcc -c -I./src -I../include -I/opt/abde/sparc-ab-elf/include    -DALDEBARAN_FPGA -DABC_CT -O3 -ffast-math -fcommon -msoft-float -mcpu=v8  -Wa,-xarch=v8plusb -Wall -Wfatal-errors   ./src/malloc.c -o obj/malloc.o
./src/malloc.c:571:40: fatal error: sys/mman.h: No such file or directory
compilation terminated.
make: *** [obj/malloc.o] Error 1


我的裸机系统没有sys / mman.h(我在elf工具链库中搜索了它),因此在定义LACKS_SYS_MMAN_H之后再次尝试

ckim@stph45:~/prj2/abts/yolo-bare/darknet] make test3
sparc-ab-elf-gcc -c -I./src -I../include -I/opt/abde/sparc-ab-elf/include    -DALDEBARAN_FPGA -DABC_CT -O3 -ffast-math -fcommon -msoft-float -mcpu=v8  -Wa,-xarch=v8plusb -Wall -Wfatal-errors  -DLACKS_SYS_MMAN_H  ./src/test3.c -o obj/test3.o
sparc-ab-elf-gcc -c -I./src -I../include -I/opt/abde/sparc-ab-elf/include    -DALDEBARAN_FPGA -DABC_CT -O3 -ffast-math -fcommon -msoft-float -mcpu=v8  -Wa,-xarch=v8plusb -Wall -Wfatal-errors  -DLACKS_SYS_MMAN_H  ./src/malloc.c -o obj/malloc.o
./src/malloc.c: In function 'mmap_alloc':
./src/malloc.c:2924:5: warning: implicit declaration of function 'mmap' [-Wimplicit-function-declaration]
./src/malloc.c:2924:24: error: 'PROT_READ' undeclared (first use in this function)
compilation terminated due to -Wfatal-errors.
make: *** [obj/malloc.o] Error 1


dlmalloc.c是一个很长的程序。 (我将其分为malloc.h和malloc.c。)下面是产生错误的函数。

/* Malloc using mmap */
static void* mmap_alloc(mstate m, size_t nb) {
  size_t mmsize = mmap_align(nb + SIX_SIZE_T_SIZES + CHUNK_ALIGN_MASK);
  if (m->footprint_limit != 0) {
    size_t fp = m->footprint + mmsize;
    if (fp <= m->footprint || fp > m->footprint_limit)
      return 0;
  }
  if (mmsize > nb) {     /* Check for wrap around 0 */
    char* mm = (char*)(CALL_DIRECT_MMAP(mmsize));    <=== line causing error.
    if (mm != CMFAIL) {
      size_t offset = align_offset(chunk2mem(mm));
      size_t psize = mmsize - offset - MMAP_FOOT_PAD;
      mchunkptr p = (mchunkptr)(mm + offset);
      p->prev_foot = offset;
      p->head = psize;
      mark_inuse_foot(m, p, psize);
      chunk_plus_offset(p, psize)->head = FENCEPOST_HEAD;
      chunk_plus_offset(p, psize+SIZE_T_SIZE)->head = 0;

      if (m->least_addr == 0 || mm < m->least_addr)
        m->least_addr = mm;
      if ((m->footprint += mmsize) > m->max_footprint)
        m->max_footprint = m->footprint;
      assert(is_aligned(chunk2mem(p)));
      check_mmapped_chunk(m, p);
      return chunk2mem(p);
    }
  }
  return 0;
}


有人可以给我点灯吗?

最佳答案

我听说我可以在这种情况下使用dlmalloc


再次阅读该答案。特别注意:“ ...您应该能够适应...”。您尚未完成适应部分。

关于c - 裸机(elf)程序构建的dlmalloc编译期间发生错误,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/44388743/

10-11 00:39
查看更多