Received: by 10.213.65.68 with SMTP id h4csp2432848imn; Mon, 9 Apr 2018 03:32:36 -0700 (PDT) X-Google-Smtp-Source: AIpwx48xFn4G0leCBkln+w402lNpd0K8ylUy56EKOj+pxRXPGGHjOrSHJKMgfT/07/Gpy/5vCWRm X-Received: by 10.99.52.134 with SMTP id b128mr24640999pga.342.1523269956608; Mon, 09 Apr 2018 03:32:36 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1523269956; cv=none; d=google.com; s=arc-20160816; b=yS5qdw4i7Ps9up9VB+b6jlVzdkyEHrExhDAZSRShTLP6Pu+TPfntGistthWn97P8Lx wBSUP8axPjfApdyb7zD3qcKVIqSS7f+k6XoAQGvCkeHyp99Rx6NooFJ1mOMsjP6nNIVw Eo3UnI+qv3xp6RU1Qerxf8pQ++UgslXehKuivvD/PwdgbjOGngJVnluQxFVydKGya6rj FQa37nZRUtqHfWWgvg54TAf9gftbft2+LDb1rEajQHM962OZIiwTSk0XGiYDmq5GXBg2 BxC4k2+e+R5uZ5c/seGxYSHpTu+dbsWnbTfF4UXZvrRb2ju7lgY2YD/QRop9SD+DTJtR nBLw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:subject:cc:to:from:date :dkim-signature:arc-authentication-results; bh=C4ZlUFfYCtDxpejcmOoRTnqeUn/eSv5vm/ggDYLhL00=; b=U2itop0xBOv+r5zUqKvZygEXZduSHvuxDdFH0+TpKxFqFtXSK0sXQSvQp76usTXsJ/ Ng3erAOMY56tBNMapbJMeQx+vs3vy7eMsEmV2aGP+Zikbpe76dBQHWS6KSnZlBH8i6JM KKsVh1N/WUJDGBWZ2OYrFe8mqp25UnH26qo76nGZVGhGz8JmIH0QlrAc3n43FImb1npy jABKwQqa2bMVcsJq7eqV4LfAyhViMStjYhp8Vg/WsvsWgFo1myeyECZjy/lt3l4lzDJh L1RafEmpKLgZ1Np9Uj+daISE+Vysj53s+tzH/VbHEN14DE+bfZ7lBUnHkGodP1P1+u9+ PvEw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@essential-com.20150623.gappssmtp.com header.s=20150623 header.b=pIDc8qbl; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 1-v6si15394plj.510.2018.04.09.03.31.59; Mon, 09 Apr 2018 03:32:36 -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=@essential-com.20150623.gappssmtp.com header.s=20150623 header.b=pIDc8qbl; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751916AbeDIK2M (ORCPT + 99 others); Mon, 9 Apr 2018 06:28:12 -0400 Received: from mail-pl0-f68.google.com ([209.85.160.68]:41053 "EHLO mail-pl0-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751581AbeDIK2L (ORCPT ); Mon, 9 Apr 2018 06:28:11 -0400 Received: by mail-pl0-f68.google.com with SMTP id bj1-v6so4827197plb.8 for ; Mon, 09 Apr 2018 03:28:10 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=essential-com.20150623.gappssmtp.com; s=20150623; h=date:from:to:cc:subject:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=C4ZlUFfYCtDxpejcmOoRTnqeUn/eSv5vm/ggDYLhL00=; b=pIDc8qblj8v60yhtw8OLmq1RADrn8K/2WPrktCZKBHFIHeZg7ynD023IX1AkveZsIP m8aU36qGY8zOUTLOn60ac5yg42M4qX5uz6yuygetKEPsxgqFFrvllZ/hBqSShTONtWsc MfZ3RniAa75xy39vvPXvpHKP1azptwvfV6jbJamj246sl0dnPWFiqWSCRuVBpi53RYJu CJhK+1ogzZkpHD46BxJmfdjp+HEjvoN6NiPlyuyrZh0j1MMu9+L3XtEV4nC67PW/Fe8q cMGl5p8mvImAz598hWodfC06/Cev5Bf8L1nyCoOQGZIJe970USSVyYEWDLoPC37IlwIv hLvA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=C4ZlUFfYCtDxpejcmOoRTnqeUn/eSv5vm/ggDYLhL00=; b=Za+WYDB1RPqPCgxIt7YxkTje57gdEERECfwOnFV+IQ5c7ABwXYS480fCdBQS0COnGA rbkVfu9iTkpLQCVDNQgbH+wiZIJJbVAhw9oGim0oWj1OHw2wae1PRvN2kyl893XhGkmn MjEifmbOEE4CwkPILliO0Uf50BkNKPjSV/oguUwiVhQscVh5Udrdc6EyEqvGBlYFkgHM VOQgBPnQQiupQ4jWACl9BUXi0MYjzNEx/Bwfo4JfCdbz7XXJcUr6nOJUReC7mJzUwwKD Biq5lVrK4P8BKFgS8TPCKzDEaw7hpMYUPCeSx+wKqabU71P6aCtwREEjDXq4/jhX79we 175Q== X-Gm-Message-State: AElRT7GYHKXfwSs2aza3Qjka2rWxR+f3RJtswF4SsML/idhEfx3WKhwC Bg7WDy+HdK9gfphW3/O4hzT6FQ== X-Received: by 2002:a17:902:6b49:: with SMTP id g9-v6mr38564573plt.75.1523269690273; Mon, 09 Apr 2018 03:28:10 -0700 (PDT) Received: from jbtheou ([203.215.133.124]) by smtp.gmail.com with ESMTPSA id t1sm80373pgs.47.2018.04.09.03.28.07 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Mon, 09 Apr 2018 03:28:10 -0700 (PDT) Date: Mon, 9 Apr 2018 19:28:03 +0900 From: Jean-Baptiste Theou To: Ard Biesheuvel Cc: Greg KH , Mark Rutland , Linux Kernel Mailing List , Will Deacon , Dan Rue , Mark Brown , Marc Zyngier , Greg Hackmann Subject: Re: Linux 4.9.93 Message-ID: <20180409192803.1e5f29af@jbtheou> In-Reply-To: <40BB2246-DD5D-4956-ADFA-6143FCC98D1B@linaro.org> References: <20180409180534.1768583293d0abe207168c5a@essential.com> <20180409093028.GA3398@kroah.com> <20180409185751.247a0ac7@jbtheou> <40BB2246-DD5D-4956-ADFA-6143FCC98D1B@linaro.org> X-Mailer: Claws Mail 3.16.0 (GTK+ 2.24.32; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: quoted-printable Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, 9 Apr 2018 12:25:07 +0200 Ard Biesheuvel wrote: > > On 9 Apr 2018, at 11:57, Jean-Baptiste Theou wrote: > >=20 > > On Mon, 9 Apr 2018 11:49:37 +0200 > > Ard Biesheuvel wrote: > > =20 > >>> On 9 April 2018 at 11:30, Greg KH wrote:= =20 > >>>> On Mon, Apr 09, 2018 at 06:05:34PM +0900, Jean-Baptiste Theou wrote:= =20 > >>>> Hi, > >>>>=20 > >>>> After this patchset, a kernel built with CFI fails. Disabling > >>>> UNMAP_KERNEL_AT_EL0 fix the issue obviously. =20 > >>=20 > >> How does one 'build a kernel with CFI' for arm64? =20 > >=20 > > From Google work on Android-4.9 > >=20 > > https://android.googlesource.com/kernel/common/+/00a195e7c0752ff5d65c9c= aadfbcc226270ca232 > >=20 > > I am not sure what is the plan on their side to upstream (Greg?), but d= efinitely > > useful to isolate actual issues. > > =20 > >> =20 > >>>=20 > >>> Is this a "clean" 4.9.93 tree or a "4.9.93 merged into > >>> android-common-4.9? =20 > >=20 > > It's a "clean 4.9.93" + whatever is needed for Clang/CFI support > >=20 > > My take is that CFI doesn't like=20 > >=20 > > * void __kpti_install_ng_mappings(int cpu, int num_cpus, phys_addr_t sw= apper) > >=20 > > and=20 > >=20 > > remap_fn =3D (void *)__pa_symbol(idmap_kpti_install_ng_mappings); > >=20 > > Maybe just flag this function to not use CFI? I remember that Sami Tolv= anen did > > similar changes. > >=20 > > I know it's a bit out of context since CFI support for ARM64 is not ups= tream yet, > > but unfortunate that an stable patchset trigger such failures. > > =20 >=20 > I am sorry but if you are implying that we should have tested these patch= es against the out of tree CFI code, I have to disappoint you: that is simp= ly not upstream=E2=80=99s job, and if the Google engineers merged this into= their v4.9 tree without proper testing, may I suggest that you report it t= o them instead? >=20 > OTOH, if that is not what you are implying, please ignore the rant :-) >=20 To be perfectly honest, I forgot that CFI wasn't an upstream feature. Indee= d, I don't expect upstream test farm to run out of tree. The real answer here is to upstream CFI ;-) Thanks a lot Best regards >=20 > > Thanks a lot > >=20 > > Best regards > > =20 > >>> =20 > >>>> Wondering if there is one of the test suite used on the review patch= set that covers the CFI usecase. > >>>>=20 > >>>> Best regards, > >>>>=20 > >>>> [ 0.249191] CPU features: detected feature: GIC system register C= PU interface > >>>> [ 0.256391] CPU features: detected feature: Privileged Access Nev= er > >>>> [ 0.262719] CPU features: detected feature: User Access Override > >>>> [ 0.268791] CPU features: detected feature: 32-bit EL0 Support > >>>> [ 0.274683] CPU features: detected feature: Kernel page table iso= lation (KPTI) > >>>> [ 0.282166] CFI failure: > >>>> [ 0.282169] CFI failure: > >>>> [ 0.282172] CFI failure: > >>>> [ 0.282173] CFI failure: > >>>> [ 0.282175] CFI failure: > >>>> [ 0.282176] CFI failure: > >>>> [ 0.282177] CFI failure: > >>>> [ 0.282178] CFI failure: > >>>> [ 0.282188] ------------[ cut here ]------------ > >>>> [ 0.282189] ------------[ cut here ]------------ > >>>> [ 0.282190] ------------[ cut here ]------------ > >>>> [ 0.282191] ------------[ cut here ]------------ > >>>> [ 0.282193] ------------[ cut here ]------------ > >>>> [ 0.282196] kernel BUG at kernel/cfi.c:32! > >>>> [ 0.282198] ------------[ cut here ]------------ > >>>> [ 0.282201] kernel BUG at kernel/cfi.c:32! > >>>> [ 0.282202] ------------[ cut here ]------------ > >>>> [ 0.282204] kernel BUG at kernel/cfi.c:32! > >>>> [ 0.282207] kernel BUG at kernel/cfi.c:32! > >>>> [ 0.282209] kernel BUG at kernel/cfi.c:32! > >>>> [ 0.282211] kernel BUG at kernel/cfi.c:32! > >>>> [ 0.282214] kernel BUG at kernel/cfi.c:32! > >>>> [ 0.282215] ------------[ cut here ]------------ > >>>> [ 0.282216] kernel BUG at kernel/cfi.c:32! > >>>> [ 0.282218] Internal error: Oops - BUG: 0 [#1] PREEMPT SMP > >>>> [ 0.282224] Modules linked in: > >>>> [ 0.282230] CPU: 2 PID: 25 Comm: migration/2 Not tainted 4.9.93-p= erf+ #39 > >>>> [ 0.282232] Hardware name: > >>>> [ 0.282235] task: fffffffbb3b36580 task.stack: fffffffbb30cc000 > >>>> [ 0.282250] PC is at __cfi_check_fail+0x14/0x1c > >>>> [ 0.282253] LR is at __cfi_check_fail+0x14/0x1c > >>>> [ 0.282255] pc : [] lr : [] p= state: 60c00085 > >>>> [ 0.282256] sp : fffffffbb30cfc30 > >>>> [ 0.282259] x29: fffffffbb30cfc30 x28: ffffff93b6415000 > >>>> [ 0.282261] x27: 00000013b65c1000 x26: ffffff93b5ce6000 > >>>> [ 0.282264] x25: ffffff93b5ce6000 x24: ffffff93b6419000 > >>>> [ 0.282266] x23: ffffff93b65c1000 x22: ffffff93b65c4000 > >>>> [ 0.282268] x21: 9d12f8172cb2f296 x20: 000000008180e3e0 > >>>> [ 0.282271] x19: 0000000000000000 x18: 000000000000002c > >>>> [ 0.282274] x17: 00000000000fd054 x16: 0000000000000000 > >>>> [ 0.282276] x15: ffffff93b65ec000 x14: 000000000000000c > >>>> [ 0.282279] x13: 0000000000000004 x12: 0000000000000000 > >>>> [ 0.282281] x11: 0000000000000000 x10: 0000000001440144 > >>>> [ 0.282283] x9 : 260822e8751d5000 x8 : 260822e8751d5000 > >>>> [ 0.282286] x7 : 0000000000000000 x6 : fffffffbbac75b60 > >>>> [ 0.282288] x5 : 0000000000000000 x4 : 0000000000000000 > >>>> [ 0.282290] x3 : 000000003a657275 x2 : 0000000000000000 > >>>> [ 0.282292] x1 : 0000000000000000 x0 : 000000000000000c > >>>> [ 0.282294] > >>>> [ 0.282294] PC: 0xffffff93b3f03d50: > >>>> [ 0.282308] 3d50 b9001ac8 f94002c8 370ffec8 17ffffbe d4210000 14= 000000 aa1603e0 f90007e8 > >>>> [ 0.282315] 3d70 94536017 f94007e8 17ffffe2 a9bf7bfd 910003fd d0= 00d100 913ee400 94533cc7 > >>>> [ 0.282322] 3d90 d4210000 14000000 b0013788 2a1f03e0 f901c51f d6= 5f03c0 f940406b 2a0203e8 > >>>> [ 0.282329] 3db0 2a0103e9 aa0003ea b400008b f9000145 f94000cb b4= 0001ab a9bf7bfd 910003fd > >>>> [ 0.282330] > >>>> [ 0.282330] LR: 0xffffff93b3f03d50: > >>>> [ 0.282336] 3d50 b9001ac8 f94002c8 370ffec8 17ffffbe d4210000 14= 000000 aa1603e0 f90007e8 > >>>> [ 0.282343] 3d70 94536017 f94007e8 17ffffe2 a9bf7bfd 910003fd d0= 00d100 913ee400 94533cc7 > >>>> [ 0.282350] 3d90 d4210000 14000000 b0013788 2a1f03e0 f901c51f d6= 5f03c0 f940406b 2a0203e8 > >>>> [ 0.282357] 3db0 2a0103e9 aa0003ea b400008b f9000145 f94000cb b4= 0001ab a9bf7bfd 910003fd > >>>> [ 0.282358] > >>>> [ 0.282358] SP: 0xfffffffbb30cfbf0: > >>>> [ 0.282365] fbf0 b3f03d90 ffffff93 b30cfc30 fffffffb b3f03d90 ff= ffff93 60c00085 00000000 > >>>> [ 0.282372] fc10 b6415000 ffffff93 b642fa00 ffffff93 ffffffff ff= ffffff b3f03d90 ffffff93 > >>>> [ 0.282378] fc30 b30cfc70 fffffffb b3d458c0 ffffff93 00000080 00= 000000 00000001 00000000 > >>>> [ 0.282385] fc50 b65c4000 ffffff93 b64420f0 ffffff93 8180e3e0 00= 000000 00000002 00000000 > >>>> [ 0.282387] Process migration/2 (pid: 25, stack limit =3D 0xfffff= ffbb30cc000) > >>>> [ 0.282389] Call trace: > >>>> [ 0.282391] Exception stack(0xfffffffbb30cfb00 to 0xfffffffbb30cf= c30) > >>>> [ 0.282395] fb00: 000000000000000c 0000000000000000 0000000000000= 000 000000003a657275 > >>>> [ 0.282397] fb20: 0000000000000000 0000000000000000 fffffffbbac75= b60 0000000000000000 > >>>> [ 0.282400] fb40: 260822e8751d5000 260822e8751d5000 0000000001440= 144 0000000000000000 > >>>> [ 0.282403] fb60: 0000000000000000 0000000000000004 0000000000000= 00c ffffff93b65ec000 > >>>> [ 0.282405] fb80: 0000000000000000 00000000000fd054 0000000000000= 02c 0000000000000000 > >>>> [ 0.282408] fba0: 000000008180e3e0 9d12f8172cb2f296 ffffff93b65c4= 000 ffffff93b65c1000 > >>>> [ 0.282411] fbc0: ffffff93b6419000 ffffff93b5ce6000 ffffff93b5ce6= 000 00000013b65c1000 > >>>> [ 0.282413] fbe0: ffffff93b6415000 fffffffbb30cfc30 ffffff93b3f03= d90 fffffffbb30cfc30 > >>>> [ 0.282416] fc00: ffffff93b3f03d90 0000000060c00085 ffffff93b6415= 000 ffffff93b642fa00 > >>>> [ 0.282418] fc20: ffffffffffffffff ffffff93b3f03d90 > >>>> [ 0.282421] [] __cfi_check_fail+0x14/0x1c > >>>> [ 0.282430] [] name_to_dev_t+0x0/0x47c > >>>> [ 0.282436] [] kpti_install_ng_mappings+0x178/0= x2e0 > >>>> [ 0.282443] [] multi_cpu_stop+0x114/0x170 > >>>> [ 0.282445] [] cpu_stopper_thread+0x128/0x2e8 > >>>> [ 0.282452] [] smpboot_thread_fn+0x230/0x558 > >>>> [ 0.282455] [] kthread+0x21c/0x238 > >>>> [ 0.282459] [] ret_from_fork+0x10/0x20 > >>>> [ 0.282464] Code: 910003fd d000d100 913ee400 94533cc7 (d4210000) = =20 > >>>=20 > >>> Oh fun :( > >>>=20 > >>> Dragging in a bunch more people to the cc: and to: lines to have them > >>> look at this... > >>>=20 > >>> thanks, > >>>=20 > >>> greg k-h =20