Revision 492a74f4210e15f4701422e2e1c4cd3c1e45ddae authored by Steven Rostedt on 25 January 2010, 20:17:47 UTC, committed by Steven Rostedt on 26 January 2010, 21:09:30 UTC
Usually reads of the ring buffer is performed by a single task.
There are two types of reads from the ring buffer.

One is a consuming read which will consume the entry that was read
and the next read will be the entry that follows.

The other is an iterator that will let the user read the contents of
the ring buffer without modifying it. When an iterator is allocated,
writes to the ring buffer are disabled to protect the iterator.

The problem exists when consuming reads happen while an iterator is
allocated. Specifically, the kind of read that swaps out an entire
page (used by splice) and replaces it with a new read. If the iterator
is on the page that is swapped out, then the next read may read
from this swapped out page and return garbage.

This patch adds a check when reading the iterator to make sure that
the iterator contents are still valid. If a consuming read has taken
place, the iterator is reset.

Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
1 parent 74bf407
History
File Mode Size
gcov
irq
power
time
trace
.gitignore -rw-r--r-- 63 bytes
Kconfig.freezer -rw-r--r-- 52 bytes
Kconfig.hz -rw-r--r-- 1.7 KB
Kconfig.locks -rw-r--r-- 4.5 KB
Kconfig.preempt -rw-r--r-- 2.0 KB
Makefile -rw-r--r-- 4.9 KB
acct.c -rw-r--r-- 17.5 KB
async.c -rw-r--r-- 10.9 KB
audit.c -rw-r--r-- 39.4 KB
audit.h -rw-r--r-- 5.8 KB
audit_tree.c -rw-r--r-- 21.9 KB
audit_watch.c -rw-r--r-- 14.4 KB
auditfilter.c -rw-r--r-- 33.3 KB
auditsc.c -rw-r--r-- 66.1 KB
backtracetest.c -rw-r--r-- 2.1 KB
bounds.c -rw-r--r-- 530 bytes
capability.c -rw-r--r-- 8.1 KB
cgroup.c -rw-r--r-- 108.5 KB
cgroup_freezer.c -rw-r--r-- 9.2 KB
compat.c -rw-r--r-- 28.2 KB
configs.c -rw-r--r-- 2.8 KB
cpu.c -rw-r--r-- 13.5 KB
cpuset.c -rw-r--r-- 71.7 KB
cred-internals.h -rw-r--r-- 559 bytes
cred.c -rw-r--r-- 22.3 KB
delayacct.c -rw-r--r-- 4.9 KB
dma.c -rw-r--r-- 3.6 KB
exec_domain.c -rw-r--r-- 4.5 KB
exit.c -rw-r--r-- 43.6 KB
extable.c -rw-r--r-- 3.2 KB
fork.c -rw-r--r-- 42.7 KB
freezer.c -rw-r--r-- 3.8 KB
futex.c -rw-r--r-- 67.7 KB
futex_compat.c -rw-r--r-- 4.5 KB
groups.c -rw-r--r-- 6.1 KB
hrtimer.c -rw-r--r-- 45.4 KB
hung_task.c -rw-r--r-- 5.1 KB
hw_breakpoint.c -rw-r--r-- 11.2 KB
itimer.c -rw-r--r-- 7.3 KB
kallsyms.c -rw-r--r-- 12.4 KB
kexec.c -rw-r--r-- 38.7 KB
kfifo.c -rw-r--r-- 11.3 KB
kgdb.c -rw-r--r-- 39.3 KB
kmod.c -rw-r--r-- 14.6 KB
kprobes.c -rw-r--r-- 38.1 KB
ksysfs.c -rw-r--r-- 5.0 KB
kthread.c -rw-r--r-- 6.6 KB
latencytop.c -rw-r--r-- 7.7 KB
lockdep.c -rw-r--r-- 90.5 KB
lockdep_internals.h -rw-r--r-- 3.9 KB
lockdep_proc.c -rw-r--r-- 17.2 KB
lockdep_states.h -rw-r--r-- 233 bytes
module.c -rw-r--r-- 77.4 KB
mutex-debug.c -rw-r--r-- 2.9 KB
mutex-debug.h -rw-r--r-- 1.7 KB
mutex.c -rw-r--r-- 13.2 KB
mutex.h -rw-r--r-- 1.3 KB
notifier.c -rw-r--r-- 16.9 KB
ns_cgroup.c -rw-r--r-- 2.5 KB
nsproxy.c -rw-r--r-- 5.0 KB
panic.c -rw-r--r-- 9.1 KB
params.c -rw-r--r-- 18.3 KB
perf_event.c -rw-r--r-- 121.6 KB
pid.c -rw-r--r-- 12.3 KB
pid_namespace.c -rw-r--r-- 4.4 KB
pm_qos_params.c -rw-r--r-- 11.5 KB
posix-cpu-timers.c -rw-r--r-- 45.2 KB
posix-timers.c -rw-r--r-- 29.2 KB
printk.c -rw-r--r-- 37.7 KB
profile.c -rw-r--r-- 16.5 KB
ptrace.c -rw-r--r-- 17.6 KB
rcupdate.c -rw-r--r-- 2.1 KB
rcutiny.c -rw-r--r-- 7.1 KB
rcutorture.c -rw-r--r-- 35.7 KB
rcutree.c -rw-r--r-- 54.9 KB
rcutree.h -rw-r--r-- 14.6 KB
rcutree_plugin.h -rw-r--r-- 24.8 KB
rcutree_trace.c -rw-r--r-- 9.4 KB
relay.c -rw-r--r-- 32.6 KB
res_counter.c -rw-r--r-- 3.8 KB
resource.c -rw-r--r-- 21.1 KB
rtmutex-debug.c -rw-r--r-- 5.8 KB
rtmutex-debug.h -rw-r--r-- 1.4 KB
rtmutex-tester.c -rw-r--r-- 9.1 KB
rtmutex.c -rw-r--r-- 29.4 KB
rtmutex.h -rw-r--r-- 1.1 KB
rtmutex_common.h -rw-r--r-- 3.7 KB
rwsem.c -rw-r--r-- 2.6 KB
sched.c -rw-r--r-- 269.5 KB
sched_clock.c -rw-r--r-- 5.6 KB
sched_cpupri.c -rw-r--r-- 5.6 KB
sched_cpupri.h -rw-r--r-- 945 bytes
sched_debug.c -rw-r--r-- 11.9 KB
sched_fair.c -rw-r--r-- 50.9 KB
sched_features.h -rw-r--r-- 3.0 KB
sched_idletask.c -rw-r--r-- 3.1 KB
sched_rt.c -rw-r--r-- 40.5 KB
sched_stats.h -rw-r--r-- 10.6 KB
seccomp.c -rw-r--r-- 1.6 KB
semaphore.c -rw-r--r-- 7.2 KB
signal.c -rw-r--r-- 67.8 KB
slow-work-debugfs.c -rw-r--r-- 5.3 KB
slow-work.c -rw-r--r-- 30.4 KB
slow-work.h -rw-r--r-- 1.8 KB
smp.c -rw-r--r-- 13.3 KB
softirq.c -rw-r--r-- 21.4 KB
softlockup.c -rw-r--r-- 6.6 KB
spinlock.c -rw-r--r-- 9.5 KB
srcu.c -rw-r--r-- 9.4 KB
stacktrace.c -rw-r--r-- 896 bytes
stop_machine.c -rw-r--r-- 4.5 KB
sys.c -rw-r--r-- 37.4 KB
sys_ni.c -rw-r--r-- 5.1 KB
sysctl.c -rw-r--r-- 61.5 KB
sysctl_binary.c -rw-r--r-- 52.1 KB
sysctl_check.c -rw-r--r-- 4.4 KB
taskstats.c -rw-r--r-- 13.7 KB
test_kprobes.c -rw-r--r-- 8.4 KB
time.c -rw-r--r-- 18.9 KB
timeconst.pl -rw-r--r-- 7.2 KB
timer.c -rw-r--r-- 44.4 KB
tracepoint.c -rw-r--r-- 15.3 KB
tsacct.c -rw-r--r-- 4.2 KB
uid16.c -rw-r--r-- 5.3 KB
up.c -rw-r--r-- 413 bytes
user-return-notifier.c -rw-r--r-- 1.3 KB
user.c -rw-r--r-- 12.2 KB
user_namespace.c -rw-r--r-- 2.2 KB
utsname.c -rw-r--r-- 1.6 KB
utsname_sysctl.c -rw-r--r-- 2.5 KB
wait.c -rw-r--r-- 8.2 KB
workqueue.c -rw-r--r-- 28.8 KB

back to top