From patchwork Mon Dec 14 20:53:05 2015 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Linus Walleij X-Patchwork-Id: 58369 Delivered-To: patch@linaro.org Received: by 10.202.179.86 with SMTP id c83csp1321443oif; Mon, 14 Dec 2015 12:53:14 -0800 (PST) X-Received: by 10.67.22.137 with SMTP id hs9mr48921207pad.66.1450126394588; Mon, 14 Dec 2015 12:53:14 -0800 (PST) Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id kr7si11049226pab.120.2015.12.14.12.53.14; Mon, 14 Dec 2015 12:53:14 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of devicetree-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 devicetree-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=devicetree-owner@vger.kernel.org; dkim=neutral (body hash did not verify) header.i=@linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753559AbbLNUxN (ORCPT + 6 others); Mon, 14 Dec 2015 15:53:13 -0500 Received: from mail-lf0-f45.google.com ([209.85.215.45]:35717 "EHLO mail-lf0-f45.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753508AbbLNUxM (ORCPT ); Mon, 14 Dec 2015 15:53:12 -0500 Received: by lfdl133 with SMTP id l133so129039931lfd.2 for ; Mon, 14 Dec 2015 12:53:10 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id; bh=loanrBCAfyqKRB1487NYCaHReEyqM9mZXiYv+99wQWk=; b=Q0Z9m/vyPnyoIZudH7RyLo48AqDWc/xatH+JOi3mxiljd0c2pcw7yNAHPTQBORkPhw lDESs9OuaL8LckNEE5+ZI8osrM9dySp38O92n25lyxE7nE4B3skNzMzG1NilRc1kfTYx kgJggcEPbl/YCCW05WRNzd6LuQ2ciIh2CXueY= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20130820; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=loanrBCAfyqKRB1487NYCaHReEyqM9mZXiYv+99wQWk=; b=HxfgMp7RQ7cU2wKUN7fD8b2SDMrxm8iePcPfLzvYcmzQYrFihgmyPN8W6ae/nqtw6Y FE+AKkuVA1+FYrMzRXaJnNzR9AbPumMaOpHKCzpxpKYCCWR8ricXLulW7XZf9PPgkdYs EIfj4UwH6AJ2sRgL8XhyEn+yZ/NMiVF2zyxk4qnsoK/tHr+oojq18pihhgc57G1+SS70 NyGVMp8ugt1cNpT6Jtb2yW+y9OP6Q2a28vsYEWdVRC96kWGXze6sBfw3p4mdnDEMjMzX Oi0uAeMMKKcekR4MdlMxNinZY3OWyh/MvOu526Yw28891U1WHCClSZdhb3ILy3EopNIN yyYQ== X-Gm-Message-State: ALoCoQla+m929ZCoY55mMUFTui4SfsxfCwZ9EEh0OVZe7oTgHKTzNvyimujLhfKecjcTF14ZaJl8ye72ObSkRZg1QXZ6ffzfoQ== X-Received: by 10.25.211.10 with SMTP id k10mr8777395lfg.114.1450126390616; Mon, 14 Dec 2015 12:53:10 -0800 (PST) Received: from localhost.localdomain.localdomain (c-297471d5.01-192-6c756e10.cust.bredbandsbolaget.se. [213.113.116.41]) by smtp.gmail.com with ESMTPSA id qb3sm3172384lbb.39.2015.12.14.12.53.09 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 14 Dec 2015 12:53:09 -0800 (PST) From: Linus Walleij To: linux-arm-kernel@lists.infradead.org Cc: Linus Walleij , Russell King , Arnd Bergmann , devicetree@vger.kernel.org Subject: [PATCH 1/2 v2] ARM: l2x0: make it possible to disable outer sync from DT Date: Mon, 14 Dec 2015 21:53:05 +0100 Message-Id: <1450126385-14517-1-git-send-email-linus.walleij@linaro.org> X-Mailer: git-send-email 2.4.3 Sender: devicetree-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: devicetree@vger.kernel.org According to commit 2503a5ecd86c002506001eba432c524ea009fe7f "ARM: 6201/1: RealView: Do not use outer_sync() on ARM11MPCore boards with L220" Some PB11MPCore RealView core tiles have broken outer_sync. We got rid of the custom barriers from the machine by disabling outer sync, but that was just for the boardfile case. We have to be able to do the same in the device tree case. Since __l2c_init() is cloning and copying the L2C vtable, we pass an argument to this function to optionally numb the outer sync operation if desired, before initializing the cache. After this we can set up the cache correctly on the RealView PB11MPCore. This was tested on a PB11MPCore known to have the issue. Before this, spurious crashes would occur if we try to set up the cache properly, after this it boots rock solid. Cc: Russell King Cc: Arnd Bergmann Cc: devicetree@vger.kernel.org Signed-off-by: Linus Walleij --- ChangeLog v2->v3: - Update description, reference Catalins initial commit in the commit blurb. --- Documentation/devicetree/bindings/arm/l2cc.txt | 3 +++ arch/arm/mm/cache-l2x0.c | 13 ++++++++++--- 2 files changed, 13 insertions(+), 3 deletions(-) -- 2.4.3 -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Acked-by: Rob Herring diff --git a/Documentation/devicetree/bindings/arm/l2cc.txt b/Documentation/devicetree/bindings/arm/l2cc.txt index d181b7c4c522..416864e9dc92 100644 --- a/Documentation/devicetree/bindings/arm/l2cc.txt +++ b/Documentation/devicetree/bindings/arm/l2cc.txt @@ -75,6 +75,9 @@ Optional properties: specified to indicate that such transforms are precluded. - arm,parity-enable : enable parity checking on the L2 cache (L220 or PL310). - arm,parity-disable : disable parity checking on the L2 cache (L220 or PL310). +- arm,outer-sync-disable : disable the outer sync operation on the L2 cache. + Some core tiles, especially ARM PB11MPCore have a faulty L220 cache that + will randomly hang unless outer sync operations are disabled. - prefetch-data : Data prefetch. Value: <0> (forcibly disable), <1> (forcibly enable), property absent (retain settings set by firmware) - prefetch-instr : Instruction prefetch. Value: <0> (forcibly disable), diff --git a/arch/arm/mm/cache-l2x0.c b/arch/arm/mm/cache-l2x0.c index 3f3008e5c662..9f9d54271aad 100644 --- a/arch/arm/mm/cache-l2x0.c +++ b/arch/arm/mm/cache-l2x0.c @@ -790,7 +790,7 @@ static const struct l2c_init_data l2c310_init_fns __initconst = { }; static int __init __l2c_init(const struct l2c_init_data *data, - u32 aux_val, u32 aux_mask, u32 cache_id) + u32 aux_val, u32 aux_mask, u32 cache_id, bool nosync) { struct outer_cache_fns fns; unsigned way_size_bits, ways; @@ -866,6 +866,10 @@ static int __init __l2c_init(const struct l2c_init_data *data, fns.configure = outer_cache.configure; if (data->fixup) data->fixup(l2x0_base, cache_id, &fns); + if (nosync) { + pr_info("L2C: disabling outer sync\n"); + fns.sync = NULL; + } /* * Check if l2x0 controller is already enabled. If we are booting @@ -925,7 +929,7 @@ void __init l2x0_init(void __iomem *base, u32 aux_val, u32 aux_mask) if (data->save) data->save(l2x0_base); - __l2c_init(data, aux_val, aux_mask, cache_id); + __l2c_init(data, aux_val, aux_mask, cache_id, false); } #ifdef CONFIG_OF @@ -1724,6 +1728,7 @@ int __init l2x0_of_init(u32 aux_val, u32 aux_mask) struct resource res; u32 cache_id, old_aux; u32 cache_level = 2; + bool nosync = false; np = of_find_matching_node(NULL, l2x0_ids); if (!np) @@ -1762,6 +1767,8 @@ int __init l2x0_of_init(u32 aux_val, u32 aux_mask) if (cache_level != 2) pr_err("L2C: device tree specifies invalid cache level\n"); + nosync = of_property_read_bool(np, "arm,outer-sync-disable"); + /* Read back current (default) hardware configuration */ if (data->save) data->save(l2x0_base); @@ -1776,6 +1783,6 @@ int __init l2x0_of_init(u32 aux_val, u32 aux_mask) else cache_id = readl_relaxed(l2x0_base + L2X0_CACHE_ID); - return __l2c_init(data, aux_val, aux_mask, cache_id); + return __l2c_init(data, aux_val, aux_mask, cache_id, nosync); } #endif