From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-8.7 required=3.0 tests=BAYES_00,DKIM_ADSP_CUSTOM_MED, DKIM_SIGNED,DKIM_VALID,FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM, HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH,MAILING_LIST_MULTI,SPF_HELO_NONE, SPF_PASS,URIBL_BLOCKED,USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 8E228C433E6 for ; Mon, 1 Feb 2021 19:43:24 +0000 (UTC) Received: from merlin.infradead.org (merlin.infradead.org [205.233.59.134]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id 436DC64EA8 for ; Mon, 1 Feb 2021 19:43:24 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 436DC64EA8 Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=gmail.com Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=merlin.20170209; h=Sender:Content-Transfer-Encoding: Content-Type:Cc:List-Subscribe:List-Help:List-Post:List-Archive: List-Unsubscribe:List-Id:MIME-Version:Message-Id:Date:Subject:To:From: Reply-To:Content-ID:Content-Description:Resent-Date:Resent-From:Resent-Sender :Resent-To:Resent-Cc:Resent-Message-ID:In-Reply-To:References:List-Owner; bh=YwmtBVo/mBDMnmcsfwdrBgorNYfsm74WzF2njsDRw9w=; b=oD79wadvTXHbPEnszWLxi8I0Yg MrNMlRWzhKq2qcO/Arft+mWqRlsFlzYF+H5cKROWNy4Q2Spo/WJhPhhYMZbvX+99sMdT7n1NMgn1x iRkz+wlE0qsw9aqfPdFeHLRCZ1glKHw9ik6jXQDAEEItVVkaWILxqlsLt64Rzm2rxj4bvYow/xucO /+amAqE+kwFDS0WCTde4mrUqjPDiQTm6X2iprT1pSsBa9tFOK97U3+14H/1zTEk9ASJK7UxML5bEx Gnmv6WXf1bJjQKuiVmSO/CilWVq+C6Rq3WibCZSfU5CWcGMGVSBHM/bDaPQF3dH3FhS4SdxO8cV01 ConAPXZw==; Received: from localhost ([::1] helo=merlin.infradead.org) by merlin.infradead.org with esmtp (Exim 4.92.3 #3 (Red Hat Linux)) id 1l6f5O-00015K-TQ; Mon, 01 Feb 2021 19:42:10 +0000 Received: from mail-pl1-x62a.google.com ([2607:f8b0:4864:20::62a]) by merlin.infradead.org with esmtps (Exim 4.92.3 #3 (Red Hat Linux)) id 1l6f5G-0000zE-OC for linux-arm-kernel@lists.infradead.org; Mon, 01 Feb 2021 19:42:07 +0000 Received: by mail-pl1-x62a.google.com with SMTP id s15so10605831plr.9 for ; Mon, 01 Feb 2021 11:42:00 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=QRjxCLuQN8hNECynzl8zP9q2hHvFmhTmWrT/R1ujkw0=; b=DAmX4uuqp1MGWh6Kb/kOqIB5x90h3PvRPjAxLzGCXNnGHYw/BQmvnejozeZFma4uj1 TB0zKpmuqmlPmpCftGdjuu7Dv+ky3AR/bYD8gDONkMWln7Y3j2TMxFurHmaQl8XfWcam lUnqFRVJ/2CU19t6q7Te0DjAzeDuFvoQz8EL5k4KJoEq/tFY1sEw//iBGEHfdEi3vMTR vvCnM7kUmbtKWAdP/6qD6YKyh2mYxB26q07K+tnsa+huOc2hJRV8NT2HMFLYqzLm9slK jrZCLJAtp8zs5IyHURJtZSkTZGBEj5ipfaHGX8dNxpFs3+AlzhV5HZGMFL5iHZFUTyOU LLFQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=QRjxCLuQN8hNECynzl8zP9q2hHvFmhTmWrT/R1ujkw0=; b=saEJAa5diTudvesBZaJ7+/XuhLarDGopEs5uIxEhysnZTignBOG8d/Wr1ixaDWyQ4J YZT+zFlT/EdjA8y2BkxMW1f6iarZBpmOmfpbNBsDde0w/afRz5j5WYc2Nn1R01SFM5kY dXX6/LnvfRNsHO81hDMOAfnD/FIo9+2bBJqXrHP3NDg1NEegxHmyqDTdrrgnl8UFc2EM jpu/eLh4TcS/fa441qZTS6dto367/HaOLvNIqDVNQLS7Ud81cu1bTYK0rYCkf5paBTvd lfmBzjVQFuWbTOzgVtlcEW8DCQ/E4V8b61kIW5mO+ejs0ucieU53oefcWGssC3as6kBx EoQQ== X-Gm-Message-State: AOAM530h954FREkco0PFvqp7Q5yOJQOAcb4T6IrwZhiKIsmH2R8BYl8Y +zu2J4T82gsDgc39CYb+qD4= X-Google-Smtp-Source: ABdhPJzl5HcS9kWOeBJCi5Lj4X/pLo35ipBIsZnFekB21lSY9Z0GG9tQePWu2rECauPs9WVQU0EAHw== X-Received: by 2002:a17:90a:5417:: with SMTP id z23mr441677pjh.111.1612208518510; Mon, 01 Feb 2021 11:41:58 -0800 (PST) Received: from laptop.hsd1.wa.comcast.net ([2601:600:9b7f:872e:a655:30fb:7373:c762]) by smtp.gmail.com with ESMTPSA id i4sm18213155pfo.40.2021.02.01.11.41.57 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 01 Feb 2021 11:41:57 -0800 (PST) From: Andrei Vagin To: Will Deacon , Catalin Marinas Subject: [PATCH 0/3 v2] arm64/ptrace: allow to get all registers on syscall traps Date: Mon, 1 Feb 2021 11:40:09 -0800 Message-Id: <20210201194012.524831-1-avagin@gmail.com> X-Mailer: git-send-email 2.29.2 MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20210201_144202_917456_F43A9F45 X-CRM114-Status: GOOD ( 13.03 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Anthony Steinhauser , linux-api@vger.kernel.org, Oleg Nesterov , linux-kernel@vger.kernel.org, Keno Fischer , Andrei Vagin , Dave Martin , linux-arm-kernel@lists.infradead.org Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org Right now, ip/r12 for AArch32 and x7 for AArch64 is used to indicate whether or not the stop has been signalled from syscall entry or syscall exit. This means that: - Any writes by the tracer to this register during the stop are ignored/discarded. - The actual value of the register is not available during the stop, so the tracer cannot save it and restore it later. For applications like the user-mode Linux or gVisor, it is critical to have access to the full set of registers in any moment. For example, they need to change values of all registers to emulate rt_sigreturn or execve and they need to have the full set of registers to build a signal frame. This series introduces the PTRACE_O_ARM64_RAW_REGS option. If it is set, PTRACE_GETREGSET returns values of all registers, and PTRACE_SETREGSET allows to change any of them. Cc: Catalin Marinas Cc: Dave Martin Cc: Keno Fischer Cc: Oleg Nesterov Cc: Will Deacon Andrei Vagin (3): arm64/ptrace: don't clobber task registers on syscall entry/exit traps arm64/ptrace: introduce PTRACE_O_ARM64_RAW_REGS selftest/arm64/ptrace: add tests for PTRACE_O_ARM64_RAW_REGS v2: use the ptrace option instead of adding a new regset. arch/arm64/include/asm/ptrace.h | 5 + arch/arm64/kernel/ptrace.c | 130 +++++++++++----- include/uapi/linux/elf.h | 1 + tools/testing/selftests/arm64/Makefile | 2 +- tools/testing/selftests/arm64/ptrace/Makefile | 6 + .../arm64/ptrace/ptrace_syscall_regs_test.c | 142 ++++++++++++++++++ 6 files changed, 246 insertions(+), 40 deletions(-) create mode 100644 tools/testing/selftests/arm64/ptrace/Makefile create mode 100644 tools/testing/selftests/arm64/ptrace/ptrace_syscall_regs_test.c -- 2.29.2 _______________________________________________ linux-arm-kernel mailing list linux-arm-kernel@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-arm-kernel