Commit 09fa4f40 authored by Wang Nan's avatar Wang Nan Committed by Arnaldo Carvalho de Melo

perf record: Rename variable to make code clear

record__mmap_read() writes data from ring buffer into perf.data.  'head'
is maintained by the kernel, points to the last written record.
'old' is maintained by perf, points to the record read in previous
round. record__mmap_read() saves data from 'old' to 'head' to
perf.data.

The names of these variables are not very intutive. In addition,
when dealing with backward writing ring buffer, the md->prev pointer
should point to 'head' instead of the last byte it got.

Add 'start' and 'end' pointer to make code clear and set md->prev to
'head' instead of the moved 'old' pointer. This patch doesn't change
behavior since:

    buf = &data[old & md->mask];
    size = head - old;
    old += size;     <--- Here, old == head
Signed-off-by: default avatarWang Nan <wangnan0@huawei.com>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: Masami Hiramatsu <masami.hiramatsu.pt@hitachi.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Zefan Li <lizefan@huawei.com>
Cc: pi3orama@163.com
Link: http://lkml.kernel.org/r/1463987628-163563-4-git-send-email-wangnan0@huawei.comSigned-off-by: default avatarHe Kuang <hekuang@huawei.com>
Signed-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent 2d11c650
...@@ -88,17 +88,18 @@ static int record__mmap_read(struct record *rec, int idx) ...@@ -88,17 +88,18 @@ static int record__mmap_read(struct record *rec, int idx)
struct perf_mmap *md = &rec->evlist->mmap[idx]; struct perf_mmap *md = &rec->evlist->mmap[idx];
u64 head = perf_mmap__read_head(md); u64 head = perf_mmap__read_head(md);
u64 old = md->prev; u64 old = md->prev;
u64 end = head, start = old;
unsigned char *data = md->base + page_size; unsigned char *data = md->base + page_size;
unsigned long size; unsigned long size;
void *buf; void *buf;
int rc = 0; int rc = 0;
if (old == head) if (start == end)
return 0; return 0;
rec->samples++; rec->samples++;
size = head - old; size = end - start;
if (size > (unsigned long)(md->mask) + 1) { if (size > (unsigned long)(md->mask) + 1) {
WARN_ONCE(1, "failed to keep up with mmap data. (warn only once)\n"); WARN_ONCE(1, "failed to keep up with mmap data. (warn only once)\n");
...@@ -107,10 +108,10 @@ static int record__mmap_read(struct record *rec, int idx) ...@@ -107,10 +108,10 @@ static int record__mmap_read(struct record *rec, int idx)
return 0; return 0;
} }
if ((old & md->mask) + size != (head & md->mask)) { if ((start & md->mask) + size != (end & md->mask)) {
buf = &data[old & md->mask]; buf = &data[start & md->mask];
size = md->mask + 1 - (old & md->mask); size = md->mask + 1 - (start & md->mask);
old += size; start += size;
if (record__write(rec, buf, size) < 0) { if (record__write(rec, buf, size) < 0) {
rc = -1; rc = -1;
...@@ -118,16 +119,16 @@ static int record__mmap_read(struct record *rec, int idx) ...@@ -118,16 +119,16 @@ static int record__mmap_read(struct record *rec, int idx)
} }
} }
buf = &data[old & md->mask]; buf = &data[start & md->mask];
size = head - old; size = end - start;
old += size; start += size;
if (record__write(rec, buf, size) < 0) { if (record__write(rec, buf, size) < 0) {
rc = -1; rc = -1;
goto out; goto out;
} }
md->prev = old; md->prev = head;
perf_evlist__mmap_consume(rec->evlist, idx); perf_evlist__mmap_consume(rec->evlist, idx);
out: out:
return rc; return rc;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment