Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp5262688imm; Tue, 18 Sep 2018 06:55:18 -0700 (PDT) X-Google-Smtp-Source: ANB0Vda9RgAi/SfRAMTm0KHTg6w1NS8YU9jGtffSqT+T2zKtjB04ONjO+SJZQ69htIkaYh1I7wd7 X-Received: by 2002:a62:9ed1:: with SMTP id f78-v6mr31302033pfk.206.1537278918861; Tue, 18 Sep 2018 06:55:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1537278918; cv=none; d=google.com; s=arc-20160816; b=y9Z/qeLE/NPJEBh9H1Bd5ydM5ReDR83T8m2jWLcwq6geOPQ/zVdq18GeCzyBYB0KMO DAAPW0lnoMuKeZpDlGY0/O/5bITlY0nOETQDpBLIDMfPL+HDcbwL1URp9gOK4jGL81EN BGEtrB+dF3vfxZ0hN7rN/vIWY6k18caTxolxmrdUGZvySkpgzdqBsY5ygQ+VUz5Mqs6a 68dTVK0eq2duLRWwK7PvMaWd9aSmkrPSG9CSfYC1Y3JNkKCE85aQxGRIxpgk+riBfgCj VuilkGSU3zGrjz2HBHMCrWyrn8fe/RJJ1gCa/Kc2p2O7whkrj4ubeCNB2f5O4WY6IzBj t9HQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature:dkim-filter; bh=Vb+Xoe63fO5xpReySK+14lEymxnrzzTwRO35FZk4+D0=; b=EXxMN/4i6UGaG4x3qOzMq9WKOi+R/uhpAJJmCLpfhOaSJRFJIkERKpadqi2lo2X7IK 4QrS5+yBoq0bpwb2J16DA36UKO5cJRocNs5WndwrAnkJbP8Ei/oQIpGLY3Hxrr1pgCv/ tV1p0TcDxROKSk5tJNMaZ0sz2Clc2vrugFxUh1/gBEVhJCgr6ow6ZmgPccEbgHCDqvga ieaYeEWrIwoU7fqEMCYXD9Z+PmYmGUHzCuLqQ037/YeMhwHDryqlY27JyMwC9BnQEnsE bX2CPsqAVVOernrhwercGbR9EMyhtuShzUdMGRQsBuDjPAVtv9fDMLe8DO1BTotRm+bk zQGQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@efficios.com header.s=default header.b=dttpcY4V; 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=NONE dis=NONE) header.from=efficios.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 91-v6si21601903ple.169.2018.09.18.06.55.03; Tue, 18 Sep 2018 06:55:18 -0700 (PDT) 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=@efficios.com header.s=default header.b=dttpcY4V; 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=NONE dis=NONE) header.from=efficios.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729843AbeIRT1S (ORCPT + 99 others); Tue, 18 Sep 2018 15:27:18 -0400 Received: from mail.efficios.com ([167.114.142.138]:51048 "EHLO mail.efficios.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727846AbeIRT1S (ORCPT ); Tue, 18 Sep 2018 15:27:18 -0400 Received: from localhost (ip6-localhost [IPv6:::1]) by mail.efficios.com (Postfix) with ESMTP id 6A2A523F9B6; Tue, 18 Sep 2018 09:54:33 -0400 (EDT) Received: from mail.efficios.com ([IPv6:::1]) by localhost (mail02.efficios.com [IPv6:::1]) (amavisd-new, port 10032) with ESMTP id 9h3yJSJJct0B; Tue, 18 Sep 2018 09:54:31 -0400 (EDT) Received: from localhost (ip6-localhost [IPv6:::1]) by mail.efficios.com (Postfix) with ESMTP id C5CD923F9B3; Tue, 18 Sep 2018 09:54:31 -0400 (EDT) DKIM-Filter: OpenDKIM Filter v2.10.3 mail.efficios.com C5CD923F9B3 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=efficios.com; s=default; t=1537278871; bh=Vb+Xoe63fO5xpReySK+14lEymxnrzzTwRO35FZk4+D0=; h=From:To:Date:Message-Id; b=dttpcY4VYtUNiiUKBdrVGYnpDbBE698elgy2o27K/4znpgdea3g+op1eUMrHBU7Rd Rw+34fCICHS8tLZxDTXqTQt+Efh1TQIlBtNlfj1/9YKS25e2UWwwwna+AQtWULAAIx Sw8yuanUv67Pm0ODmnktN8VYIH5LqDKibjxjc6mMrRzXo/OmzmzUVgBax8+DECiPda flv22ur+60+M+8Zo+ZmK3xEF47+DhXtF6P9Te9TwnPDz/EFPdpxtO/WgJmnM2PJNKA AQjjpXSAzrjSOIil6fgNWQxkhcsqb1gFcspYR46xHasuhtxRL9/kE7YgTLI2NRLMKx VrmXUHlQ19Kxw== X-Virus-Scanned: amavisd-new at efficios.com Received: from mail.efficios.com ([IPv6:::1]) by localhost (mail02.efficios.com [IPv6:::1]) (amavisd-new, port 10026) with ESMTP id L5VxyA8y2AEX; Tue, 18 Sep 2018 09:54:31 -0400 (EDT) Received: from thinkos.internal.efficios.com (192-222-157-41.qc.cable.ebox.net [192.222.157.41]) by mail.efficios.com (Postfix) with ESMTPSA id 50A0323F9AE; Tue, 18 Sep 2018 09:54:31 -0400 (EDT) From: Mathieu Desnoyers To: Thomas Gleixner Cc: linux-kernel@vger.kernel.org, linux-api@vger.kernel.org, Peter Zijlstra , "Paul E . McKenney" , Boqun Feng , Andy Lutomirski , Dave Watson , Paul Turner , Andrew Morton , Russell King , Ingo Molnar , "H . Peter Anvin" , Andi Kleen , Chris Lameter , Ben Maurer , Steven Rostedt , Josh Triplett , Linus Torvalds , Catalin Marinas , Will Deacon , Michael Kerrisk , Joel Fernandes , Mathieu Desnoyers , "# v4 . 18" , Shuah Khan , linux-kselftest@vger.kernel.org Subject: [PATCH] rseq/selftests: fix parametrized test with -fpie Date: Tue, 18 Sep 2018 09:53:28 -0400 Message-Id: <20180918135328.32034-1-mathieu.desnoyers@efficios.com> X-Mailer: git-send-email 2.11.0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On x86-64, the parametrized selftest code for rseq crashes with a segmentation fault when compiled with -fpie. This happens when the param_test binary is loaded at an address beyond 32-bit on x86-64. The issue is caused by use of a 32-bit register to hold the address of the loop counter variable. Fix this by using a 64-bit register to calculate the address of the loop counter variables as an offset from rip. Signed-off-by: Mathieu Desnoyers Cc: # v4.18 Cc: Thomas Gleixner Cc: Joel Fernandes Cc: Peter Zijlstra Cc: Catalin Marinas Cc: Dave Watson Cc: Will Deacon Cc: Shuah Khan Cc: Andi Kleen Cc: linux-kselftest@vger.kernel.org Cc: "H . Peter Anvin" Cc: Chris Lameter Cc: Russell King Cc: Michael Kerrisk Cc: "Paul E . McKenney" Cc: Paul Turner Cc: Boqun Feng Cc: Josh Triplett Cc: Steven Rostedt Cc: Ben Maurer Cc: Andy Lutomirski Cc: Andrew Morton Cc: Linus Torvalds --- tools/testing/selftests/rseq/param_test.c | 19 ++++++++++--------- 1 file changed, 10 insertions(+), 9 deletions(-) diff --git a/tools/testing/selftests/rseq/param_test.c b/tools/testing/selftests/rseq/param_test.c index 615252331813..4bc071525bf7 100644 --- a/tools/testing/selftests/rseq/param_test.c +++ b/tools/testing/selftests/rseq/param_test.c @@ -56,15 +56,13 @@ unsigned int yield_mod_cnt, nr_abort; printf(fmt, ## __VA_ARGS__); \ } while (0) -#if defined(__x86_64__) || defined(__i386__) +#ifdef __i386__ #define INJECT_ASM_REG "eax" #define RSEQ_INJECT_CLOBBER \ , INJECT_ASM_REG -#ifdef __i386__ - #define RSEQ_INJECT_ASM(n) \ "mov asm_loop_cnt_" #n ", %%" INJECT_ASM_REG "\n\t" \ "test %%" INJECT_ASM_REG ",%%" INJECT_ASM_REG "\n\t" \ @@ -76,9 +74,16 @@ unsigned int yield_mod_cnt, nr_abort; #elif defined(__x86_64__) +#define INJECT_ASM_REG_P "rax" +#define INJECT_ASM_REG "eax" + +#define RSEQ_INJECT_CLOBBER \ + , INJECT_ASM_REG_P \ + , INJECT_ASM_REG + #define RSEQ_INJECT_ASM(n) \ - "lea asm_loop_cnt_" #n "(%%rip), %%" INJECT_ASM_REG "\n\t" \ - "mov (%%" INJECT_ASM_REG "), %%" INJECT_ASM_REG "\n\t" \ + "lea asm_loop_cnt_" #n "(%%rip), %%" INJECT_ASM_REG_P "\n\t" \ + "mov (%%" INJECT_ASM_REG_P "), %%" INJECT_ASM_REG "\n\t" \ "test %%" INJECT_ASM_REG ",%%" INJECT_ASM_REG "\n\t" \ "jz 333f\n\t" \ "222:\n\t" \ @@ -86,10 +91,6 @@ unsigned int yield_mod_cnt, nr_abort; "jnz 222b\n\t" \ "333:\n\t" -#else -#error "Unsupported architecture" -#endif - #elif defined(__ARMEL__) #define RSEQ_INJECT_INPUT \ -- 2.11.0