Received: by 10.223.164.202 with SMTP id h10csp3931915wrb; Tue, 28 Nov 2017 20:52:03 -0800 (PST) X-Google-Smtp-Source: AGs4zMZmfK2Z1oFVPzaLKiq38KsZEasUf/xgtALkK846tCXWtQvGC+eMT4qbLXlygNTPOmopn9hr X-Received: by 10.98.166.84 with SMTP id t81mr1680475pfe.196.1511931123530; Tue, 28 Nov 2017 20:52:03 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1511931123; cv=none; d=google.com; s=arc-20160816; b=H03zDdxhKXr2kRL6rv+yNnruide1Zl8Vl8lAAq6tELVlVHeFITloeKVvRN1m6ZFlkb EEDjIWSL6LlAJTJcGlbNc8hOJ/00Ev2+fOocSVTZG/8IWnqOFLaGeTgCuhyJ3orTrozJ KSobkuC24rZlyhmFhc3VI4sPYtBl8RS3qL9+M2dUBxq4jkh/u2bW6/WNPTtCcm3goXzG pRhoQiburbVnG8hTY0T20E7hQ6dvwXaY6psJxIA6dc4EuUW/8UW977Fi3WnM7iU1hci2 hsykAQDRUwyksNEdMnru2YncRjXLR96pqwpqWuTGFmRwAFVxig06eys1O80PTccFXwKC ZlRw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :arc-authentication-results; bh=mOHe12948G3+2FB49+xI9nxZWrmdDyAFNxGupioiEy0=; b=fUDDGP9E+g5027A73P1rY4P1rfM0GtK8LgyjsPGt1C8ltBVEkIf8W5Trx9Y6UManBx AMvQc1ty/BFUn6q3DTOAMKg75f8PBJNY645IzRogBsKMs+BNHnqq+ceEPJLoWncwUKv1 xJyJaUfi2e9mLNC2QxQdZrfnXFuF5KZQgpuhHNLB8ciZ6M592vnkQ0jEsD79Q01PJjPG YnyYSOQuT5NS/GrIzqO40hYPlvvUVxLR1vQtZsEHSQRWKojqiDznO7hbcMydboo2CTlX tOafh2RkIOQa1ss8E4aluQnyAjA/AmTsH2SP0EBM5bxrPfAYhy+zu8rrBuP8rvAYEpti Wn1w== 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 a91si636734pla.455.2017.11.28.20.51.53; Tue, 28 Nov 2017 20:52:03 -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 S1752862AbdK2EuZ (ORCPT + 71 others); Tue, 28 Nov 2017 23:50:25 -0500 Received: from mga07.intel.com ([134.134.136.100]:60655 "EHLO mga07.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751693AbdK2EuY (ORCPT ); Tue, 28 Nov 2017 23:50:24 -0500 Received: from fmsmga003.fm.intel.com ([10.253.24.29]) by orsmga105.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 28 Nov 2017 20:50:23 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.44,470,1505804400"; d="scan'208";a="7077480" Received: from gvt-dell.bj.intel.com (HELO gvt-dell-host.bj.intel.com) ([10.238.154.59]) by FMSMGA003.fm.intel.com with ESMTP; 28 Nov 2017 20:50:22 -0800 From: changbin.du@intel.com To: rostedt@goodmis.org Cc: mingo@redhat.com, linux-kernel@vger.kernel.org, Changbin Du Subject: [RESEND PATCH v3] tracing: Allocate mask_str buffer dynamically Date: Wed, 29 Nov 2017 12:42:45 +0800 Message-Id: <1511930565-16531-1-git-send-email-changbin.du@intel.com> X-Mailer: git-send-email 2.7.4 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Changbin Du The default NR_CPUS can be very large, but actual possible nr_cpu_ids usually is very small. For my x86 distribution, the NR_CPUS is 8192 and nr_cpu_ids is 4. About 2 pages are wasted. Most machines don't have so many CPUs, so define a array with NR_CPUS just wastes memory. So let's allocate the buffer dynamically when need. The exact buffer size should be: DIV_ROUND_UP(nr_cpu_ids, 4) + nr_cpu_ids/32 + 2; Example output: ff,ffffffff With this change, the mutext tracing_cpumask_update_lock also can be removed now, which was used to protect mask_str. Signed-off-by: Changbin Du Cc: Steven Rostedt --- v3: - remove tracing_cpumask_update_lock which was used to protect mask_str. (Rostedt) v2: - remove 'static' declaration. - fix buffer size. --- kernel/trace/trace.c | 29 +++++++++-------------------- 1 file changed, 9 insertions(+), 20 deletions(-) diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c index 73e67b6..6750d05 100644 --- a/kernel/trace/trace.c +++ b/kernel/trace/trace.c @@ -4178,37 +4178,30 @@ static const struct file_operations show_traces_fops = { .llseek = seq_lseek, }; -/* - * The tracer itself will not take this lock, but still we want - * to provide a consistent cpumask to user-space: - */ -static DEFINE_MUTEX(tracing_cpumask_update_lock); - -/* - * Temporary storage for the character representation of the - * CPU bitmask (and one more byte for the newline): - */ -static char mask_str[NR_CPUS + 1]; - static ssize_t tracing_cpumask_read(struct file *filp, char __user *ubuf, size_t count, loff_t *ppos) { struct trace_array *tr = file_inode(filp)->i_private; + char *mask_str; int len; - mutex_lock(&tracing_cpumask_update_lock); + /* Bitmap, ',' and two more bytes for the newline and '\0'. */ + len = DIV_ROUND_UP(nr_cpu_ids, 4) + nr_cpu_ids/32 + 2; + mask_str = kmalloc(len, GFP_KERNEL); + if (!mask_str) + return -ENOMEM; - len = snprintf(mask_str, count, "%*pb\n", + len = snprintf(mask_str, len, "%*pb\n", cpumask_pr_args(tr->tracing_cpumask)); if (len >= count) { count = -EINVAL; goto out_err; } - count = simple_read_from_buffer(ubuf, count, ppos, mask_str, NR_CPUS+1); + count = simple_read_from_buffer(ubuf, count, ppos, mask_str, len); out_err: - mutex_unlock(&tracing_cpumask_update_lock); + kfree(mask_str); return count; } @@ -4228,8 +4221,6 @@ tracing_cpumask_write(struct file *filp, const char __user *ubuf, if (err) goto err_unlock; - mutex_lock(&tracing_cpumask_update_lock); - local_irq_disable(); arch_spin_lock(&tr->max_lock); for_each_tracing_cpu(cpu) { @@ -4252,8 +4243,6 @@ tracing_cpumask_write(struct file *filp, const char __user *ubuf, local_irq_enable(); cpumask_copy(tr->tracing_cpumask, tracing_cpumask_new); - - mutex_unlock(&tracing_cpumask_update_lock); free_cpumask_var(tracing_cpumask_new); return count; -- 2.7.4 From 1586590632497028095@xxx Tue Dec 12 14:58:56 +0000 2017 X-GM-THRID: 1586590632497028095 X-Gmail-Labels: Inbox,Category Forums,HistoricalUnread