<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/59037>59037</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
Tools should _not_ catch their own SIGPIPE
</td>
</tr>
<tr>
<th>Labels</th>
<td>
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
kees
</td>
</tr>
</table>
<pre>
Since commit 51b557adc131, tools are catching their own SIGPIPE signals. This is wrong: the caller needs to be the one handling these. This is the long-standing behavior for *nix utilities. For example:
```
$ seq 10000 | head -n1
1
```
No error generated, but `seq` _is_ being killed by `SIGPIPE`:
```
$ strace seq 10000 | head -n1
...
write(1, "1\n2\n3\n4\n5\n6\n7\n8\n9\n10\n11\n12\n13\n14"..., 8192) = 8192
1
write(1, "\n1861\n1862\n1863\n1864\n1865\n1866\n1"..., 4096) = -1 EPIPE (Broken pipe)
--- SIGPIPE {si_signo=SIGPIPE, si_code=SI_USER, si_pid=3503448, si_uid=1000} ---
+++ killed by SIGPIPE +++
```
It is the caller (the shell, here) that is filtering out `SIGPIPE`. The tool itself should not catch the signal, and caller are expecting tools to be killed early by `SIGPIPE` so that needless CPU resources (and time) are not wasted. (For example, when using `head`, or `grep -mN`, etc.)
The SIGPIPE handler should be left explicitly untouched, i.e. set to `SIG_DFL`. If the error is wanted, callers (shells) can be configured to report it:
```
$ set -o pipefail
$ seq 10000 | head -n1
1
$ echo $?
141
```
The LLVM tool behavior is incorrect:
```
$ llvm-objdump -d /bin/true | head -n1
error: write on a pipe with no reader
```
And we can see that the signal is being caught internally:
```
$ strace llvm-objdump -d /bin/true | head -n1
...
write(1, "\n/bin/true:\tfile format elf64-x8"..., 95) = 95
write(1, " 1000: f3 0f 1e fa "..., 48
) = -1 EPIPE (Broken pipe)
--- SIGPIPE {si_signo=SIGPIPE, si_code=SI_USER, si_pid=3503786, si_uid=1000} ---
...
rt_sigaction(SIGPIPE, {sa_handler=SIG_DFL, sa_mask=[], sa_flags=SA_RESTORER, sa_restorer=0x7fa15add7520}, NULL, 8) = 0
...
lseek(2, 0, SEEK_CUR) = -1 ESPIPE (Illegal seek)
newfstatat(2, "", {st_mode=S_IFCHR|0620, st_rdev=makedev(0x88, 0x19), ...}, AT_EMPTY_PATH) = 0
write(2, "error: write on a pipe with no r"..., 38error: write on a pipe with no reader
) = 38
exit_group(74) = ?
+++ exited with 74 +++
```
And errno 74 is _also_ wrong here (`EBADMSG`). Again, setting `pipefail` can expose this wrong error too:
```
$ set -o pipefail
$ llvm-objdump -d /bin/true | head -n1
...
$ echo $?
74
```
But this errno is not correct. :(
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJy9V1tzmzgU_jX4RWMPd_CDHxzHbjObdjNxsjP7xAg4GDUYeSVRO_--5wiw0zZN292ZJViALufy6ZzvKLksnxdb0RbACrnfC8MiL4-ihJeFF3iOv2JGykYzrnACN0Ut2h0zNQjF5LFl25t3dzd3a6bFruWNnrGHWmiG91HJducES5qLC5sGFGsBSo3yWA62W7bAat6WzSBTw2U9jTcoYqoNzqAJOdT8s5CKVfhz_GUrTqwzohFGACreYC-c-P7QAKp13GvHHdvYHe7-0w-Zhn-Y5-LFnGTFauAlm7ZeP-69vsq2HyUDpVDTDlpQ3EBJCOWdYTgRhWLLMqEzNJZMfhLod8nyZxoeoCKJP7fPKI478paZs9msfzkqYcDxU7tZju97TrRqfWoCakJqImpiahJqUmrm1Hiube0azy7y7CovREmkAmWm3tx3_Dlzguv-_SVM32q3i9PYG57jdzA8w-EZDU9rk3fRFbrzeNQ19djaBheKv1LyCVp2EAdUNu9VT6fTc_w5yZUWGUWhxKUj1CgQewtZgu3MHrfr-6HzIErsCyI3CMN06OtsHwHuJKh-Oh035Kq_X-znWe849kbQ3JgxoIc8QH_oS9fQNKS6BkVe4RRup1aiMaAogGQfWZfQoQQBm5JMGA1NhVJk15SslabPT6uoT0eSjckzqqUUhtMBCmPzzaZ1n4yDX8BV8_xdtDIte8sofRvQmq3uHpkCLTtVgCZvSIkRe-sEaSFjjlxjesxo-GVqoknHGney02QEiqeoJsBwgPI6dncKDmy6_zh0gilm5y3vW4Jg3ADLH-jcAAM600BlyM9GFMKgP11rZFfUfaqKGXKMBkOO915m15tbC-xNZaHr85sYjLdDfvf4WU_tnmnys-AtaStkW4ldpxA-FImmS4V7aH6FggybShvRFRfN73ETToOiRhf80Ak2w1j4FnMRZre3f33oY-fMpUS2bSGVwqj4uc1N83k_lfmnstvjFpWofpOLFlujOnjF3L61iFIpsFyBrM-4dZsdhakxVhA1XoJ6w_glxtcRLOQaoI_GS5iTEz3fFrzb1Qg_bpzCgeb5l5n2dz37IfsSn321mEyIVgZzGqhy7dF0TNs4nJ7SC-3No5H08O1VuQwvy0yIYxUwt2IeyuPscr0g0XT0738l0iSN3ybSM2jKkAaORCQRpvSFFlLPsyGpewNsgpJcnu25fsJOJ7pyouuhr2r4TtPMZXa_3j78eT9YxjOkKCOVFeOekop7ES_LJPLJKJry8fHWCk5HnNxvzGww2J7QPp9mWTLartd_ZKvHe1rx_TVivR3BvkHe2GGA9nIGtFs4Vniowb9RNIWN74_um2w_4JzdbFbv7zH43Ni36nFMlfAZx_b8CejNT91TauuXe_LmpANfyYHexeVDtv5w9_B3drd8eP-Nm2OEjSb8PE0vERakv5fUg-ZgCEw4CZPtlOwOqD8JX0fzBahnjruUYhKBnGu1JeEv1WFiETQbbcMFyBkZHlhl1p9UbQ2mLcM166vl9YftO1t_5jO23HFK5hUxthmK1pm1sTwSK2G5kZqIaTz5DmUEyfY_VIJ_TUqv1gfE-cfYXHWmt74HCF_sgaIvDFjE0Qk_ncDCi2M81MVekkzKRVDOgzmfGCyzsHiw54mhDGe4OrucR77-Z2HSqWZRG3PQVuwG7x1uY5fP8D8Q_CC3h8f0oOQnKk3-RmjdAVbeTTRHqpnUC7_kSREHaZDzKAz8qkihjMKYuzyNgrLKJw3PodGLni0mYuG7eDj2vNib4y-ZBVVahEUalVGSl-XcdUIX9oj_jBTPpNpN1MLakHdIMKHbCG30ZZBrIkmAUT7vTC3V4glAT6ytC2voF6fPy9g">