Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp21730557ybl; Mon, 6 Jan 2020 10:04:55 -0800 (PST) X-Google-Smtp-Source: APXvYqzA156rVv4RiuNf7EGJrboEG67LpsqripuhY0F2essvUbjUb7loFTzWLWnVBWz5NrvNql4l X-Received: by 2002:a9d:62c7:: with SMTP id z7mr107397729otk.189.1578333894920; Mon, 06 Jan 2020 10:04:54 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1578333894; cv=none; d=google.com; s=arc-20160816; b=XLqaekvZbPVhmw6NdVu4P1Hgih98jSO7aMTPTUaarDH7CwZaCWDcp7E6WGxCElmyfl DY+889noDXjmTOXr4Ao2KNh0ZazVtaVzjs+WjJ+Xt8ExCj7TpoppjgkfGj/qgvc5wlcp nHpepkqER/mOArsE9iMuNoQDD/1KIIAVEjPNFnnTY2H9TvgwL0uvRuwVHrwcpapA8tzL Z3SRncrJn437wWEKSyaE3AVWYu7trOZlwpn4RJ5qLi+G9EOOSTDuARJ6LnMkmvzaI7b6 jZtBDbgnA6NrZSoDqWUhF2EKo3JH6rbBHyqP1VF9aVAKlVCIiniTXYM27ESGvVQNtdKj PGhA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=NXHuuZed9m4gmjDMxbSt8Ydx4KTmpkC7vJID6XaP7I0=; b=gSNgSDgF+LksJUwo1saE2ph92p1D/DHJmIRRD6FnZiu9OP7qwFreU5ste/WvOqmSIj hNMWIzZdJ5ca4Xy7hoIs9osujL2a63ME8KotyqcGpKrBTMiKXE/NCWdGpKvPb0amibq8 HyriI+wkDFA5Qu8cb1lfWOltESxvA2b/tay7m4IWj3rLPzXdo4HmtHA3mtC3ui6KvAD5 U3B2TfbL7HNSqkoYr7p7LEmIKwXphYqF7YfoqYLTJGhmAzRLHSrpOKNJ0NQtfgNCbOCN gq7MjFmZzuVmPiw9TZWI+lotgAE9o+jAonPzNEBBHoaaJhLUQkDcwwiLF9LC7WeWBpsa aRrA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=MRrkj8EI; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id q131si21950415oig.203.2020.01.06.10.04.40; Mon, 06 Jan 2020 10:04:54 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=MRrkj8EI; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726722AbgAFSDp (ORCPT + 99 others); Mon, 6 Jan 2020 13:03:45 -0500 Received: from mail-qt1-f194.google.com ([209.85.160.194]:44645 "EHLO mail-qt1-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726448AbgAFSDo (ORCPT ); Mon, 6 Jan 2020 13:03:44 -0500 Received: by mail-qt1-f194.google.com with SMTP id t3so43126061qtr.11; Mon, 06 Jan 2020 10:03:44 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=NXHuuZed9m4gmjDMxbSt8Ydx4KTmpkC7vJID6XaP7I0=; b=MRrkj8EI0gCPmdFxE+7l+GK4uoJ6rM6ez9nHt6AUuGx0FMkXiOZaBPPo6v3ir/4qvC UM5lPvnzAegMqlxcvWBcv3A3h05n6p3fJ4wHTpCTlugRpUV3todEv6atqHe976LnXxna if18JR4BhGt+t0M9PlWIWDBou86TspPSN28Kqbqr919TE6T9gKIMe/E0zIxV3Oq3Tfnm LO0AH25bvTRbBaokmYmmGonA1NFq16uTbNKa5S2pthdQ8j1nL0twPvfvOIY3HlDgZQNg YZUB0rAifbrSZjdksMKGwPQs4JtyBqj9GDLvR3mBRdQiAlt/GQkvWduSfMO9EhkKG5Fy FoYQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=NXHuuZed9m4gmjDMxbSt8Ydx4KTmpkC7vJID6XaP7I0=; b=VezwHh+MIzzxCQGalTuzxr99SNZEgNC8XxVSbBV56MIyvlQkv+7LNisHa866jeX9o0 94nGEkGj5cejiHTRS+5gRElR3k2ZMKt2P16H1XOLPaptyhZvAOERYWH0IfR83znHbXKM NSyp1+rs8rvHEX6R4EbuZKekH3/mHA0yCvFMYlYFQoJ+fVDKQ0Gx/hAJgs3DVGVJVazG ij3LPm/QJVYowTN6ApfvJatJTq0dZprpBSboZOg48Hui2ALcKvRpKOAUydLWHhl7InIq F9E9N7/yZrcDGu71cfQJV2qcmbcSx+/62TnrB/X6xMHvszCy+G+sPb1cexhQzkb1VyKW OCBQ== X-Gm-Message-State: APjAAAUnId8NLkMWS+NoVkwkR6cyzkHFuplSB/95GrLUASK+KCbNJRTw mIBIPCEjHK1Ler5IEW0yMAzNv7cVr28C8vvdmC4= X-Received: by 2002:ac8:5457:: with SMTP id d23mr72628654qtq.93.1578333823652; Mon, 06 Jan 2020 10:03:43 -0800 (PST) MIME-Version: 1.0 References: <20200102172413.654385-1-amanieu@gmail.com> <20200102172413.654385-3-amanieu@gmail.com> <20200102180130.hmpipoiiu3zsl2d6@wittgenstein> <20200106173953.GB9676@willie-the-truck> In-Reply-To: <20200106173953.GB9676@willie-the-truck> From: "Amanieu d'Antras" Date: Mon, 6 Jan 2020 19:03:32 +0100 Message-ID: Subject: Re: [PATCH 2/7] arm64: Implement copy_thread_tls To: Will Deacon Cc: Christian Brauner , Will Deacon , linux-kernel@vger.kernel.org, Christian Brauner , "# 3.4.x" , Linux ARM Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Jan 6, 2020 at 6:39 PM Will Deacon wrote: > I also ran the native and compat selftests but, unfortunately, they all > pass even without this patch. Do you reckon it would be possible to update > them to check the tls pointer? Here's the program I used for testing on arm64. I considered adding it to the selftests but there is no portable way of reading the TLS register on all architectures. #include #include #include #include #define __NR_clone3 435 struct clone_args { uint64_t flags; uint64_t pidfd; uint64_t child_tid; uint64_t parent_tid; uint64_t exit_signal; uint64_t stack; uint64_t stack_size; uint64_t tls; }; #define USE_CLONE3 int main() { printf("Before fork: tp = %p\n", __builtin_thread_pointer()); #ifdef USE_CLONE3 struct clone_args args = { .flags = CLONE_SETTLS, .tls = (uint64_t)__builtin_thread_pointer(), }; int ret = syscall(__NR_clone3, &args, sizeof(args)); #else int ret = syscall(__NR_clone, CLONE_SETTLS, 0, 0, __builtin_thread_pointer(), 0); #endif printf("Fork returned %d, tp = %p\n", ret, __builtin_thread_pointer()); }