From c190883a0a76cee5ffc951728a539fe7f9d71feb Mon Sep 17 00:00:00 2001 From: Jun-ichi Takimoto Date: Wed, 11 May 2022 11:22:46 +0900 Subject: 50192: use set{u,g}id() for dropping privilege on NetBSD --- Src/openssh_bsd_setres_id.c | 10 ++++++++++ 1 file changed, 10 insertions(+) (limited to 'Src') diff --git a/Src/openssh_bsd_setres_id.c b/Src/openssh_bsd_setres_id.c index 217a6d074..26c7d3958 100644 --- a/Src/openssh_bsd_setres_id.c +++ b/Src/openssh_bsd_setres_id.c @@ -55,6 +55,16 @@ #include #include +#ifdef __NetBSD__ +/* + * On NetBSD, setreuid() does not reset the saved uid if the real uid + * is not modified. Better to use setuid() that resets all of real, + * effective and saved uids to the specified value. Same for setregid(). + */ +#define BROKEN_SETREUID +#define BROKEN_SETREGID +#endif + #if defined(ZSH_IMPLEMENT_SETRESGID) || defined(BROKEN_SETRESGID) int setresgid(gid_t rgid, gid_t egid, gid_t sgid) -- cgit 1.4.1