Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp634397pxb; Sat, 20 Feb 2021 16:30:22 -0800 (PST) X-Google-Smtp-Source: ABdhPJz6TXEM6uYEOO8rK/B++t6sRlLpmw22nYayXVoV/9skhqVphyYWroXcr7K1kMKQO1RkbP5Y X-Received: by 2002:a17:906:1759:: with SMTP id d25mr11834383eje.524.1613867422496; Sat, 20 Feb 2021 16:30:22 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1613867422; cv=none; d=google.com; s=arc-20160816; b=zh592btmlvAikqUDzUN7FENaekvTAY5DvXly8wPlUOVwIILqRChAR+7LMYDJeMCIhy DIPpxk2MFyPehs0rYPfJdl9kVaNzsrGv6uNnT5ix996mmPGszabCh9QoKuGVPR2AzRR5 IlMuSuhMaBONf9ufs1DqdvYQ3MkdOPgpCgWLP9EBZXmRET/WcL2fJRMxvMxmQDVsOHvW HepBKyzTN6K2NutkabKJgBV/aW3zYq+mUs1Zr3gp89lNBAVir2OfAeMOppAlcR6CtQH9 dobwKw71+wgFENHQGavTUopWYm1LqWf00Ew9IbbvVq8OmRRxbqY/ycdQVPisZYVFFYhM CN4w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=r0oWREkkf7NrTORPBLua9gG4PKW/JPZ44Tem5YnLfo8=; b=wB9U6X1GNUmvKJz63lmXrSwHrz1ZmqarSOF8DJ3WFuxCBvafhT1OK3ThazUjtdk4cn QygVh1JkwqZr/dinDOzKfTtoemx9HJfMqhUDHR4TtpfGwcKtvlmk9oi30ENkAoKpqpsH iyIJDljZHKPnx9v895Jnnp+aBhgkNc1JaN5UNCPsFWipIkhPPGmkY0MrIY9sAUPqhIZV mxOGTz3v8OBrqjc5OnG5kSDttYnW7yQX10ZmOfMG5yAPqcoOmvcUPVH9pJRZife7GC7G m358kV/NbBBg9HrFZeYLqfJT8rO2q/VLS4Pszj5GwauJg/VW1OXkTmsMvUJO/ZV4ncHL HZmQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=gentoo.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id l21si9107095edw.606.2021.02.20.16.29.38; Sat, 20 Feb 2021 16:30:22 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=gentoo.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229847AbhBUA0w (ORCPT + 99 others); Sat, 20 Feb 2021 19:26:52 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53130 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229819AbhBUA0s (ORCPT ); Sat, 20 Feb 2021 19:26:48 -0500 Received: from smtp.gentoo.org (dev.gentoo.org [IPv6:2001:470:ea4a:1:5054:ff:fec7:86e4]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 55DA6C061574; Sat, 20 Feb 2021 16:26:07 -0800 (PST) Received: by sf.home (Postfix, from userid 1000) id 58FC65A2208E; Sun, 21 Feb 2021 00:25:59 +0000 (GMT) From: Sergei Trofimovich To: Andrew Morton , linux-kernel@vger.kernel.org Cc: Sergei Trofimovich , linux-ia64@vger.kernel.org, "Dmitry V . Levin" Subject: [PATCH] ia64: fix ptrace(PTRACE_SYSCALL_INFO_EXIT) sign Date: Sun, 21 Feb 2021 00:25:54 +0000 Message-Id: <20210221002554.333076-2-slyfox@gentoo.org> X-Mailer: git-send-email 2.30.1 In-Reply-To: <20210221002554.333076-1-slyfox@gentoo.org> References: <20210221002554.333076-1-slyfox@gentoo.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org In https://bugs.gentoo.org/769614 Dmitry noticed that `ptrace(PTRACE_GET_SYSCALL_INFO)` does not return error sign properly. The bug is in mismatch between get/set errors: static inline long syscall_get_error(struct task_struct *task, struct pt_regs *regs) { return regs->r10 == -1 ? regs->r8:0; } static inline long syscall_get_return_value(struct task_struct *task, struct pt_regs *regs) { return regs->r8; } static inline void syscall_set_return_value(struct task_struct *task, struct pt_regs *regs, int error, long val) { if (error) { /* error < 0, but ia64 uses > 0 return value */ regs->r8 = -error; regs->r10 = -1; } else { regs->r8 = val; regs->r10 = 0; } } Tested on v5.10 on rx3600 machine (ia64 9040 CPU). CC: linux-ia64@vger.kernel.org CC: linux-kernel@vger.kernel.org CC: Andrew Morton Reported-by: Dmitry V. Levin Bug: https://bugs.gentoo.org/769614 Signed-off-by: Sergei Trofimovich --- arch/ia64/include/asm/syscall.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/arch/ia64/include/asm/syscall.h b/arch/ia64/include/asm/syscall.h index 6c6f16e409a8..0d23c0049301 100644 --- a/arch/ia64/include/asm/syscall.h +++ b/arch/ia64/include/asm/syscall.h @@ -32,7 +32,7 @@ static inline void syscall_rollback(struct task_struct *task, static inline long syscall_get_error(struct task_struct *task, struct pt_regs *regs) { - return regs->r10 == -1 ? regs->r8:0; + return regs->r10 == -1 ? -regs->r8:0; } static inline long syscall_get_return_value(struct task_struct *task, -- 2.30.1