From: William Lee Irwin III <wli@holomorphy.com>
To: linux-kernel@vger.kernel.org
Cc: rddunlap@osdl.org
Subject: Re: [profile]: [22/23] put 1 << prof_shift at prof_buffer[0]
Date: Tue, 22 Jun 2004 10:10:57 -0700 [thread overview]
Message-ID: <20040622171057.GD2135@holomorphy.com> (raw)
In-Reply-To: <0406220817.IbZaYa0a2aZaKb5aIbJbYaXa4aIbIbZaZaWa3aZa5a2a2aHbIbMbZa0aMbHbHbKb15250@holomorphy.com>
On Tue, Jun 22, 2004 at 08:18:10AM -0700, William Lee Irwin III wrote:
> Change the profile buffer format so that prof_buffer[0] contains the
> stepsize.
And this actually needs to be the following, to fix up an off-by-one
and a hunk that migrated to the wrong patch of the series (to be
followed by an mmap() patch that actually applies atop this):
Index: prof-2.6.7/kernel/profile.c
===================================================================
--- prof-2.6.7.orig/kernel/profile.c 2004-06-22 08:28:11.401782488 -0700
+++ prof-2.6.7/kernel/profile.c 2004-06-22 10:06:59.034645320 -0700
@@ -32,8 +32,9 @@
return;
/* only text is profiled */
- prof_len = (_etext - _stext) >> prof_shift;
+ prof_len = ((unsigned long)(_etext - _stext) >> prof_shift) + 1;
prof_buffer = alloc_bootmem(sizeof(atomic_t)*prof_len);
+ atomic_set(prof_buffer, 1 << prof_shift);
}
int profiling_on(void)
@@ -48,7 +49,7 @@
if (!prof_on)
return;
idx = (pc - (unsigned long)_stext) >> prof_shift;
- atomic_inc(&prof_buffer[min(idx, prof_len - 1)]);
+ atomic_inc(&prof_buffer[min(idx + 1, prof_len - 1)]);
}
/* Profile event notifications */
@@ -176,26 +177,14 @@
read_profile(struct file *file, char __user *buf, size_t count, loff_t *ppos)
{
unsigned long p = *ppos;
- ssize_t read;
- char * pnt;
- unsigned int sample_step = 1 << prof_shift;
- if (p >= (prof_len+1)*sizeof(atomic_t))
+ if (p >= sizeof(atomic_t)*prof_len)
return 0;
- if (count > (prof_len+1)*sizeof(atomic_t) - p)
- count = (prof_len+1)*sizeof(atomic_t) - p;
- read = 0;
-
- while (p < sizeof(atomic_t) && count > 0) {
- put_user(*((char *)(&sample_step)+p),buf);
- buf++; p++; count--; read++;
- }
- pnt = (char *)prof_buffer + p - sizeof(atomic_t);
- if (copy_to_user(buf,(void *)pnt,count))
+ count = min(prof_len*sizeof(atomic_t) - p, count);
+ if (copy_to_user(buf, (char *)prof_buffer + p, count))
return -EFAULT;
- read += count;
- *ppos += read;
- return read;
+ *ppos += count;
+ return count;
}
/*
@@ -221,7 +210,7 @@
}
#endif
- memset(prof_buffer, 0, prof_len*sizeof(atomic_t));
+ memset(&prof_buffer[1], 0, (prof_len-1)*sizeof(atomic_t));
return count;
}
@@ -240,6 +229,6 @@
if (!entry)
return;
entry->proc_fops = &proc_profile_operations;
- entry->size = (1+prof_len) * sizeof(atomic_t);
+ entry->size = sizeof(atomic_t)*prof_len;
}
#endif /* CONFIG_PROC_FS */
next prev parent reply other threads:[~2004-06-22 17:18 UTC|newest]
Thread overview: 36+ messages / expand[flat|nested] mbox.gz Atom feed top
2004-06-22 15:16 [profile]: [0/23] mmap() support for /proc/profile William Lee Irwin III
2004-06-22 15:16 ` [profile]: [1/23] move proc_profile_operations to profile.c William Lee Irwin III
2004-06-22 15:16 ` [profile]: [2/23] ppc32 profiling cleanups William Lee Irwin III
2004-06-22 15:16 ` [profile]: [3/23] mips " William Lee Irwin III
2004-06-22 15:16 ` [profile]: [4/23] sparc64 " William Lee Irwin III
2004-06-22 15:16 ` [profile]: [5/23] m68knommu " William Lee Irwin III
2004-06-22 15:16 ` [profile]: [6/23] sparc32 " William Lee Irwin III
2004-06-22 15:16 ` [profile]: [7/23] superh " William Lee Irwin III
2004-06-22 15:17 ` [profile]: [8/23] arm26 " William Lee Irwin III
2004-06-22 15:17 ` [profile]: [9/23] m68k " William Lee Irwin III
2004-06-22 15:17 ` [profile]: [10/23] ia64 " William Lee Irwin III
2004-06-22 15:17 ` [profile]: [11/23] alpha " William Lee Irwin III
2004-06-22 15:17 ` [profile]: [12/23] ppc64 " William Lee Irwin III
2004-06-22 15:17 ` [profile]: [13/23] arm " William Lee Irwin III
2004-06-22 15:17 ` [profile]: [14/23] parisc " William Lee Irwin III
2004-06-22 15:17 ` [profile]: [15/23] h8300 " William Lee Irwin III
2004-06-22 15:17 ` [profile]: [16/23] s390 " William Lee Irwin III
2004-06-22 15:17 ` [profile]: [17/23] x86-64 " William Lee Irwin III
2004-06-22 15:17 ` [profile]: [18/23] i386 " William Lee Irwin III
2004-06-22 15:17 ` [profile]: [19/23] remove public decls of profile.c internal state William Lee Irwin III
2004-06-22 15:17 ` [profile]: [20/23] clean up profile_init() not to oversize buffer William Lee Irwin III
2004-06-22 15:17 ` [profile]: [21/23] use atomic_t for prof_buffer William Lee Irwin III
2004-06-22 15:18 ` [profile]: [22/23] put 1 << prof_shift at prof_buffer[0] William Lee Irwin III
2004-06-22 15:18 ` [profile]: [23/23] add mmap() support for /proc/profile William Lee Irwin III
2004-06-22 17:03 ` William Lee Irwin III
2004-06-22 17:10 ` William Lee Irwin III [this message]
2004-06-22 17:12 ` [profile]: [22/23] put 1 << prof_shift at prof_buffer[0] William Lee Irwin III
2004-06-22 20:01 ` [profile]: [21/23] use atomic_t for prof_buffer David S. Miller
2004-06-22 20:16 ` William Lee Irwin III
2004-06-22 20:47 ` David S. Miller
2004-06-29 18:56 ` [profile]: [10/23] ia64 profiling cleanups David Mosberger
2004-06-29 19:23 ` William Lee Irwin III
2004-06-22 23:16 ` [profile]: [0/23] mmap() support for /proc/profile Anton Blanchard
2004-06-23 1:58 ` David S. Miller
2004-06-23 2:05 ` William Lee Irwin III
2004-06-23 3:00 ` Anton Blanchard
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20040622171057.GD2135@holomorphy.com \
--to=wli@holomorphy.com \
--cc=linux-kernel@vger.kernel.org \
--cc=rddunlap@osdl.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox