Fix: deny overwrite mode and num subbuf less than 2
authorDavid Goulet <dgoulet@efficios.com>
Fri, 23 May 2014 14:32:09 +0000 (10:32 -0400)
committerDavid Goulet <dgoulet@efficios.com>
Fri, 23 May 2014 14:53:44 +0000 (10:53 -0400)
Also fixed in UST and modules with commit:

(modules) 5140d2b3070f211e6d8a0ad7cb0a190e8b6f3e28
(ust) 3d8e9399b2fb9000b3b55e488a7d04184b5bb56e

Fixes #793

Signed-off-by: David Goulet <dgoulet@efficios.com>
doc/man/lttng.1
src/bin/lttng-sessiond/cmd.c

index 834d302bf49138f8cea4931be67bb2c3f223f82a..9d163f5d95d1913937cef14f70eb87cf2e6b3efc 100644 (file)
@@ -397,7 +397,8 @@ Apply to the user-space tracer
 Discard event when subbuffers are full (default)
 .TP
 .BR "\-\-overwrite"
-Flight recorder mode : overwrites events when subbuffers are full
+Flight recorder mode: overwrites events when subbuffers are full. The
+number of subbuffer must be 2 or more.
 .TP
 .BR "\-\-subbuf-size SIZE"
 Subbuffer size in bytes {+k,+M,+G}.
index 03fb8a88151ec53dee835d968f376dfd3458bd2b..8ee641d8e07726b7826572fb19a745cef76514f1 100644 (file)
@@ -931,6 +931,16 @@ int cmd_enable_channel(struct ltt_session *session,
                attr->attr.switch_timer_interval = 0;
        }
 
+       /*
+        * The ringbuffer (both in user space and kernel) behave badly in overwrite
+        * mode and with less than 2 subbuf so block it right away and send back an
+        * invalid attribute error.
+        */
+       if (attr->attr.overwrite && attr->attr.num_subbuf < 2) {
+               ret = LTTNG_ERR_INVALID;
+               goto error;
+       }
+
        switch (domain->type) {
        case LTTNG_DOMAIN_KERNEL:
        {
This page took 0.028999 seconds and 4 git commands to generate.