aboutsummaryrefslogtreecommitdiffstats
path: root/include/net/inet_connection_sock.h
diff options
context:
space:
mode:
authorThomas Gleixner <tglx@linutronix.de>2010-11-30 17:49:49 +0000
committerArnaldo Carvalho de Melo <acme@redhat.com>2010-11-30 20:01:08 -0200
commitfe17420784a6d3602e98f798731369fa05936cbe (patch)
tree7c55a62a093b6c640114c07dd18f634a17073b97 /include/net/inet_connection_sock.h
parent55b44629f599a2305265ae9c77f9d9bcfd6ddc17 (diff)
downloadkernel_samsung_smdk4412-fe17420784a6d3602e98f798731369fa05936cbe.tar.gz
kernel_samsung_smdk4412-fe17420784a6d3602e98f798731369fa05936cbe.tar.bz2
kernel_samsung_smdk4412-fe17420784a6d3602e98f798731369fa05936cbe.zip
perf session: Keep file mmaped instead of malloc/memcpy
Profiling perf with perf revealed that a large part of the processing time is spent in malloc/memcpy/free in the sample ordering code. That code copies the data from the mmap into malloc'ed memory. That's silly. We can keep the mmap and just store the pointer in the queuing data structure. For 64 bit this is not a problem as we map the whole file anyway. On 32bit we keep 8 maps around and unmap the oldest before mmaping the next chunk of the file. Performance gain: 2.95s -> 1.23s (Faktor 2.4) Cc: Ingo Molnar <mingo@elte.hu> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Frederic Weisbecker <fweisbec@gmail.com> LKML-Reference: <20101130163820.278787719@linutronix.de> Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'include/net/inet_connection_sock.h')
0 files changed, 0 insertions, 0 deletions