From patchwork Thu Jun 21 16:23:23 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Nick Desaulniers X-Patchwork-Id: 10480183 Return-Path: Received: from mail.wl.linuxfoundation.org (pdx-wl-mail.web.codeaurora.org [172.30.200.125]) by pdx-korg-patchwork.web.codeaurora.org (Postfix) with ESMTP id AFE0460532 for ; Thu, 21 Jun 2018 16:26:23 +0000 (UTC) Received: from mail.wl.linuxfoundation.org (localhost [127.0.0.1]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id 9717B2930B for ; Thu, 21 Jun 2018 16:26:23 +0000 (UTC) Received: by mail.wl.linuxfoundation.org (Postfix, from userid 486) id 8517729304; Thu, 21 Jun 2018 16:26:23 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on pdx-wl-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-7.8 required=2.0 tests=BAYES_00, DKIM_ADSP_CUSTOM_MED, DKIM_SIGNED, MAILING_LIST_MULTI, RCVD_IN_DNSWL_HI, T_DKIM_INVALID autolearn=ham version=3.3.1 Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id 22B7229334 for ; Thu, 21 Jun 2018 16:24:18 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S933297AbeFUQYQ (ORCPT ); Thu, 21 Jun 2018 12:24:16 -0400 Received: from mail-it0-f73.google.com ([209.85.214.73]:39917 "EHLO mail-it0-f73.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S933422AbeFUQXj (ORCPT ); Thu, 21 Jun 2018 12:23:39 -0400 Received: by mail-it0-f73.google.com with SMTP id o7-v6so3039736itf.4 for ; Thu, 21 Jun 2018 09:23:38 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=mime-version:date:in-reply-to:message-id:references:subject:from:to :cc; bh=6IRyW2+wJGByljsyTJ7DxPDfnQO8dfQWb02gEMcyb/I=; b=KZDQzMmiOTmJL4Bg4c61XG5P+PkX8ExmS6RdxYMtWnQXO6tbAUV82YwTJz6bLugXjA P89JHaUMiXfrhp4IO0wOxlVvQLfHWiiQxCJJ51KwExaA6jSwwHqdgs1SHoI/kkBRo9Nj F1N+vNuBnoBrF5X3EQyFPo9HO6DpfYt9N0UcNjvRkE/9AWXRGOSb8l1JA7ymBehIBxH2 DStGEl+yPBgYCzm8jLW47ZJCcgI/OiB5i3svl0xcCzXBP7bTvpsuMMSQeis5zj96nD8Y lh0AoxB90URn8e/ggtyTNj3diEmWUGbkvMbjIgYSogkL2RXCxOqiaUyMqynuBvWuIqAs uYHQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:date:in-reply-to:message-id :references:subject:from:to:cc; bh=6IRyW2+wJGByljsyTJ7DxPDfnQO8dfQWb02gEMcyb/I=; b=AZAzr2svojmJJH+tYe2Rkdpv2mPng4fqUBFJL7JYsiJtPo3EfPA6YG4vpwO/F/AFDs 3WwN8zF3Z07hCwZZd3ZCROWq9GScQC2N2RC1RY/DqZNONW5wnXxKJrtOe+murcvrefn0 sXgmS5vgPzJtmeGzq2MYtS9J3NKP2MTtXZrxsk+iI0MhBx+OK2J5A5VChZ12ZQFOoQLI iQurFuf9mzBmxMGvw6ks30d/q0PTW9ysPxmiCXuqEqKw/nrM0isdWEY3durpP56Hshmd 66s/j+IZ2UM/oBx6K8E6wOfQD5izUACOj7lOI2OINW8fHXoBEMXTdJbj81qjX22/XiBG qS5A== X-Gm-Message-State: APt69E2I866nPFbtyDX1rgM382JkEX6EGMCM52hjBeoksRuqfbvV/EG0 +twI7JacpTEycj/ldfaaYDjQdemUup03BaD5WKg= X-Google-Smtp-Source: ADUXVKJFUUPUsRNdiQoVlTdOsKnXMZ1OHQCPRT4oOKG69Pxc8FAupYvIq/39emBitL8SYG9oPiC3o/cK2cZfDUvlBPo= MIME-Version: 1.0 X-Received: by 2002:a24:228c:: with SMTP id o134-v6mr2901471ito.30.1529598217972; Thu, 21 Jun 2018 09:23:37 -0700 (PDT) Date: Thu, 21 Jun 2018 09:23:23 -0700 In-Reply-To: <20180621162324.36656-1-ndesaulniers@google.com> Message-Id: <20180621162324.36656-3-ndesaulniers@google.com> References: <20180621162324.36656-1-ndesaulniers@google.com> X-Mailer: git-send-email 2.18.0.rc2.346.g013aa6912e-goog Subject: [PATCH v6 2/3] x86/asm: add _ASM_ARG* constants for argument registers to From: Nick Desaulniers To: mingo@redhat.com, tglx@linutronix.de Cc: akpm@linux-foundation.org, hpa@zytor.com, linux-efi@vger.kernel.org, linux-kernel@vger.kernel.org, x86@kernel.org, virtualization@lists.linux-foundation.org, astrachan@google.com, manojgupta@google.com, ghackmann@google.com, sedat.dilek@gmail.com, tstellar@redhat.com, keescook@google.com, yamada.masahiro@socionext.com, michal.lkml@markovi.net, linux-kbuild@vger.kernel.org, geert@linux-m68k.org, will.deacon@arm.com, mawilcox@microsoft.com, arnd@arndb.de, rientjes@google.com, acme@redhat.com, pombredanne@nexb.com, aryabinin@virtuozzo.com, kstewart@linuxfoundation.org, boris.ostrovsky@oracle.com, jan.kiszka@siemens.com, rostedt@goodmis.org, kirill.shutemov@linux.intel.com, ard.biesheuvel@linaro.org, akataria@vmware.com, brijesh.singh@amd.com, caoj.fnst@cn.fujitsu.com, gregkh@linuxfoundation.org, jarkko.sakkinen@linux.intel.com, jgross@suse.com, jpoimboe@redhat.com, mka@chromium.org, ndesaulniers@google.com, thomas.lendacky@amd.com, tweek@google.com, mjg59@google.com, joe@perches.com, andrea.parri@amarulasolutions.com, "H. Peter Anvin" Sender: linux-kbuild-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kbuild@vger.kernel.org X-Virus-Scanned: ClamAV using ClamSMTP From: "H. Peter Anvin" i386 and x86-64 uses different registers for arguments; make them available so we don't have to #ifdef in the actual code. Native size and specified size (q, l, w, b) versions are provided. Acked-by: Juergen Gross Reviewed-by: Sedat Dilek Signed-off-by: H. Peter Anvin Signed-off-by: Nick Desaulniers --- arch/x86/include/asm/asm.h | 59 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 59 insertions(+) diff --git a/arch/x86/include/asm/asm.h b/arch/x86/include/asm/asm.h index 219faaec51df..990770f9e76b 100644 --- a/arch/x86/include/asm/asm.h +++ b/arch/x86/include/asm/asm.h @@ -46,6 +46,65 @@ #define _ASM_SI __ASM_REG(si) #define _ASM_DI __ASM_REG(di) +#ifndef __x86_64__ +/* 32 bit */ + +#define _ASM_ARG1 _ASM_AX +#define _ASM_ARG2 _ASM_DX +#define _ASM_ARG3 _ASM_CX + +#define _ASM_ARG1L eax +#define _ASM_ARG2L edx +#define _ASM_ARG3L ecx + +#define _ASM_ARG1W ax +#define _ASM_ARG2W dx +#define _ASM_ARG3W cx + +#define _ASM_ARG1B al +#define _ASM_ARG2B dl +#define _ASM_ARG3B cl + +#else +/* 64 bit */ + +#define _ASM_ARG1 _ASM_DI +#define _ASM_ARG2 _ASM_SI +#define _ASM_ARG3 _ASM_DX +#define _ASM_ARG4 _ASM_CX +#define _ASM_ARG5 r8 +#define _ASM_ARG6 r9 + +#define _ASM_ARG1Q rdi +#define _ASM_ARG2Q rsi +#define _ASM_ARG3Q rdx +#define _ASM_ARG4Q rcx +#define _ASM_ARG5Q r8 +#define _ASM_ARG6Q r9 + +#define _ASM_ARG1L edi +#define _ASM_ARG2L esi +#define _ASM_ARG3L edx +#define _ASM_ARG4L ecx +#define _ASM_ARG5L r8d +#define _ASM_ARG6L r9d + +#define _ASM_ARG1W di +#define _ASM_ARG2W si +#define _ASM_ARG3W dx +#define _ASM_ARG4W cx +#define _ASM_ARG5W r8w +#define _ASM_ARG6W r9w + +#define _ASM_ARG1B dil +#define _ASM_ARG2B sil +#define _ASM_ARG3B dl +#define _ASM_ARG4B cl +#define _ASM_ARG5B r8b +#define _ASM_ARG6B r9b + +#endif + /* * Macros to generate condition code outputs from inline assembly, * The output operand must be type "bool".