From patchwork Mon Nov 6 17:09:56 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Loic Pallardy X-Patchwork-Id: 118073 Delivered-To: patch@linaro.org Received: by 10.140.22.164 with SMTP id 33csp2993621qgn; Mon, 6 Nov 2017 09:10:41 -0800 (PST) X-Google-Smtp-Source: ABhQp+TaClIUW7UkqaxCq5DvHQHGWHEaio2ZMs1orva/RAs9apnmT9IQXtQxGIWTWg4ziWI1m44c X-Received: by 10.159.194.6 with SMTP id x6mr15421427pln.359.1509988241124; Mon, 06 Nov 2017 09:10:41 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1509988241; cv=none; d=google.com; s=arc-20160816; b=CnoMXTLbapPzgsedi4JxVbw4EGPT7pOu9ioaU7Flfh3wv4NTcLwAdtG3hdvcQ6RZCN AY7Mhs9aCo59dIHqdE5G0lPcQ531khEoGsa2aFjwGX70YIA8h4t6ZbFdHYXfK/xw/SM7 SUVRbGAzd/HDVivKtbTTFgk2ulRJxmBLiIz2ySe5pvqGfZ6qMMd3f150lGY0HPc4RAV3 b2jKqRI+81jjDXsQyUiiLwTxpKDRvgb+50Pn0vuzkSbhurbCAOLyZy8hZSP9AIvsIP/v MzGbxIXaOxkpVRzn3o8G8jRFVItywbLHUAoBneUW/Nr+YmJvAD9PZk0xa34DiAKr+7Fg 3jBA== 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 :message-id:date:subject:cc:to:from:arc-authentication-results; bh=Dt7JBbbJf48N0VC72j3qj8liQsdhzDqlI9/H5udp72c=; b=FybJ3QaM/Mlx5ONXci07Q22N0yvOsNdlRmpD5TVGW2yTy6AOw7gxpgccKUKL91POXX mcYCbwuOWXvINPb8lCmDmw1rD4xZHApARII4crqA4OuP6vKwNeN5OeBvgWu078PRQtKM DKrN3UbA/zMdo2YpxFEYBQ8K5aduwWgdPPjwK7PBtyILrzFdIDjHOwTVVinCMIomur6t swFaBJUmMYco8MdXhS+mnxWg46E1VrdzfvHem6GXgcyQUUBKpxi4HYFK/3je6H8Mccpc pxHI52UVUwd47K26CPRWYCNMlddoGHCJm3Q4jFGPMTknR1xh10sRNUpGk4ifmi4SZ08V ercw== 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 n1si11833832pgt.498.2017.11.06.09.10.40; Mon, 06 Nov 2017 09:10:41 -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 S1753759AbdKFRKY (ORCPT + 26 others); Mon, 6 Nov 2017 12:10:24 -0500 Received: from mx08-00178001.pphosted.com ([91.207.212.93]:17769 "EHLO mx07-00178001.pphosted.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1752419AbdKFRKJ (ORCPT ); Mon, 6 Nov 2017 12:10:09 -0500 Received: from pps.filterd (m0046660.ppops.net [127.0.0.1]) by mx08-.pphosted.com (8.16.0.21/8.16.0.21) with SMTP id vA6H9WDa031167; Mon, 6 Nov 2017 18:10:06 +0100 Received: from beta.dmz-eu.st.com (beta.dmz-eu.st.com [164.129.1.35]) by mx08-00178001.pphosted.com with ESMTP id 2e13j8v3r2-1 (version=TLSv1 cipher=ECDHE-RSA-AES256-SHA bits=256 verify=NOT); Mon, 06 Nov 2017 18:10:06 +0100 Received: from zeta.dmz-eu.st.com (zeta.dmz-eu.st.com [164.129.230.9]) by beta.dmz-eu.st.com (STMicroelectronics) with ESMTP id DFC3534; Mon, 6 Nov 2017 17:10:05 +0000 (GMT) Received: from Webmail-eu.st.com (sfhdag7node2.st.com [10.75.127.20]) by zeta.dmz-eu.st.com (STMicroelectronics) with ESMTP id BC7CE28D1; Mon, 6 Nov 2017 17:10:05 +0000 (GMT) Received: from localhost (10.75.127.46) by SFHDAG7NODE2.st.com (10.75.127.20) with Microsoft SMTP Server (TLS) id 15.0.1347.2; Mon, 6 Nov 2017 18:10:05 +0100 From: Loic Pallardy To: , CC: , , , , Loic Pallardy Subject: [PATCH v2 2/2] remoteproc: debug: add carveouts list dump feature Date: Mon, 6 Nov 2017 18:09:56 +0100 Message-ID: <1509988196-24377-3-git-send-email-loic.pallardy@st.com> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1509988196-24377-1-git-send-email-loic.pallardy@st.com> References: <1509988196-24377-1-git-send-email-loic.pallardy@st.com> MIME-Version: 1.0 X-Originating-IP: [10.75.127.46] X-ClientProxiedBy: SFHDAG2NODE2.st.com (10.75.127.5) To SFHDAG7NODE2.st.com (10.75.127.20) X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10432:, , definitions=2017-11-06_06:, , signatures=0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patch offers the capability to dump memory carveouts associated to one remoteprocessor. Signed-off-by: Loic Pallardy --- V2 : - Fix 0-DAY reported issues on open function prototype drivers/remoteproc/remoteproc_debugfs.c | 31 +++++++++++++++++++++++++++++++ 1 file changed, 31 insertions(+) -- 1.9.1 diff --git a/drivers/remoteproc/remoteproc_debugfs.c b/drivers/remoteproc/remoteproc_debugfs.c index dc5e259..a204883 100644 --- a/drivers/remoteproc/remoteproc_debugfs.c +++ b/drivers/remoteproc/remoteproc_debugfs.c @@ -252,6 +252,35 @@ static int rproc_rsc_table_open(struct inode *inode, struct file *file) .release = single_release, }; +/* Expose carveout content via debugfs */ +static int rproc_carveouts_show(struct seq_file *seq, void *p) +{ + struct rproc *rproc = seq->private; + struct rproc_mem_entry *carveout; + + list_for_each_entry(carveout, &rproc->carveouts, node) { + seq_puts(seq, "Carveout memory entry:\n"); + seq_printf(seq, "\tVirtual address: %p\n", carveout->va); + seq_printf(seq, "\tDMA address: %pad\n", &carveout->dma); + seq_printf(seq, "\tDevice address: 0x%x\n", carveout->da); + seq_printf(seq, "\tLength: 0x%x Bytes\n\n", carveout->len); + } + + return 0; +} + +static int rproc_carveouts_open(struct inode *inode, struct file *file) +{ + return single_open(file, rproc_carveouts_show, inode->i_private); +} + +static const struct file_operations rproc_carveouts_ops = { + .open = rproc_carveouts_open, + .read = seq_read, + .llseek = seq_lseek, + .release = single_release, +}; + void rproc_remove_trace_file(struct dentry *tfile) { debugfs_remove(tfile); @@ -297,6 +326,8 @@ void rproc_create_debug_dir(struct rproc *rproc) rproc, &rproc_recovery_ops); debugfs_create_file("resource_table", 0400, rproc->dbg_dir, rproc, &rproc_rsc_table_ops); + debugfs_create_file("carveout_memories", 0400, rproc->dbg_dir, + rproc, &rproc_carveouts_ops); } void __init rproc_init_debugfs(void)