Received: by 10.223.176.46 with SMTP id f43csp2673057wra; Mon, 22 Jan 2018 01:19:31 -0800 (PST) X-Google-Smtp-Source: AH8x224Zb+FA66G1f+VYnrlohs2PZHUG+A8+nC2+8RRnqN69OF7AaEXRk+l7oDO6GE9sEd1rTIte X-Received: by 10.99.107.73 with SMTP id g70mr6873116pgc.281.1516612771796; Mon, 22 Jan 2018 01:19:31 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1516612771; cv=none; d=google.com; s=arc-20160816; b=gasiZPBh4jK652TRKRbNmKUvcAuiVjqUAJHPh6h45ET+Z9riz0QeSU4OuB5PPLBbiZ hPJP2JlJjnNRTh0IkHve4jutN/qP8NTVF5zR2L/DbrzXf5lyJ20yqeen8mxDFWQ+Q/bt lQsP38RLS1bB9fW9LHTGijOM6cY5G73u38TCAx3elJP46M+IcVDew7fralGvc+Pcqy01 HsUgU9RtM7omV40RZLc0aDBXKevvkOB4Gx9yP0o8doAyscgViEBiu0OCihoOFQe8SWZw YIof2nzFnAQIjugW98WodAwAMC/5bLIY9e6c1u5xR1YOMG8RDJqMl13FXBuTPcwdJfyK GOyA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :in-reply-to:message-id:date:subject:cc:to:from :arc-authentication-results; bh=yK1WgIXqmAcVi73tT8UcgNgR0ORME3Elnaw/9dnX0fI=; b=NL18Za/SO7Y+DeSICBPcQl91/HNgl3YGPaI5TQypnULHM5/4Gr25ZyH1SVFRzG/OkW F9l8yrHKLfB7iAz6XBup6sc9++0hQ7lwHZrhm2oDLYguTBh6Mb8i0mlkddBhKx6tb51V MCrhJvRYClMMYafJCEwfNxNg3zxeUhAy/rZ3TFvyt321tmyMV8xCaTGvdss/jvwOG+Re UR2w50+Hkj3+9CXd+qlQOQEsPgRoN3VqCTdtK2oiRH7axXpYK4W3+G+gwWh4k9Nx6Ef5 zHp6ZWDR3a/BGrjeKtFux9fMiN42p757UVpIovB6IfNHMc/DUhipyWpFlQIjUusW2o1E AwWg== 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 i188si13497092pgc.177.2018.01.22.01.19.17; Mon, 22 Jan 2018 01:19:31 -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; 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 S1752675AbeAVIuk (ORCPT + 99 others); Mon, 22 Jan 2018 03:50:40 -0500 Received: from mail.linuxfoundation.org ([140.211.169.12]:33004 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751359AbeAVIuh (ORCPT ); Mon, 22 Jan 2018 03:50:37 -0500 Received: from localhost (LFbn-1-12258-90.w90-92.abo.wanadoo.fr [90.92.71.90]) by mail.linuxfoundation.org (Postfix) with ESMTPSA id A183AE5C; Mon, 22 Jan 2018 08:50:36 +0000 (UTC) From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Michael Neuling , Michael Ellerman Subject: [PATCH 4.14 14/89] powerpc/pseries: Query hypervisor for RFI flush settings Date: Mon, 22 Jan 2018 09:44:54 +0100 Message-Id: <20180122083956.108886736@linuxfoundation.org> X-Mailer: git-send-email 2.16.0 In-Reply-To: <20180122083954.683903493@linuxfoundation.org> References: <20180122083954.683903493@linuxfoundation.org> User-Agent: quilt/0.65 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.14-stable review patch. If anyone has any objections, please let me know. ------------------ From: Michael Neuling commit 8989d56878a7735dfdb234707a2fee6faf631085 upstream. A new hypervisor call is available which tells the guest settings related to the RFI flush. Use it to query the appropriate flush instruction(s), and whether the flush is required. Signed-off-by: Michael Neuling Signed-off-by: Michael Ellerman Signed-off-by: Greg Kroah-Hartman --- arch/powerpc/platforms/pseries/setup.c | 35 +++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) --- a/arch/powerpc/platforms/pseries/setup.c +++ b/arch/powerpc/platforms/pseries/setup.c @@ -459,6 +459,39 @@ static void __init find_and_init_phbs(vo of_pci_check_probe_only(); } +static void pseries_setup_rfi_flush(void) +{ + struct h_cpu_char_result result; + enum l1d_flush_type types; + bool enable; + long rc; + + /* Enable by default */ + enable = true; + + rc = plpar_get_cpu_characteristics(&result); + if (rc == H_SUCCESS) { + types = L1D_FLUSH_NONE; + + if (result.character & H_CPU_CHAR_L1D_FLUSH_TRIG2) + types |= L1D_FLUSH_MTTRIG; + if (result.character & H_CPU_CHAR_L1D_FLUSH_ORI30) + types |= L1D_FLUSH_ORI; + + /* Use fallback if nothing set in hcall */ + if (types == L1D_FLUSH_NONE) + types = L1D_FLUSH_FALLBACK; + + if (!(result.behaviour & H_CPU_BEHAV_L1D_FLUSH_PR)) + enable = false; + } else { + /* Default to fallback if case hcall is not available */ + types = L1D_FLUSH_FALLBACK; + } + + setup_rfi_flush(types, enable); +} + static void __init pSeries_setup_arch(void) { set_arch_panic_timeout(10, ARCH_PANIC_TIMEOUT); @@ -476,6 +509,8 @@ static void __init pSeries_setup_arch(vo fwnmi_init(); + pseries_setup_rfi_flush(); + /* By default, only probe PCI (can be overridden by rtas_pci) */ pci_add_flags(PCI_PROBE_ONLY);