Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp5065250imm; Sun, 26 Aug 2018 09:54:54 -0700 (PDT) X-Google-Smtp-Source: ANB0Vdbanp1UfrQn3YW/DWzODXwtEAjJ9pHLrq1XrR4EcaDOQevPKwOHoixnvsk4tKBHuq27htwo X-Received: by 2002:a63:2b58:: with SMTP id r85-v6mr9333512pgr.406.1535302494420; Sun, 26 Aug 2018 09:54:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1535302494; cv=none; d=google.com; s=arc-20160816; b=DPkv1SJB+YD24vnRoCjTQMtkeDkRnNUFrtUo7Pn+asxeO/a8yJL5NaABmk0EHb4Pxh sHX6QiVDngazKbjNT7nb5HysadjdY0U+/zvHG+pdNYWhcvaQQ6UvUEMMWzFqDk3AVTJn eQP7nN2r9ooJVCWF3HkZZrl0Bt6PUaLoLqPZxakK5DDEKV3uXyBH9ddD5SwaAdfQV22n cNU0DC53peNUOzgPgZV9uRirb0tnDALa1liq+qVd+aK1oVNNxvV/RpIQhV/wiAid5Fw3 a2kDQjP8yEgwz8N9flnRZ7LN6laMuwakwH7Gac2g1rdAmlVSMOzZjUCLKSZRWXYCm2I7 Qz8Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:references:in-reply-to:date :cc:to:from:subject:message-id:arc-authentication-results; bh=8epdqQzOD761gV7sqDbaat4MLoGuOkCoWCHUCGm35LA=; b=XkkiE1/Nnv9eBkkJJ6+tBVnm9XhXxwH6TO4XvX7ICy8hYmhmvCglOQDNYb3lc37aQ/ 70zy7YeKjlGK6z/XEdGzhyirPHTOKwTknbEJ2ja0W6qahnq3z8/OnsK7oEtbS5kEsBUU LNHzjLX7fZ9IBHelUkbTLa0A2OAg1hFdyc17/pZk5iPlXSggDvScXIVkUl4nOKA1MJl3 jc9niWedDLR/53xKRaM64UZhp8kBmt/6mXmO2UkSCQDDWlGKTxWXGzWxWzfTNKuT0TA6 jBhr2fDv4yj19zfWWSbaolPDRXYeWGTezanNUbunJHt3/+b4h2xxLf1ZMHskmvn0VCxS VAjA== ARC-Authentication-Results: i=1; mx.google.com; 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 s13-v6si14010193pfs.330.2018.08.26.09.54.39; Sun, 26 Aug 2018 09:54:54 -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; 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 S1726873AbeHZUgk (ORCPT + 99 others); Sun, 26 Aug 2018 16:36:40 -0400 Received: from shelob.surriel.com ([96.67.55.147]:43992 "EHLO shelob.surriel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726643AbeHZUgk (ORCPT ); Sun, 26 Aug 2018 16:36:40 -0400 Received: from imladris.surriel.com ([96.67.55.152]) by shelob.surriel.com with esmtpsa (TLSv1.2:ECDHE-RSA-AES256-GCM-SHA384:256) (Exim 4.90_1) (envelope-from ) id 1ftyI6-0002Ve-35; Sun, 26 Aug 2018 12:53:30 -0400 Message-ID: <3983fcb4c663e8dc05f13cac32ff56ec15c3dac1.camel@surriel.com> Subject: Re: [PATCH v2 01/17] asm: simd context helper API From: Rik van Riel To: Andy Lutomirski , Thomas Gleixner Cc: "Jason A. Donenfeld" , LKML , Netdev , David Miller , Andrew Lutomirski , Greg Kroah-Hartman , Samuel Neves , linux-arch@vger.kernel.org Date: Sun, 26 Aug 2018 12:53:29 -0400 In-Reply-To: <2532E417-DDD2-4E2C-9F21-3B8D9B96370D@amacapital.net> References: <20180824213849.23647-1-Jason@zx2c4.com> <20180824213849.23647-2-Jason@zx2c4.com> <2532E417-DDD2-4E2C-9F21-3B8D9B96370D@amacapital.net> Content-Type: multipart/signed; micalg="pgp-sha256"; protocol="application/pgp-signature"; boundary="=-4L9haMCxh2AgKTDDi3f4" X-Mailer: Evolution 3.28.5 (3.28.5-1.fc28) Mime-Version: 1.0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org --=-4L9haMCxh2AgKTDDi3f4 Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable On Sun, 2018-08-26 at 07:18 -0700, Andy Lutomirski wrote: > > On Aug 26, 2018, at 7:06 AM, Thomas Gleixner > > wrote: > >=20 > > Jason, > >=20 > > > On Sun, 26 Aug 2018, Jason A. Donenfeld wrote: > > > > On Sun, Aug 26, 2018 at 6:10 AM Thomas Gleixner < > > > > tglx@linutronix.de> wrote: > > > > I'm not too fond of this simply because it requires that > > > > relax() step in > > > > all code pathes. I'd rather make that completely transparent by > > > > just > > > > marking the task as FPU using and let the context switch code > > > > deal with it > > > > in case that it gets preempted. I'll let one of my engineers > > > > look into > > > > that next week. > > >=20 > > > Do you mean to say you intend to make kernel_fpu_end() and > > > kernel_neon_end() only actually do something upon context switch, > > > but > > > not when it's actually called? So that multiple calls to > > > kernel_fpu_begin() and kernel_neon_begin() can be made without > > > penalty? > >=20 > > On context switch and exit to user. That allows to keep those code > > pathes > > fully preemptible. Still twisting my brain around the details. >=20 > I think you=E2=80=99ll have to treat exit to user and context switch as > different things. For exit to user, we want to restore the *user* > state, but, for context switch, we=E2=80=99ll need to restore *kernel* st= ate. For non-preemptible kernel_fpu_begin/end (which seems like a good starting point since since it gets the code halfway to where Thomas would like it to go), the rules would be a little simpler: - For exit to userspace, restore the user FPU state. - At kernel_fpu_begin(), save the user FPU state (if still loaded). - At context switch time, save the user FPU state (if still loaded). > Do user first as its own patch set. It=E2=80=99ll be less painful that wa= y. >=20 > And someone needs to rework PKRU for this to make sense. See previous > threads. I sent Thomas the patches I worked on in the past. That series is likely incomplete, but should be a reasonable starting point. --=20 All Rights Reversed. --=-4L9haMCxh2AgKTDDi3f4 Content-Type: application/pgp-signature; name="signature.asc" Content-Description: This is a digitally signed message part Content-Transfer-Encoding: 7bit -----BEGIN PGP SIGNATURE----- iQEzBAABCAAdFiEEKR73pCCtJ5Xj3yADznnekoTE3oMFAluC2wkACgkQznnekoTE 3oMupAgAoVxpSsYCJN2MhLQcQl3qjjHMMA+97fqkh1tEuTyhgmRONEm+6JXGfv8+ 7lkwhKcr5zruvj1PcC/W+XJK6KD5Ev/4W2/+dcv0vH2zbbB4qSPXxmQni//eQhC9 Pw5eNJO80UrifFayRm9axhF+sZZrgU4TFoUckRM55F3Jj62x7TqQHkvHKeMBfDSl MQ86ytVZsnTvqmREoXqwjBnANtMeV/2nao5ZQiUpuXPjt1BKSBvgZfQBXUTs0fAp VL7/GBKToQwrVIqzvL733a/1590Pmt86wxUN7ZLQee2b9gpF7NxenK8IcVNq1Wxc Ah2B+zCFVS4VzWKCVdshWyePIyGxdA== =4lZP -----END PGP SIGNATURE----- --=-4L9haMCxh2AgKTDDi3f4--