From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (qmail 29083 invoked by alias); 6 Nov 2019 14:06:38 -0000 Mailing-List: contact cygwin-cvs-help@cygwin.com; run by ezmlm Precedence: bulk List-Id: List-Subscribe: List-Post: List-Help: , Sender: cygwin-cvs-owner@cygwin.com Received: (qmail 29033 invoked by uid 9078); 6 Nov 2019 14:06:38 -0000 Date: Wed, 06 Nov 2019 14:06:00 -0000 Message-ID: <20191106140638.29031.qmail@sourceware.org> Content-Type: text/plain; charset="us-ascii" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit From: Corinna Vinschen To: cygwin-cvs@sourceware.org Subject: [newlib-cygwin] Cygwin: pty: Change how to determine if running as service or not. X-Act-Checkin: newlib-cygwin X-Git-Author: Takashi Yano X-Git-Refname: refs/heads/master X-Git-Oldrev: 44432b93add22888a849110f12e2c146291d2176 X-Git-Newrev: e5db0d2fe06d66607f7d3423f75451fab2bda6ee X-SW-Source: 2019-q4/txt/msg00023.txt.bz2 https://sourceware.org/git/gitweb.cgi?p=newlib-cygwin.git;h=e5db0d2fe06d66607f7d3423f75451fab2bda6ee commit e5db0d2fe06d66607f7d3423f75451fab2bda6ee Author: Takashi Yano Date: Wed Nov 6 21:08:43 2019 +0900 Cygwin: pty: Change how to determine if running as service or not. Diff: --- winsup/cygwin/fhandler_tty.cc | 17 +++-------------- 1 file changed, 3 insertions(+), 14 deletions(-) diff --git a/winsup/cygwin/fhandler_tty.cc b/winsup/cygwin/fhandler_tty.cc index da6119d..0109d45 100644 --- a/winsup/cygwin/fhandler_tty.cc +++ b/winsup/cygwin/fhandler_tty.cc @@ -3094,22 +3094,11 @@ pty_master_fwd_thread (VOID *arg) the helper process is running as privileged user while slave process is not. This function is used to determine if the process is running as a srvice or not. */ -static bool +inline static bool is_running_as_service (void) { - DWORD dwSize = 0; - PTOKEN_GROUPS pGroupInfo; - tmp_pathbuf tp; - pGroupInfo = (PTOKEN_GROUPS) tp.w_get (); - NtQueryInformationToken (hProcToken, TokenGroups, pGroupInfo, - 2 * NT_MAX_PATH, &dwSize); - for (DWORD i=0; iGroupCount; i++) - if (RtlEqualSid (well_known_service_sid, pGroupInfo->Groups[i].Sid)) - return true; - for (DWORD i=0; iGroupCount; i++) - if (RtlEqualSid (well_known_interactive_sid, pGroupInfo->Groups[i].Sid)) - return false; - return true; + return check_token_membership (well_known_service_sid) + || cygheap->user.saved_sid () == well_known_system_sid; } bool