[llvm-dev] lld: sigbus error handling

Brian Cain via llvm-dev llvm-dev at lists.llvm.org
Mon Oct 23 15:40:00 PDT 2017


On Mon, Oct 23, 2017 at 5:21 PM, Rui Ueyama via llvm-dev <
llvm-dev at lists.llvm.org> wrote:

> If your system does not support fallocate(2), we use ftruncate(2) to
> create an output file. fallocate(2) succeeds even if your disk have less
> space than the requested size, because it creates a sparse file. If you
> mmap such sparse file, you'll receive a SIGBUS when the disk actually
> becomes full.
>
> So, lld can die suddenly with SIGBUS when your disk becomes full, and
> currently we are not doing anything about it. It's sometimes hard to notice
> that that was caused by the lack of disk space.
>
> I wonder if we should print out a hint (e.g. "Bus error -- disk full?")
> when we receive a SIGBUS. Any opinions?
>
>
What about reading back the file's size with stat() before mapping?
.st_blocks should give the "real" size.

BTW, posix_fallocate() might provide better portability and decrease the
likelihood of falling back on ftruncate().


> _______________________________________________
> LLVM Developers mailing list
> llvm-dev at lists.llvm.org
> http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev
>
>


-- 
-Brian
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20171023/ee6554d5/attachment.html>


More information about the llvm-dev mailing list