From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (qmail 119034 invoked by alias); 26 Mar 2018 22:43:25 -0000 Mailing-List: contact libc-alpha-help@sourceware.org; run by ezmlm Precedence: bulk List-Id: List-Subscribe: List-Archive: List-Post: List-Help: , Sender: libc-alpha-owner@sourceware.org Received: (qmail 119014 invoked by uid 89); 26 Mar 2018 22:43:24 -0000 Authentication-Results: sourceware.org; auth=none X-Virus-Found: No X-Spam-SWARE-Status: No, score=-2.6 required=5.0 tests=AWL,BAYES_00,FREEMAIL_FROM,KAM_SHORT,RCVD_IN_DNSWL_NONE,SPF_PASS autolearn=unavailable version=3.3.2 spammy= X-HELO: mail-ot0-f178.google.com X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:from:date:message-id:subject:to; bh=iWXr6Tr5Z1hDsc4ryIZKa1QIlVgMa2H2JriSSwBTi8k=; b=d9EzOYz4dfvxz89IhyzWklllQjXJ0hi266zE5pJa0IbvIs55j9EcW57n/mPy7W2bZ9 Nuz1/o5glJCwFmg4HOlbXGAHyaK9jdgg6kGnQk48hjE+v5sfzkbqUS8sWckMyxBHj1Vj trSiiYkZU/gxXWWQUv8bfuIkGw5/cRZGOx3BGbx/aWeHSXINAeM0WU4UuEEsyExA96j+ RlUV+MRY8ob5xLNDmBIbeFdA6WN1LLKXXJgKH+yDuUpBqUbRD++c4AFHR2qeP7ZjvISk AY7uCGYVd4dDFukTKpWOCQtQ/qvdTGWhirA2hgGSfsnluEUGycfBCg5/njd6DWfmwGfl gUeA== X-Gm-Message-State: AElRT7H8x7RNM3RU5BRfGgTA11Bs8St4tX7riEHeHtEvv2dEev6FDK2J JkGYBYfcjYlIE3FlNq9WVwgO+WOdsQzWdXY0cseDTg== X-Google-Smtp-Source: AIpwx4/rZ9ApOmQvgNlsV1wwCXzMbHPzioY+NYwgXZNdsc51RIGIroFL8TS+3cbbibPEtvwZkwqbRNJq6T7TS1ItAZA= X-Received: by 2002:a9d:4183:: with SMTP id p3-v6mr11666273ote.70.1522104201047; Mon, 26 Mar 2018 15:43:21 -0700 (PDT) MIME-Version: 1.0 From: "H.J. Lu" Date: Mon, 26 Mar 2018 22:43:00 -0000 Message-ID: Subject: RFA: Need to extend x86 psABI to support thread cancellation and alternate signal stack To: GNU C Library , GCC Development , "Carlos O'Donell" Content-Type: text/plain; charset="UTF-8" X-SW-Source: 2018-03/txt/msg00559.txt.bz2 On Linux, when alternate signal stack is used with thread cancellation, _Unwind_Resume fails when it tries to unwind shadow stack from signal handler on alternate signal stack. The issue is that signal handler on alternate signal stack uses a separate shadow stack and we must switch to the original shadow stack to unwind it. But frame count will be wrong in this case. For thread cancellation, there is no need to unwind shadow stack since it will long jump back and exit. One possibility is 1. Add _URC_NO_REASON_CANCEL. 2. unwind_stop in libpthread returns _URC_NO_REASON_CANCEL. 3. _Unwind_ForcedUnwind_Phase2 sets frames to 1 for _URC_NO_REASON_CANCEL BTW, I opened: https://gcc.gnu.org/bugzilla/show_bug.cgi?id=85086 -- H.J.