Received: by 10.223.164.221 with SMTP id h29csp1656658wrb; Wed, 25 Oct 2017 04:32:34 -0700 (PDT) X-Google-Smtp-Source: ABhQp+RKt7NI3eIRCL78QSG78XxAFCNkQIQedOd0bl3Ezzi8XvtW3WZB992oYBceUu0gXjgoQQYk X-Received: by 10.99.97.132 with SMTP id v126mr1734156pgb.179.1508931154830; Wed, 25 Oct 2017 04:32:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1508931154; cv=none; d=google.com; s=arc-20160816; b=aB4gYmpE7HlHOEdfOn9diX6TOSDUOdmdzE1BafjNZUmSEwq69axg05MWMbgzp4MIJw aWI7yeaz5HtPtWoQpiUYxqtuTZupwLw3kysJOUzWSC8PXyW/vL/5DtkLolPUkZzOST+L Qje+4Hu+b8wh4DklZazWxJt6z1QA5ypKpCZiXXCVGrQwlHEM/v0rQXeDve0nqBI7Jegx t3z/gwlKMbI21OQpiU9Cy0jpLZelkXYf/14xZfFvFZ2nmK+Z1Yrm8t/WgJXFiBdCt7AV yi6kpRkyAhy3My0Bx9ZmNEzuTPXYJ5q7urogZgUohOhQ7R+wuDb3hZvBe7UdwcDBAYn2 Gq2g== 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=/Ld4wgY9uia2Osaxr/QXRaaILstrfEAg9S9L+ztqjzo=; b=vhiWZldtk+oGB9Dtm079ZbUiYCTui9yEmo9BEzrIO8Gp/2loJmBDHBv53HML7LoOzc xlY+uIJcKEnBeyWvpXuMjtDT2Wl/yUiWIy9fwwSRtS+6hryZeAWbDgEye5fbSRriOT+H yuEZZ9ldZm0qQakCm5ID/e6zxCOazTRYKbBwVktIQ6Z3WtySpEZwxu9p648vzdTgewMm nH4L9keThNNlZRn/EWcuDHIJcrm6DvGU+HSKb1LGVi7h/p2Ci5DJ0Yd6OwSl7YNXMYsw 52CgVlhIdnWjxF/G61/x2SmM3bRNttsTHWIXaOKbfkGwIs0cIwbtuIvQR8THlnwzyxWa +j5A== 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 h1si1503078pln.309.2017.10.25.04.32.20; Wed, 25 Oct 2017 04:32:34 -0700 (PDT) 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 S1751637AbdJYLbt (ORCPT + 99 others); Wed, 25 Oct 2017 07:31:49 -0400 Received: from mga02.intel.com ([134.134.136.20]:26382 "EHLO mga02.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751374AbdJYLbs (ORCPT ); Wed, 25 Oct 2017 07:31:48 -0400 Received: from fmsmga001.fm.intel.com ([10.253.24.23]) by orsmga101.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 25 Oct 2017 04:31:47 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.43,431,1503385200"; d="scan'208";a="1209878607" Received: from gvt-dell.bj.intel.com (HELO gvt-dell-host.bj.intel.com) ([10.238.154.59]) by fmsmga001.fm.intel.com with ESMTP; 25 Oct 2017 04:31:41 -0700 From: changbin.du@intel.com To: rostedt@goodmis.org, mingo@redhat.com Cc: linux-kernel@vger.kernel.org, Changbin Du Subject: [PATCH] tracing: Allocate mask_str buffer dynamically Date: Wed, 25 Oct 2017 19:24:36 +0800 Message-Id: <1508930676-8861-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. Signed-off-by: Changbin Du --- kernel/trace/trace.c | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c index 752e5da..d1b3f11 100644 --- a/kernel/trace/trace.c +++ b/kernel/trace/trace.c @@ -4184,19 +4184,18 @@ static const struct file_operations show_traces_fops = { */ 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; + static char *mask_str; int len; + mask_str = kmalloc(nr_cpu_ids + 1, GFP_KERNEL); + if (!mask_str) + return -ENOMEM; + mutex_lock(&tracing_cpumask_update_lock); len = snprintf(mask_str, count, "%*pb\n", @@ -4205,10 +4204,12 @@ tracing_cpumask_read(struct file *filp, char __user *ubuf, 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, nr_cpu_ids+1); out_err: mutex_unlock(&tracing_cpumask_update_lock); + kfree(mask_str); return count; } -- 2.7.4 From 1583028743154672218@xxx Fri Nov 03 07:24:14 +0000 2017 X-GM-THRID: 1581815231837338326 X-Gmail-Labels: Inbox,Category Forums,HistoricalUnread