summaryrefslogtreecommitdiff
path: root/monitor.c
diff options
context:
space:
mode:
authormarkus@openbsd.org <markus@openbsd.org>2017-05-31 10:04:29 +0000
committerDamien Miller <djm@mindrot.org>2017-06-01 14:55:23 +1000
commit84008608c9ee944d9f72f5100f31ccff743b10f2 (patch)
treed7e6d3145d5e8a6c7a4377bae278e7dda5e47575 /monitor.c
parent9e509d4ec97cb3d71696f1a2f1fdad254cbbce11 (diff)
upstream commit
use SO_ZEROIZE for privsep communication (if available) Upstream-ID: abcbb6d2f8039fc4367a6a78096e5d5c39de4a62
Diffstat (limited to 'monitor.c')
-rw-r--r--monitor.c11
1 files changed, 10 insertions, 1 deletions
diff --git a/monitor.c b/monitor.c
index ef107a2e8..8897f6a82 100644
--- a/monitor.c
+++ b/monitor.c
@@ -1,4 +1,4 @@
1/* $OpenBSD: monitor.c,v 1.170 2017/05/31 08:09:45 markus Exp $ */ 1/* $OpenBSD: monitor.c,v 1.171 2017/05/31 10:04:29 markus Exp $ */
2/* 2/*
3 * Copyright 2002 Niels Provos <provos@citi.umich.edu> 3 * Copyright 2002 Niels Provos <provos@citi.umich.edu>
4 * Copyright 2002 Markus Friedl <markus@openbsd.org> 4 * Copyright 2002 Markus Friedl <markus@openbsd.org>
@@ -1655,9 +1655,18 @@ static void
1655monitor_openfds(struct monitor *mon, int do_logfds) 1655monitor_openfds(struct monitor *mon, int do_logfds)
1656{ 1656{
1657 int pair[2]; 1657 int pair[2];
1658#ifdef SO_ZEROIZE
1659 int on = 1;
1660#endif
1658 1661
1659 if (socketpair(AF_UNIX, SOCK_STREAM, 0, pair) == -1) 1662 if (socketpair(AF_UNIX, SOCK_STREAM, 0, pair) == -1)
1660 fatal("%s: socketpair: %s", __func__, strerror(errno)); 1663 fatal("%s: socketpair: %s", __func__, strerror(errno));
1664#ifdef SO_ZEROIZE
1665 if (setsockopt(pair[0], SOL_SOCKET, SO_ZEROIZE, &on, sizeof(on)) < 0)
1666 error("setsockopt SO_ZEROIZE(0): %.100s", strerror(errno));
1667 if (setsockopt(pair[1], SOL_SOCKET, SO_ZEROIZE, &on, sizeof(on)) < 0)
1668 error("setsockopt SO_ZEROIZE(1): %.100s", strerror(errno));
1669#endif
1661 FD_CLOSEONEXEC(pair[0]); 1670 FD_CLOSEONEXEC(pair[0]);
1662 FD_CLOSEONEXEC(pair[1]); 1671 FD_CLOSEONEXEC(pair[1]);
1663 mon->m_recvfd = pair[0]; 1672 mon->m_recvfd = pair[0];