fukuyasu / long_number

Library for operating numbers with long fraction part
0 stars 0 forks source link

malloc.c:2372: sysmalloc: Assertion `...' failed. #6

Closed fukuyasu closed 5 years ago

fukuyasu commented 5 years ago

Raspberry Pi上でコンパイル・実行すると,特定の場合だけmallocに失敗する.

$ ./pi
pi: malloc.c:2372: sysmalloc: Assertion `(old_top == (((mbinptr) (((char *) &((av)->bins[((1) - 1) * 2])) - __builtin_offsetof (struct malloc_chunk, fd)))) && old_size == 0) || ((unsigned long) (old_size) >= (unsigned long)((((__builtin_offsetof (struct malloc_chunk, fd_nextsize))+((2 *(sizeof(size_t))) - 1)) & ~((2 *(sizeof(size_t))) - 1))) && ((old_top)->size & 0x1) && ((unsigned long) old_end & pagemask) == 0)' failed.
Aborted

これまでに観測されている失敗例:

実行環境は以下の通り.

$ uname -a
Linux raspberrypi 4.4.11-v7+ #888 SMP Mon May 23 20:10:33 BST 2016 armv7l GNU/Linux
$ cc -v
gcc version 4.9.2 (Raspbian 4.9.2-10)
fukuyasu commented 5 years ago

成功例:

$ ./pi 2000
$ ./pi -d 8 1000
$ ./pi -d 1 31

失敗例:

$ ./pi -d 1 30
fukuyasu commented 5 years ago

失敗例:

$ ./pi -d 1 22
$ ./pi -d 1 24
$ ./pi -d 1 26
$ ./pi -d 1 28
$ ./pi -d 2 51
$ ./pi -d 2 52
$ ./pi -d 2 24
$ ./pi -d 2 59
$ ./pi -d 2 60
$ ./pi -d 3 76
fukuyasu commented 5 years ago

7 によって malloc に失敗することはなくなった.