Received: by 10.223.164.202 with SMTP id h10csp450899wrb; Wed, 22 Nov 2017 09:40:37 -0800 (PST) X-Google-Smtp-Source: AGs4zMapW2FuOx3hHiofS5SBln+bC0nsLIQfLoYcs7R5yROXwDOP2zoQ1NzwN9kzkZNpj3/feJwF X-Received: by 10.99.47.134 with SMTP id v128mr21902615pgv.232.1511372437748; Wed, 22 Nov 2017 09:40:37 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1511372437; cv=none; d=google.com; s=arc-20160816; b=FPL0mZD0bpIRvW0meFSxpl5yN5scCL8lE4rxJGlpuiNV5N8U/k6ot8e3yYtR3FWkMs qvJ/EZR7oOj4Swr+TtZ7xzBskBhWyFa0TXksCeM8EFvHlLsFfovtLpy1YXCrtta1x5Sd bincXtsnaDjtWTWMDWOyhIeimCgRntwqXmXrPZsZrU2Fib+dxpRTEF+4s8wSUzCiJ24u F/jKM/6Vx5wPYHOPBvk+R0jwOw1u+SJAjeZU4hgb4bKT3HBeuapqVm6Qm3WqYb/iGbhD HywKc8YIO5ksarygd3sgNbWGAbFjmCH/nv3ht+hONLi0vFzQAE1lRco6btr8rg2E8yK8 ko3w== 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 :message-id:to:from:cc:in-reply-to:subject:date:dkim-signature :arc-authentication-results; bh=d2IEM0qYKTBxie+V230scrIKvp0+yI6P7T0BJ8aO0oU=; b=fLED93wPNJ1JEeyxFmexu68KCz02qTCJmjel1dN/rUgRzfWvFuLwYemkoURhK3gwDc sXyhSjkvKJJ4BmlpQ+fwVBPlKZh4HQkb135XQ6e8WHW4CaiDdx/lamO5k4mXF4+Ecc3O fyjgiGefeCo7mNlu1II4U5fzJcn0/aMlTeR2PeVdnLccErzPCEnCJ4C/+Ih/uCTpL2QV qtHrHe4Qu+cQcC2nH4amDO857Rf+6lLdGqcZPNf16xOL+LueJDlHe/lg53AWFIVXa/A/ aXyjIPevBcSuJD4NUqtKOV1SeggqFXhfkmI9yrbVOo0e012Of9lIlp0wsYejDNvgusDf I+yg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@sifive.com header.s=google header.b=JyyQXnm5; 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 f5si14116412pga.52.2017.11.22.09.40.25; Wed, 22 Nov 2017 09:40:37 -0800 (PST) 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=@sifive.com header.s=google header.b=JyyQXnm5; 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 S1752011AbdKVRiT (ORCPT + 78 others); Wed, 22 Nov 2017 12:38:19 -0500 Received: from mail-pg0-f50.google.com ([74.125.83.50]:33449 "EHLO mail-pg0-f50.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751472AbdKVRiS (ORCPT ); Wed, 22 Nov 2017 12:38:18 -0500 Received: by mail-pg0-f50.google.com with SMTP id s75so12885173pgs.0 for ; Wed, 22 Nov 2017 09:38:17 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=sifive.com; s=google; h=date:subject:in-reply-to:cc:from:to:message-id:mime-version :content-transfer-encoding; bh=d2IEM0qYKTBxie+V230scrIKvp0+yI6P7T0BJ8aO0oU=; b=JyyQXnm5egkdAs3YOZBM2GpeyFIZKi3W/hXujPbKLKgNOcCu2h64OgSg2O3YUkX2Ff 14J81VyBRf5i9spq5SvKJT5JnslftR341nNqh0UQ92ufAuainGPDGkgQJ42OoUEyEzVl gquYDGLR50N9MT3pykblvalRCjQ+jNjfXUMK7TpbP84hvnPy//eUQ8NtyB7SegmHgEYk LLpbQTJxzFBzWwHSZv+ZS6/6LSQHeyQsbu7YpXvJdqiFVCMfdGy23vf0i4XTCa0pC/Ab spNkZ9p1h7x5JkVp2fZDikjgwc9/usNqs2Is4VkRdoLOxoC/Dx8iNFwvMIHX+pF4+QNx nRwQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:subject:in-reply-to:cc:from:to:message-id :mime-version:content-transfer-encoding; bh=d2IEM0qYKTBxie+V230scrIKvp0+yI6P7T0BJ8aO0oU=; b=kmA1w/ddHOYbGSMDBivDzxnaHJ23PYSQ7lJHgvEbmbRYp0W0arilhcwq5ItugD0M29 vlBFRJYqcx7RNCSABF8WzQlROiyBNGOkx1RNT6mXdpz6b2UjLTwUhtI3JAgaasCmOXt4 jJ8ZslcTJ4am2RJCLUfibqM9VS20Kb463mPsptITe4ECnde9lAQ82XYXzkoGuAI6IHrV bqm7pyXIOQoxdxGMRGurglYsB3MZyWE6GxDErkjgHO6R9FY/CQ1UU7+c7pc/99jWHBXE FAhdWgsiV3j7cmir7m6BnSa9nJKsGpK2WiEmiofxI/qvFCnh8ynYwqfwyL4P+ykIT6+3 4fNw== X-Gm-Message-State: AJaThX5RUmGZEDcKE7BOwoJLBqGxivLcJlABpbwXi+1APrfSCM8Xqe4G 2XkFSXwzo2XNptcvAQm24LHfmcSq5ymlQA== X-Received: by 10.99.1.139 with SMTP id 133mr9997928pgb.257.1511372297340; Wed, 22 Nov 2017 09:38:17 -0800 (PST) Received: from localhost ([12.206.222.5]) by smtp.gmail.com with ESMTPSA id p10sm16083922pfl.32.2017.11.22.09.38.16 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 22 Nov 2017 09:38:16 -0800 (PST) Date: Wed, 22 Nov 2017 09:38:16 -0800 (PST) X-Google-Original-Date: Wed, 22 Nov 2017 09:38:02 PST (-0800) Subject: Re: [patches] RE: [PATCH 3/4] RISC-V: Flush I$ when making a dirty page executable In-Reply-To: <9acaf467a587413a9aa1529ab8cc904e@AcuMS.aculab.com> CC: linux-kernel@vger.kernel.org, patches@groups.riscv.org, Andrew Waterman From: Palmer Dabbelt To: David.Laight@ACULAB.COM Message-ID: Mime-Version: 1.0 (MHng) Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, 21 Nov 2017 08:57:07 PST (-0800), David.Laight@ACULAB.COM wrote: > From: Palmer Dabbelt >> Sent: 20 November 2017 18:58 >> >> The RISC-V ISA allows for instruction caches that are not coherent WRT >> stores, even on a single hart. As a result, we need to explicitly flush >> the instruction cache whenever marking a dirty page as executable in >> order to preserve the correct system behavior. > > Isn't the I-flush only needed if there has been an unmap since the > previous I-flush? > Since code is rarely unmapped (exec and driver unload come to mind) > the I-flush won't be needed very often. There's nothing in the RISC-V ISA that prevents the instruction cache from caching read-only (or even unmapped!) pages. Instructions fetched this manner could never commit, but they could fill up the icache with garbage. I believe that means we need to flush on dirty->execute, but if I'm wrong I'm happy to change it. From 1584695578537912495@xxx Tue Nov 21 16:57:52 +0000 2017 X-GM-THRID: 1584612605235196569 X-Gmail-Labels: Inbox,Category Forums,HistoricalUnread