From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: by sourceware.org (Postfix, from userid 1944) id 018C6387689A; Wed, 26 Oct 2022 15:21:15 +0000 (GMT) DKIM-Filter: OpenDKIM Filter v2.11.0 sourceware.org 018C6387689A DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=sourceware.org; s=default; t=1666797678; bh=5xZ2TsOk7I1DFBsmlfDsSrL8RgpFZTSbUD0LtQ6aJMQ=; h=From:To:Subject:Date:From; b=bWMNRlMAIRnQcF0RPfJBs0fSPPjkkjcfOUAYozI1JviMBAN1aNLe8AMgCHYLKMje6 asl7/iV6Nxs6NqNrerVz+qmOObsIRTu9CDytVKpGyYs4GYPVFzPi6iXY5OAAWcilhP wUyOwnpgqI+QourAUKA7dwwq60RRlkXLz5COWCYw= Content-Type: text/plain; charset="us-ascii" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit From: Szabolcs Nagy To: glibc-cvs@sourceware.org Subject: [glibc/arm/morello/main] cheri: nptl: Check user provided stack for PCS constraints X-Act-Checkin: glibc X-Git-Author: Carlos Eduardo Seo X-Git-Refname: refs/heads/arm/morello/main X-Git-Oldrev: 3384f13b9de0b4bae43997cee1ad43bae569cd1d X-Git-Newrev: aca3967b3fef75c176c44a63dcdc442748d271a7 Message-Id: <20221026152118.018C6387689A@sourceware.org> Date: Wed, 26 Oct 2022 15:21:15 +0000 (GMT) List-Id: https://sourceware.org/git/gitweb.cgi?p=glibc.git;h=aca3967b3fef75c176c44a63dcdc442748d271a7 commit aca3967b3fef75c176c44a63dcdc442748d271a7 Author: Carlos Eduardo Seo Date: Thu Mar 17 20:51:32 2022 -0300 cheri: nptl: Check user provided stack for PCS constraints In pthread_attr_setstack fail with EINVAL if the input stack does not meet the PCS constraints. Diff: --- nptl/pthread_attr_setstack.c | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/nptl/pthread_attr_setstack.c b/nptl/pthread_attr_setstack.c index e08b167df6..a0338c2752 100644 --- a/nptl/pthread_attr_setstack.c +++ b/nptl/pthread_attr_setstack.c @@ -19,7 +19,9 @@ #include #include "pthreadP.h" #include - +#ifdef __CHERI_PURE_CAPABILITY__ +# include +#endif #ifndef NEW_VERNUM # define NEW_VERNUM GLIBC_2_3_3 @@ -43,6 +45,11 @@ __pthread_attr_setstack (pthread_attr_t *attr, void *stackaddr, EXTRA_PARAM_CHECKS; #endif +#ifdef __CHERI_PURE_CAPABILITY__ + if (!STACK_CAP_CHECK (stackaddr, stacksize)) + return EINVAL; +#endif + iattr->stacksize = stacksize; #if _STACK_GROWS_DOWN iattr->stackaddr = (char *) stackaddr + stacksize;