Crashing threads with *(int*)NULL = 1; problematic

2020-07-16 08:39发布

I found this in a multi-threaded c application. The authors commented that it's used to make a thread crash in a custom assert function. GCC is fine with it, but clang issues the following warning:

note: consider using __builtin_trap() or qualifying pointer with 'volatile'

and also issues one of those, for each usage of the assert function:

warning: indirection of non-volatile null pointer will be deleted, not trap

What is going on here? Is __builtin_trap specific to clang? Should I use it?

2条回答
forever°为你锁心
2楼-- · 2020-07-16 09:18

The statement provoques undefined behavior. In particular the compiler is not obliged to try to store something at address 0 and may optimize this out. This is what the compilers are telling you.

Use exit() or abort() or some of the derivatives to terminate the whole process execution. This is portable. (C11 has exit, _Exit, quick_exit and abort)

查看更多
别忘想泡老子
3楼-- · 2020-07-16 09:25

Writing to NULL address is not guaranteed to crash your program reliably, so GCC introduced __builtin_trap for that.

It looks like clang decided to go further, and eliminate such writes altogether, almost forcing you into using __builtin_trap. Their other option of casting NULL to volatile pointer does not look attractive compared to __builtin_trap, because it's "merely" an undefined behavior.

查看更多
登录 后发表回答