From patchwork Wed Oct 29 09:22:55 2014 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Marek Szyprowski X-Patchwork-Id: 39727 Return-Path: X-Original-To: linaro@patches.linaro.org Delivered-To: linaro@patches.linaro.org Received: from mail-wg0-f69.google.com (mail-wg0-f69.google.com [74.125.82.69]) by ip-10-151-82-157.ec2.internal (Postfix) with ESMTPS id 50B9124046 for ; Wed, 29 Oct 2014 09:23:52 +0000 (UTC) Received: by mail-wg0-f69.google.com with SMTP id m15sf1415506wgh.8 for ; Wed, 29 Oct 2014 02:23:51 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20130820; h=x-gm-message-state:mime-version:delivered-to:from:to:cc:subject :date:message-id:in-reply-to:references:sender:precedence:list-id :x-original-sender:x-original-authentication-results:mailing-list :list-post:list-help:list-archive:list-unsubscribe; bh=PARImfbc0GC5jL04gF9MGscQlPEAcntfZYkCAIZtsTc=; b=a7SEFkunT0Ibh3qkg6eVtLvZpusQ0aa0ipvqd4b7Rvad+iNFSo+8aQ+MmBZWqyihkC uNUbRb8DT18Ay3C7UOhDMVjnlVLc+jzG4cmwyzGUJcdugSCYKdA83jGRDMTgXY8C+aoB 7h/BfYT1ZOTgq5mCYkFkvrTz5xZKBJHMDnY2cVrPfoqmxLXkI5w7i9dh+C4Cpq8LgfxQ GhKo5GU2FWgkvXU+FCT/yCuE2o850+MFc29vrA/w2HNMyxTMPUGrkE1gRLB1E+EEqr+I cE1cjyVCrspzlQhCDbT6H5haJLR2wETbWdZ08MjcnMKvfCv2B6Di7pr/+7ybk2FoZQUI brcA== X-Gm-Message-State: ALoCoQkKei1oCKdyiaRDEals8KNDwEAE4MBYXy79DuumRMNSEaHu/XTpTBYItFmv8Sp9y+dnp9CI X-Received: by 10.112.166.2 with SMTP id zc2mr1251lbb.24.1414574631472; Wed, 29 Oct 2014 02:23:51 -0700 (PDT) MIME-Version: 1.0 X-BeenThere: patchwork-forward@linaro.org Received: by 10.152.42.225 with SMTP id r1ls163410lal.84.gmail; Wed, 29 Oct 2014 02:23:51 -0700 (PDT) X-Received: by 10.152.27.38 with SMTP id q6mr2332826lag.92.1414574631301; Wed, 29 Oct 2014 02:23:51 -0700 (PDT) Received: from mail-lb0-f172.google.com (mail-lb0-f172.google.com. [209.85.217.172]) by mx.google.com with ESMTPS id rq6si6371435lbb.21.2014.10.29.02.23.51 for (version=TLSv1 cipher=ECDHE-RSA-RC4-SHA bits=128/128); Wed, 29 Oct 2014 02:23:51 -0700 (PDT) Received-SPF: pass (google.com: domain of patch+caf_=patchwork-forward=linaro.org@linaro.org designates 209.85.217.172 as permitted sender) client-ip=209.85.217.172; Received: by mail-lb0-f172.google.com with SMTP id n15so2122498lbi.17 for ; Wed, 29 Oct 2014 02:23:51 -0700 (PDT) X-Received: by 10.152.120.199 with SMTP id le7mr9765123lab.67.1414574631206; Wed, 29 Oct 2014 02:23:51 -0700 (PDT) X-Forwarded-To: patchwork-forward@linaro.org X-Forwarded-For: patch@linaro.org patchwork-forward@linaro.org Delivered-To: patch@linaro.org Received: by 10.112.84.229 with SMTP id c5csp624777lbz; Wed, 29 Oct 2014 02:23:50 -0700 (PDT) X-Received: by 10.70.43.78 with SMTP id u14mr71459pdl.166.1414574628975; Wed, 29 Oct 2014 02:23:48 -0700 (PDT) Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id hn2si3576311pbc.82.2014.10.29.02.23.48 for ; Wed, 29 Oct 2014 02:23:48 -0700 (PDT) Received-SPF: none (google.com: linux-kernel-owner@vger.kernel.org does not designate permitted sender hosts) client-ip=209.132.180.67; Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1756438AbaJ2JXV (ORCPT + 26 others); Wed, 29 Oct 2014 05:23:21 -0400 Received: from mailout4.w1.samsung.com ([210.118.77.14]:46382 "EHLO mailout4.w1.samsung.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755790AbaJ2JXL (ORCPT ); Wed, 29 Oct 2014 05:23:11 -0400 Received: from eucpsbgm1.samsung.com (unknown [203.254.199.244]) by mailout4.w1.samsung.com (Oracle Communications Messaging Server 7u4-24.01(7.0.4.24.0) 64bit (built Nov 17 2011)) with ESMTP id <0NE700D958V7ON60@mailout4.w1.samsung.com>; Wed, 29 Oct 2014 09:25:56 +0000 (GMT) X-AuditID: cbfec7f4-b7f6c6d00000120b-de-5450b1fd6509 Received: from eusync1.samsung.com ( [203.254.199.211]) by eucpsbgm1.samsung.com (EUCPMTA) with SMTP id A6.04.04619.DF1B0545; Wed, 29 Oct 2014 09:23:09 +0000 (GMT) Received: from amdc1339.digital.local ([106.116.147.30]) by eusync1.samsung.com (Oracle Communications Messaging Server 7u4-23.01 (7.0.4.23.0) 64bit (built Aug 10 2011)) with ESMTPA id <0NE700DWE8QECT50@eusync1.samsung.com>; Wed, 29 Oct 2014 09:23:09 +0000 (GMT) From: Marek Szyprowski To: linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-samsung-soc@vger.kernel.org Cc: Marek Szyprowski , Tomasz Figa , Kyungmin Park , Russell King - ARM Linux , Kukjin Kim , lauraa@codeaurora.org, linux-omap@vger.kernel.org, linus.walleij@linaro.org, tony@atomide.com, drake@endlessm.com, loeliger@gmail.com, Mark Rutland Subject: [PATCH v7 2/8] ARM: l2c: Add interface to ask hypervisor to configure L2C Date: Wed, 29 Oct 2014 10:22:55 +0100 Message-id: <1414574581-2320-3-git-send-email-m.szyprowski@samsung.com> X-Mailer: git-send-email 1.9.2 In-reply-to: <1414574581-2320-1-git-send-email-m.szyprowski@samsung.com> References: <1414574581-2320-1-git-send-email-m.szyprowski@samsung.com> X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFtrELMWRmVeSWpSXmKPExsVy+t/xy7p/NwaEGHzcqGfxaP5jZoveBVfZ LM42vWG32N45g91iyp/lTBabHl9jtbi8aw6bxewl/SwWM87vY7K4fZnX4tz2LSwWa4/cZbdY ev0ik8WqXX8YLfZf8XLg91gzbw2jR0tzD5vHt6+TWDwu9/UyeSz6nuWxc9Zddo871/aweWxe Uu/Rt2UVo8fnTXIBXFFcNimpOZllqUX6dglcGd++yxQ85q84tnQ+UwNjH28XIyeHhICJxJym uYwQtpjEhXvr2boYuTiEBJYySky4tJoFJCEk0Mck8eJ5GYjNJmAo0fW2iw3EFhHIlvjxbTIL SAOzQB+zxPnpPcwgCWGBEIllZ5rAbBYBVYn902axgti8Au4SPV+PQW2Tk/j/cgUTiM0p4CGx +sISNohl7hIbD3ezTWDkXcDIsIpRNLU0uaA4KT3XUK84Mbe4NC9dLzk/dxMjJJy/7GBcfMzq EKMAB6MSD6/Gbv8QIdbEsuLK3EOMEhzMSiK8O8wDQoR4UxIrq1KL8uOLSnNSiw8xMnFwSjUw ymQ9klaa9SPS+s2yQ5Gm1eYxp2dd+FMvHb/DuPxV+cMfUhXhdit3Hr9gLs/Y3D3n6VvFrTXC nxkbThtcPh9jfHzJ333lPPu8tFaqn3KLMuSUZRN8ybLth1qcYUmlkaC0iMUMs4tdh88emn5o XonIQ5anDa2KAalT3O5e/KF58Pd/mRb9P7eKlFiKMxINtZiLihMBIkd1xkUCAAA= Sender: linux-kernel-owner@vger.kernel.org Precedence: list List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Removed-Original-Auth: Dkim didn't pass. X-Original-Sender: m.szyprowski@samsung.com X-Original-Authentication-Results: mx.google.com; spf=pass (google.com: domain of patch+caf_=patchwork-forward=linaro.org@linaro.org designates 209.85.217.172 as permitted sender) smtp.mail=patch+caf_=patchwork-forward=linaro.org@linaro.org Mailing-list: list patchwork-forward@linaro.org; contact patchwork-forward+owners@linaro.org X-Google-Group-Id: 836684582541 List-Post: , List-Help: , List-Archive: List-Unsubscribe: , From: Tomasz Figa Because certain secure hypervisor do not allow writes to individual L2C registers, but rather expect set of parameters to be passed as argument to secure monitor calls, there is a need to provide an interface for the L2C driver to ask the firmware to configure the hardware according to specified parameters. This patch adds such. Signed-off-by: Tomasz Figa Signed-off-by: Marek Szyprowski --- arch/arm/include/asm/outercache.h | 3 +++ arch/arm/mm/cache-l2x0.c | 6 ++++++ 2 files changed, 9 insertions(+) diff --git a/arch/arm/include/asm/outercache.h b/arch/arm/include/asm/outercache.h index 891a56b35bcf..563b92fc2f41 100644 --- a/arch/arm/include/asm/outercache.h +++ b/arch/arm/include/asm/outercache.h @@ -23,6 +23,8 @@ #include +struct l2x0_regs; + struct outer_cache_fns { void (*inv_range)(unsigned long, unsigned long); void (*clean_range)(unsigned long, unsigned long); @@ -36,6 +38,7 @@ struct outer_cache_fns { /* This is an ARM L2C thing */ void (*write_sec)(unsigned long, unsigned); + void (*configure)(const struct l2x0_regs *); }; extern struct outer_cache_fns outer_cache; diff --git a/arch/arm/mm/cache-l2x0.c b/arch/arm/mm/cache-l2x0.c index 4286ee9bb3bd..ad981894de73 100644 --- a/arch/arm/mm/cache-l2x0.c +++ b/arch/arm/mm/cache-l2x0.c @@ -110,6 +110,11 @@ static inline void l2c_unlock(void __iomem *base, unsigned num) static void l2c_configure(void __iomem *base) { + if (outer_cache.configure) { + outer_cache.configure(&l2x0_saved_regs); + return; + } + if (l2x0_data->configure) l2x0_data->configure(base); @@ -910,6 +915,7 @@ static int __init __l2c_init(const struct l2c_init_data *data, fns = data->outer_cache; fns.write_sec = outer_cache.write_sec; + fns.configure = outer_cache.configure; if (data->fixup) data->fixup(l2x0_base, cache_id, &fns);