Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp10885726imu; Thu, 6 Dec 2018 08:15:30 -0800 (PST) X-Google-Smtp-Source: AFSGD/V71Qd8A+bqlAQW3XcZpV5d/BqAmsmL9DvSN4s8ZLjJCohU4fX3TNvJVIBlvEIuFzXRGp1D X-Received: by 2002:a17:902:e085:: with SMTP id cb5mr28392210plb.24.1544112930179; Thu, 06 Dec 2018 08:15:30 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1544112930; cv=none; d=google.com; s=arc-20160816; b=Dfk5ANxeuZ8EOqgn8gSy1EHdiqqXSthIy7fj283gqDv7qLYiU/HxZX6A88pzFWXOu2 AV1qaEgN3OUuL6LtgmKVlpVUP2PS2n40L7jxL1qR9m+JDHqXxrnfYRDn7El9ko+6gaK3 w9Icl/8GWS0YT6ftNf51a7PsIuTYtxZlLIo+ipXyQ7yfGp5qYTNyOhvowj2j8s4cImIe 8aKkDcDsMdFBclTaDdxszRf5HwjvjETiqmYY7yf/uehRDq0I6qlV4M0q1o2+MYdeeULs j7McWtDpiV0zGyCgc8wdjrkWNE7E3X4IxjN4o/d+zSeNwGCMiAhSMcUuiVWGWbFtkm2n mzXw== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature; bh=JKpDRoF13vRK0kRuu1xAPyd1lI2nDNemsInl5pztJRs=; b=d3FLScYF++nHo5aFhPvGdFo0RQA8lK5vGdGpwg6YgQpxr1b3+3Zxu82aQGKV47LSTc c0lFupLF18EIis8EVXlQdLLLqllJzH+zLTAAPHQyidBfE+m0bErLjTaXQGwSSbA0PT0p pnch+wA9t2F0PJ0IEWwX9TxY+H4eLeu+cypGOJGL+tyYtLHpWLD3m4jl1DiiqsNZsjSK URPXV6nixheAU1D4l8dJBy14KkCF+9vCaoe1HDbXapaXUQUWil9rSxICdbjjWAERPHq/ GYsNuKUfpFzACsx+N2YNtenzD8Am0Eq6aqac6zEUnUs9Ezh5hxIQ5O6nZ6AJGqjV5lA0 Uw3A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@oracle.com header.s=corp-2018-07-02 header.b=Uly1QzyG; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=oracle.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id u3si575491plb.99.2018.12.06.08.14.41; Thu, 06 Dec 2018 08:15:30 -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=@oracle.com header.s=corp-2018-07-02 header.b=Uly1QzyG; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=oracle.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726050AbeLFQMW (ORCPT + 99 others); Thu, 6 Dec 2018 11:12:22 -0500 Received: from userp2120.oracle.com ([156.151.31.85]:51216 "EHLO userp2120.oracle.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725930AbeLFQMW (ORCPT ); Thu, 6 Dec 2018 11:12:22 -0500 Received: from pps.filterd (userp2120.oracle.com [127.0.0.1]) by userp2120.oracle.com (8.16.0.22/8.16.0.22) with SMTP id wB6GAAIK088066; Thu, 6 Dec 2018 16:12:12 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oracle.com; h=subject : to : cc : references : from : message-id : date : mime-version : in-reply-to : content-type : content-transfer-encoding; s=corp-2018-07-02; bh=JKpDRoF13vRK0kRuu1xAPyd1lI2nDNemsInl5pztJRs=; b=Uly1QzyGOHuZhkaV/ZNgeftJdaTWwfoCqvHk6WyBoTg7nYUqTm1oCGXnbz6uRdR0s5EQ 9NBRndTLSd7WiyrhMYrOdiiN/dNU6uGT4koaQUOf8+0VydoToyHjR3mMQfE1ikWufGAP 8D/2Bta/DNghwED1YSie0PRdrcZG7wx4DkwqfrRmLv3r60cHR0uwj7HHapu7/Y0nwM02 nKrpq96gafOeYv0SO9hPRtEx6Z3mWFNmYA13hxmjRJNI0fNfV+7i18yOMZtJGERmLkfo StOe6GkAIQLzXM6wQD5b+tNlOU9/jVHmNeqvQE0e57J45Zk/9HJLJVx2smXgV78lKgqi BQ== Received: from userv0022.oracle.com (userv0022.oracle.com [156.151.31.74]) by userp2120.oracle.com with ESMTP id 2p3jxrs35n-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Thu, 06 Dec 2018 16:12:12 +0000 Received: from aserv0122.oracle.com (aserv0122.oracle.com [141.146.126.236]) by userv0022.oracle.com (8.14.4/8.14.4) with ESMTP id wB6GC6CG022492 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Thu, 6 Dec 2018 16:12:06 GMT Received: from abhmp0009.oracle.com (abhmp0009.oracle.com [141.146.116.15]) by aserv0122.oracle.com (8.14.4/8.14.4) with ESMTP id wB6GC5w1014292; Thu, 6 Dec 2018 16:12:05 GMT Received: from [10.211.46.123] (/10.211.46.123) by default (Oracle Beehive Gateway v4.0) with ESMTP ; Thu, 06 Dec 2018 08:12:05 -0800 Subject: Re: [PATCH RFC 1/1] swiotlb: add debugfs to track swiotlb buffer usage To: Dongli Zhang , iommu@lists.linux-foundation.org, linux-kernel@vger.kernel.org Cc: konrad.wilk@oracle.com, hch@lst.de, m.szyprowski@samsung.com, robin.murphy@arm.com References: <1544068785-20399-1-git-send-email-dongli.zhang@oracle.com> From: Joe Jin Message-ID: Date: Thu, 6 Dec 2018 08:12:02 -0800 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.13; rv:52.0) Gecko/20100101 Thunderbird/52.9.1 MIME-Version: 1.0 In-Reply-To: <1544068785-20399-1-git-send-email-dongli.zhang@oracle.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit X-Proofpoint-Virus-Version: vendor=nai engine=5900 definitions=9098 signatures=668679 X-Proofpoint-Spam-Details: rule=notspam policy=default score=0 suspectscore=2 malwarescore=0 phishscore=0 bulkscore=0 spamscore=0 mlxscore=0 mlxlogscore=999 adultscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1810050000 definitions=main-1812060138 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Dongli, Maybe move d_swiotlb_usage declare into swiotlb_create_debugfs(): void swiotlb_create_debugfs(void) { #ifdef CONFIG_DEBUG_FS static struct dentry *d_swiotlb_usage = NULL; if (d_swiotlb_usage) return; d_swiotlb_usage = debugfs_create_dir("swiotlb", NULL); if (!d_swiotlb_usage) return; debugfs_create_file("usage", 0600, d_swiotlb_usage, NULL, &swiotlb_usage_fops); #endif } And for io_tlb_used, possible add a check at the begin of swiotlb_tbl_map_single(), if there were not any free slots or not enough slots, return fail directly? Thanks, Joe On 12/5/18 7:59 PM, Dongli Zhang wrote: > The device driver will not be able to do dma operations once swiotlb buffer > is full, either because the driver is using so many IO TLB blocks inflight, > or because there is memory leak issue in device driver. To export the > swiotlb buffer usage via debugfs would help the user estimate the size of > swiotlb buffer to pre-allocate or analyze device driver memory leak issue. > > As the swiotlb can be initialized at very early stage when debugfs cannot > register successfully, this patch creates the debugfs entry on demand. > > Signed-off-by: Dongli Zhang > --- > kernel/dma/swiotlb.c | 57 ++++++++++++++++++++++++++++++++++++++++++++++++++++ > 1 file changed, 57 insertions(+) > > diff --git a/kernel/dma/swiotlb.c b/kernel/dma/swiotlb.c > index 045930e..d3c8aa4 100644 > --- a/kernel/dma/swiotlb.c > +++ b/kernel/dma/swiotlb.c > @@ -35,6 +35,9 @@ > #include > #include > #include > +#ifdef CONFIG_DEBUG_FS > +#include > +#endif > > #include > #include > @@ -73,6 +76,13 @@ static phys_addr_t io_tlb_start, io_tlb_end; > */ > static unsigned long io_tlb_nslabs; > > +#ifdef CONFIG_DEBUG_FS > +/* > + * The number of used IO TLB block > + */ > +static unsigned long io_tlb_used; > +#endif > + > /* > * This is a free list describing the number of free entries available from > * each index > @@ -100,6 +110,41 @@ static DEFINE_SPINLOCK(io_tlb_lock); > > static int late_alloc; > > +#ifdef CONFIG_DEBUG_FS > + > +static struct dentry *d_swiotlb_usage; > + > +static int swiotlb_usage_show(struct seq_file *m, void *v) > +{ > + seq_printf(m, "%lu\n%lu\n", io_tlb_used, io_tlb_nslabs); > + return 0; > +} > + > +static int swiotlb_usage_open(struct inode *inode, struct file *filp) > +{ > + return single_open(filp, swiotlb_usage_show, NULL); > +} > + > +static const struct file_operations swiotlb_usage_fops = { > + .open = swiotlb_usage_open, > + .read = seq_read, > + .llseek = seq_lseek, > + .release = single_release, > +}; > + > +void swiotlb_create_debugfs(void) > +{ > + d_swiotlb_usage = debugfs_create_dir("swiotlb", NULL); > + > + if (!d_swiotlb_usage) > + return; > + > + debugfs_create_file("usage", 0600, d_swiotlb_usage, > + NULL, &swiotlb_usage_fops); > +} > + > +#endif > + > static int __init > setup_io_tlb_npages(char *str) > { > @@ -449,6 +494,11 @@ phys_addr_t swiotlb_tbl_map_single(struct device *hwdev, > pr_warn_once("%s is active and system is using DMA bounce buffers\n", > sme_active() ? "SME" : "SEV"); > > +#ifdef CONFIG_DEBUG_FS > + if (unlikely(!d_swiotlb_usage)) > + swiotlb_create_debugfs(); > +#endif > + > mask = dma_get_seg_boundary(hwdev); > > tbl_dma_addr &= mask; > @@ -528,6 +578,9 @@ phys_addr_t swiotlb_tbl_map_single(struct device *hwdev, > dev_warn(hwdev, "swiotlb buffer is full (sz: %zd bytes)\n", size); > return SWIOTLB_MAP_ERROR; > found: > +#ifdef CONFIG_DEBUG_FS > + io_tlb_used += nslots; > +#endif > spin_unlock_irqrestore(&io_tlb_lock, flags); > > /* > @@ -588,6 +641,10 @@ void swiotlb_tbl_unmap_single(struct device *hwdev, phys_addr_t tlb_addr, > */ > for (i = index - 1; (OFFSET(i, IO_TLB_SEGSIZE) != IO_TLB_SEGSIZE -1) && io_tlb_list[i]; i--) > io_tlb_list[i] = ++count; > + > +#ifdef CONFIG_DEBUG_FS > + io_tlb_used -= nslots; > +#endif > } > spin_unlock_irqrestore(&io_tlb_lock, flags); > } >