|
@@ -143,6 +143,7 @@ static int __cmd_trace(void)
|
|
int ret, rc = EXIT_FAILURE;
|
|
int ret, rc = EXIT_FAILURE;
|
|
unsigned long offset = 0;
|
|
unsigned long offset = 0;
|
|
unsigned long head = 0;
|
|
unsigned long head = 0;
|
|
|
|
+ unsigned long shift;
|
|
struct stat perf_stat;
|
|
struct stat perf_stat;
|
|
event_t *event;
|
|
event_t *event;
|
|
uint32_t size;
|
|
uint32_t size;
|
|
@@ -180,6 +181,10 @@ static int __cmd_trace(void)
|
|
return EXIT_FAILURE;
|
|
return EXIT_FAILURE;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ shift = page_size * (head / page_size);
|
|
|
|
+ offset += shift;
|
|
|
|
+ head -= shift;
|
|
|
|
+
|
|
remap:
|
|
remap:
|
|
buf = (char *)mmap(NULL, page_size * mmap_window, PROT_READ,
|
|
buf = (char *)mmap(NULL, page_size * mmap_window, PROT_READ,
|
|
MAP_SHARED, input, offset);
|
|
MAP_SHARED, input, offset);
|
|
@@ -192,9 +197,9 @@ more:
|
|
event = (event_t *)(buf + head);
|
|
event = (event_t *)(buf + head);
|
|
|
|
|
|
if (head + event->header.size >= page_size * mmap_window) {
|
|
if (head + event->header.size >= page_size * mmap_window) {
|
|
- unsigned long shift = page_size * (head / page_size);
|
|
|
|
int res;
|
|
int res;
|
|
|
|
|
|
|
|
+ shift = page_size * (head / page_size);
|
|
res = munmap(buf, page_size * mmap_window);
|
|
res = munmap(buf, page_size * mmap_window);
|
|
assert(res == 0);
|
|
assert(res == 0);
|
|
|
|
|