Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp1729793pxb; Mon, 23 Aug 2021 03:15:27 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwfYOClJRZdJkZEhAT7DblunIGl/eLw2vw2tjlaGw8Z1Z9svrfVvwZ/d9OXTeHXfKsYBIyi X-Received: by 2002:a05:6e02:15c8:: with SMTP id q8mr22372861ilu.285.1629713727360; Mon, 23 Aug 2021 03:15:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1629713727; cv=none; d=google.com; s=arc-20160816; b=FkV52tTeOCiA5IdKazUA/nW+xN8xQbVWmr3sBMH+mLLFF01A/NFhnX+2NoS7AOTkPf nZrA0fNHyWKCAkKJolGh8ZH2Z79L61IZQ8b8wuJexIkatO4M348Ykv6+F/GeISMY7hxK n/hTZLhyiWOvUR0MbkHYI1U0utViXeaWSsVEJso4gxIagAl+qxMpqD8cYvW+m5JUAPY2 6DKJjcJ+w8zL1SmQ96QWis06+hPF4A7k9yxVbXiVV8krvL6Jff4UwfkLtqkmct27hIOF VOI46YryC5YZ7/V4mfrxU7kwdMkNXkgKMivqBdOsnZUHWvjeGj8Fdp3UQ6GFtFF0WX6T jsJA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject; bh=y2u9qkwyEApLwwB82+S9v7DM4TfHRQYR/KST/sTZbqM=; b=nMlNVVT7XGbcpyfrk+4zyJ2zKukTFFH5Xpdz59q5tZJSJV2T/EEsx4d1j6/pB2t5d5 nYp5RNCBVvb3Vfa8mpnxJXr4wezWi1Wgfi5k1XZ0/o5u+j3Jiw1aMHDf74nMJqpAytyz nSW+hqbedRKjO3/QPrxDXQxRVLHaHlLA3dobszRAFlXvBz3z8Lzp8osZ64friBTCYAXW QKL0Jo5MwoRmU6QZ8dOXiD+ziTx6nvxhhU66a1Roh3v+eMTXCvVSDSBMHZus+5z1y1PH bh/2Oio5gv6JuxkVv87Y83MfUvR/H6BE3e1ihgiI8FMbE93AsXgWy1XCTtlYLCqtoREs lP6A== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id t39si16188562jal.96.2021.08.23.03.15.16; Mon, 23 Aug 2021 03:15:27 -0700 (PDT) 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233399AbhHWKOw (ORCPT + 99 others); Mon, 23 Aug 2021 06:14:52 -0400 Received: from 8.mo548.mail-out.ovh.net ([46.105.45.231]:57583 "EHLO 8.mo548.mail-out.ovh.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236126AbhHWKOs (ORCPT ); Mon, 23 Aug 2021 06:14:48 -0400 X-Greylist: delayed 2399 seconds by postgrey-1.27 at vger.kernel.org; Mon, 23 Aug 2021 06:14:47 EDT Received: from mxplan5.mail.ovh.net (unknown [10.109.138.5]) by mo548.mail-out.ovh.net (Postfix) with ESMTPS id 01DE01FED9; Mon, 23 Aug 2021 08:56:19 +0000 (UTC) Received: from kaod.org (37.59.142.106) by DAG4EX1.mxp5.local (172.16.2.31) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2308.14; Mon, 23 Aug 2021 10:56:19 +0200 Authentication-Results: garm.ovh; auth=pass (GARM-106R0065799e57a-66fe-451c-a3d9-b40df5884a81, 6C3DA580BFD2A03B9CD9C7EDF86CA127720438B1) smtp.auth=clg@kaod.org X-OVh-ClientIp: 83.199.102.86 Subject: Re: [PATCH v2] powerpc/audit: Convert powerpc to AUDIT_ARCH_COMPAT_GENERIC To: Christophe Leroy , Benjamin Herrenschmidt , Paul Mackerras , Michael Ellerman CC: , References: From: =?UTF-8?Q?C=c3=a9dric_Le_Goater?= Message-ID: <753e61fc-aab5-7797-d344-b15e9f4d6d5c@kaod.org> Date: Mon, 23 Aug 2021 10:56:18 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.11.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 8bit X-Originating-IP: [37.59.142.106] X-ClientProxiedBy: DAG3EX2.mxp5.local (172.16.2.22) To DAG4EX1.mxp5.local (172.16.2.31) X-Ovh-Tracer-GUID: 72695990-56d4-485e-b4e1-f8349831bb03 X-Ovh-Tracer-Id: 7112028239204944678 X-VR-SPAMSTATE: OK X-VR-SPAMSCORE: -100 X-VR-SPAMCAUSE: gggruggvucftvghtrhhoucdtuddrgedvtddruddthedguddtucetufdoteggodetrfdotffvucfrrhhofhhilhgvmecuqfggjfdpvefjgfevmfevgfenuceurghilhhouhhtmecuhedttdenucesvcftvggtihhpihgvnhhtshculddquddttddmnecujfgurhepuffvfhfhkffffgggjggtgfhisehtkeertddtfeejnecuhfhrohhmpeevrogurhhitggpnfgvpgfiohgrthgvrhcuoegtlhhgsehkrghougdrohhrgheqnecuggftrfgrthhtvghrnhepjeekudeuudevleegudeugeekleffveeludejteffiedvledvgfekueefudehheefnecukfhppedtrddtrddtrddtpdefjedrheelrddugedvrddutdeinecuvehluhhsthgvrhfuihiivgeptdenucfrrghrrghmpehmohguvgepshhmthhpqdhouhhtpdhhvghlohepmhigphhlrghnhedrmhgrihhlrdhovhhhrdhnvghtpdhinhgvtheptddrtddrtddrtddpmhgrihhlfhhrohhmpegtlhhgsehkrghougdrohhrghdprhgtphhtthhopegthhhrihhsthhophhhvgdrlhgvrhhohiestghsghhrohhuphdrvghu Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 8/23/21 8:49 AM, Christophe Leroy wrote: > Commit e65e1fc2d24b ("[PATCH] syscall class hookup for all normal > targets") added generic support for AUDIT but that didn't include > support for bi-arch like powerpc. > > Commit 4b58841149dc ("audit: Add generic compat syscall support") > added generic support for bi-arch. > > Convert powerpc to that bi-arch generic audit support. > > Signed-off-by: Christophe Leroy Reviewed-by: Cédric Le Goater Thanks, C. > --- > v2: > - Missing 'git add' for arch/powerpc/include/asm/unistd32.h > - Finalised commit description > --- > arch/powerpc/Kconfig | 5 +- > arch/powerpc/include/asm/unistd32.h | 7 +++ > arch/powerpc/kernel/Makefile | 3 -- > arch/powerpc/kernel/audit.c | 84 ----------------------------- > arch/powerpc/kernel/compat_audit.c | 44 --------------- > 5 files changed, 8 insertions(+), 135 deletions(-) > create mode 100644 arch/powerpc/include/asm/unistd32.h > delete mode 100644 arch/powerpc/kernel/audit.c > delete mode 100644 arch/powerpc/kernel/compat_audit.c > > diff --git a/arch/powerpc/Kconfig b/arch/powerpc/Kconfig > index 663766fbf505..5472358609d2 100644 > --- a/arch/powerpc/Kconfig > +++ b/arch/powerpc/Kconfig > @@ -163,6 +163,7 @@ config PPC > select ARCH_WANT_IRQS_OFF_ACTIVATE_MM > select ARCH_WANT_LD_ORPHAN_WARN > select ARCH_WEAK_RELEASE_ACQUIRE > + select AUDIT_ARCH_COMPAT_GENERIC > select BINFMT_ELF > select BUILDTIME_TABLE_SORT > select CLONE_BACKWARDS > @@ -316,10 +317,6 @@ config GENERIC_TBSYNC > bool > default y if PPC32 && SMP > > -config AUDIT_ARCH > - bool > - default y > - > config GENERIC_BUG > bool > default y > diff --git a/arch/powerpc/include/asm/unistd32.h b/arch/powerpc/include/asm/unistd32.h > new file mode 100644 > index 000000000000..07689897d206 > --- /dev/null > +++ b/arch/powerpc/include/asm/unistd32.h > @@ -0,0 +1,7 @@ > +/* SPDX-License-Identifier: GPL-2.0-or-later */ > +#ifndef _ASM_POWERPC_UNISTD32_H_ > +#define _ASM_POWERPC_UNISTD32_H_ > + > +#include > + > +#endif /* _ASM_POWERPC_UNISTD32_H_ */ > diff --git a/arch/powerpc/kernel/Makefile b/arch/powerpc/kernel/Makefile > index 7be36c1e1db6..825121eba3c2 100644 > --- a/arch/powerpc/kernel/Makefile > +++ b/arch/powerpc/kernel/Makefile > @@ -125,9 +125,6 @@ obj-$(CONFIG_PCI) += pci_$(BITS).o $(pci64-y) \ > pci-common.o pci_of_scan.o > obj-$(CONFIG_PCI_MSI) += msi.o > > -obj-$(CONFIG_AUDIT) += audit.o > -obj64-$(CONFIG_AUDIT) += compat_audit.o > - > obj-$(CONFIG_PPC_IO_WORKAROUNDS) += io-workarounds.o > > obj-y += trace/ > diff --git a/arch/powerpc/kernel/audit.c b/arch/powerpc/kernel/audit.c > deleted file mode 100644 > index a2dddd7f3d09..000000000000 > --- a/arch/powerpc/kernel/audit.c > +++ /dev/null > @@ -1,84 +0,0 @@ > -// SPDX-License-Identifier: GPL-2.0 > -#include > -#include > -#include > -#include > - > -static unsigned dir_class[] = { > -#include > -~0U > -}; > - > -static unsigned read_class[] = { > -#include > -~0U > -}; > - > -static unsigned write_class[] = { > -#include > -~0U > -}; > - > -static unsigned chattr_class[] = { > -#include > -~0U > -}; > - > -static unsigned signal_class[] = { > -#include > -~0U > -}; > - > -int audit_classify_arch(int arch) > -{ > -#ifdef CONFIG_PPC64 > - if (arch == AUDIT_ARCH_PPC) > - return 1; > -#endif > - return 0; > -} > - > -int audit_classify_syscall(int abi, unsigned syscall) > -{ > -#ifdef CONFIG_PPC64 > - extern int ppc32_classify_syscall(unsigned); > - if (abi == AUDIT_ARCH_PPC) > - return ppc32_classify_syscall(syscall); > -#endif > - switch(syscall) { > - case __NR_open: > - return 2; > - case __NR_openat: > - return 3; > - case __NR_socketcall: > - return 4; > - case __NR_execve: > - return 5; > - default: > - return 0; > - } > -} > - > -static int __init audit_classes_init(void) > -{ > -#ifdef CONFIG_PPC64 > - extern __u32 ppc32_dir_class[]; > - extern __u32 ppc32_write_class[]; > - extern __u32 ppc32_read_class[]; > - extern __u32 ppc32_chattr_class[]; > - extern __u32 ppc32_signal_class[]; > - audit_register_class(AUDIT_CLASS_WRITE_32, ppc32_write_class); > - audit_register_class(AUDIT_CLASS_READ_32, ppc32_read_class); > - audit_register_class(AUDIT_CLASS_DIR_WRITE_32, ppc32_dir_class); > - audit_register_class(AUDIT_CLASS_CHATTR_32, ppc32_chattr_class); > - audit_register_class(AUDIT_CLASS_SIGNAL_32, ppc32_signal_class); > -#endif > - audit_register_class(AUDIT_CLASS_WRITE, write_class); > - audit_register_class(AUDIT_CLASS_READ, read_class); > - audit_register_class(AUDIT_CLASS_DIR_WRITE, dir_class); > - audit_register_class(AUDIT_CLASS_CHATTR, chattr_class); > - audit_register_class(AUDIT_CLASS_SIGNAL, signal_class); > - return 0; > -} > - > -__initcall(audit_classes_init); > diff --git a/arch/powerpc/kernel/compat_audit.c b/arch/powerpc/kernel/compat_audit.c > deleted file mode 100644 > index 55c6ccda0a85..000000000000 > --- a/arch/powerpc/kernel/compat_audit.c > +++ /dev/null > @@ -1,44 +0,0 @@ > -// SPDX-License-Identifier: GPL-2.0 > -#undef __powerpc64__ > -#include > - > -unsigned ppc32_dir_class[] = { > -#include > -~0U > -}; > - > -unsigned ppc32_chattr_class[] = { > -#include > -~0U > -}; > - > -unsigned ppc32_write_class[] = { > -#include > -~0U > -}; > - > -unsigned ppc32_read_class[] = { > -#include > -~0U > -}; > - > -unsigned ppc32_signal_class[] = { > -#include > -~0U > -}; > - > -int ppc32_classify_syscall(unsigned syscall) > -{ > - switch(syscall) { > - case __NR_open: > - return 2; > - case __NR_openat: > - return 3; > - case __NR_socketcall: > - return 4; > - case __NR_execve: > - return 5; > - default: > - return 1; > - } > -} >