aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/trace/trace.c
diff options
context:
space:
mode:
Diffstat (limited to 'kernel/trace/trace.c')
-rw-r--r--kernel/trace/trace.c42
1 files changed, 38 insertions, 4 deletions
diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c
index f5898051fdd9..192c1354a7e0 100644
--- a/kernel/trace/trace.c
+++ b/kernel/trace/trace.c
@@ -57,7 +57,7 @@ static struct trace_array max_tr;
57static DEFINE_PER_CPU(struct trace_array_cpu, max_data); 57static DEFINE_PER_CPU(struct trace_array_cpu, max_data);
58 58
59static int tracer_enabled = 1; 59static int tracer_enabled = 1;
60static unsigned long trace_nr_entries = 16384UL; 60static unsigned long trace_nr_entries = 65536UL;
61 61
62static struct tracer *trace_types __read_mostly; 62static struct tracer *trace_types __read_mostly;
63static struct tracer *current_trace __read_mostly; 63static struct tracer *current_trace __read_mostly;
@@ -87,6 +87,7 @@ enum trace_type {
87 87
88 TRACE_FN, 88 TRACE_FN,
89 TRACE_CTX, 89 TRACE_CTX,
90 TRACE_WAKE,
90 TRACE_SPECIAL, 91 TRACE_SPECIAL,
91 92
92 __TRACE_LAST_TYPE 93 __TRACE_LAST_TYPE
@@ -711,6 +712,30 @@ tracing_sched_switch_trace(struct trace_array *tr,
711 wake_up (&trace_wait); 712 wake_up (&trace_wait);
712} 713}
713 714
715void
716tracing_sched_wakeup_trace(struct trace_array *tr,
717 struct trace_array_cpu *data,
718 struct task_struct *wakee, struct task_struct *curr,
719 unsigned long flags)
720{
721 struct trace_entry *entry;
722 unsigned long irq_flags;
723
724 spin_lock_irqsave(&data->lock, irq_flags);
725 entry = tracing_get_trace_entry(tr, data);
726 tracing_generic_entry_update(entry, flags);
727 entry->type = TRACE_WAKE;
728 entry->ctx.prev_pid = curr->pid;
729 entry->ctx.prev_prio = curr->prio;
730 entry->ctx.prev_state = curr->state;
731 entry->ctx.next_pid = wakee->pid;
732 entry->ctx.next_prio = wakee->prio;
733 spin_unlock_irqrestore(&data->lock, irq_flags);
734
735 if (!(trace_flags & TRACE_ITER_BLOCK))
736 wake_up(&trace_wait);
737}
738
714#ifdef CONFIG_FTRACE 739#ifdef CONFIG_FTRACE
715static void 740static void
716function_trace_call(unsigned long ip, unsigned long parent_ip) 741function_trace_call(unsigned long ip, unsigned long parent_ip)
@@ -1183,13 +1208,14 @@ print_lat_fmt(struct trace_iterator *iter, unsigned int trace_idx, int cpu)
1183 trace_seq_puts(s, ")\n"); 1208 trace_seq_puts(s, ")\n");
1184 break; 1209 break;
1185 case TRACE_CTX: 1210 case TRACE_CTX:
1211 case TRACE_WAKE:
1186 S = entry->ctx.prev_state < sizeof(state_to_char) ? 1212 S = entry->ctx.prev_state < sizeof(state_to_char) ?
1187 state_to_char[entry->ctx.prev_state] : 'X'; 1213 state_to_char[entry->ctx.prev_state] : 'X';
1188 comm = trace_find_cmdline(entry->ctx.next_pid); 1214 comm = trace_find_cmdline(entry->ctx.next_pid);
1189 trace_seq_printf(s, " %d:%d:%c --> %d:%d %s\n", 1215 trace_seq_printf(s, " %5d:%3d:%c %s %5d:%3d %s\n",
1190 entry->ctx.prev_pid, 1216 entry->ctx.prev_pid,
1191 entry->ctx.prev_prio, 1217 entry->ctx.prev_prio,
1192 S, 1218 S, entry->type == TRACE_CTX ? "==>" : " +",
1193 entry->ctx.next_pid, 1219 entry->ctx.next_pid,
1194 entry->ctx.next_prio, 1220 entry->ctx.next_prio,
1195 comm); 1221 comm);
@@ -1256,12 +1282,14 @@ static int print_trace_fmt(struct trace_iterator *iter)
1256 return 0; 1282 return 0;
1257 break; 1283 break;
1258 case TRACE_CTX: 1284 case TRACE_CTX:
1285 case TRACE_WAKE:
1259 S = entry->ctx.prev_state < sizeof(state_to_char) ? 1286 S = entry->ctx.prev_state < sizeof(state_to_char) ?
1260 state_to_char[entry->ctx.prev_state] : 'X'; 1287 state_to_char[entry->ctx.prev_state] : 'X';
1261 ret = trace_seq_printf(s, " %d:%d:%c ==> %d:%d\n", 1288 ret = trace_seq_printf(s, " %5d:%3d:%c %s %5d:%3d\n",
1262 entry->ctx.prev_pid, 1289 entry->ctx.prev_pid,
1263 entry->ctx.prev_prio, 1290 entry->ctx.prev_prio,
1264 S, 1291 S,
1292 entry->type == TRACE_CTX ? "==>" : " +",
1265 entry->ctx.next_pid, 1293 entry->ctx.next_pid,
1266 entry->ctx.next_prio); 1294 entry->ctx.next_prio);
1267 if (!ret) 1295 if (!ret)
@@ -1301,8 +1329,11 @@ static int print_raw_fmt(struct trace_iterator *iter)
1301 return 0; 1329 return 0;
1302 break; 1330 break;
1303 case TRACE_CTX: 1331 case TRACE_CTX:
1332 case TRACE_WAKE:
1304 S = entry->ctx.prev_state < sizeof(state_to_char) ? 1333 S = entry->ctx.prev_state < sizeof(state_to_char) ?
1305 state_to_char[entry->ctx.prev_state] : 'X'; 1334 state_to_char[entry->ctx.prev_state] : 'X';
1335 if (entry->type == TRACE_WAKE)
1336 S = '+';
1306 ret = trace_seq_printf(s, "%d %d %c %d %d\n", 1337 ret = trace_seq_printf(s, "%d %d %c %d %d\n",
1307 entry->ctx.prev_pid, 1338 entry->ctx.prev_pid,
1308 entry->ctx.prev_prio, 1339 entry->ctx.prev_prio,
@@ -1355,8 +1386,11 @@ static int print_hex_fmt(struct trace_iterator *iter)
1355 SEQ_PUT_HEX_FIELD_RET(s, entry->fn.parent_ip); 1386 SEQ_PUT_HEX_FIELD_RET(s, entry->fn.parent_ip);
1356 break; 1387 break;
1357 case TRACE_CTX: 1388 case TRACE_CTX:
1389 case TRACE_WAKE:
1358 S = entry->ctx.prev_state < sizeof(state_to_char) ? 1390 S = entry->ctx.prev_state < sizeof(state_to_char) ?
1359 state_to_char[entry->ctx.prev_state] : 'X'; 1391 state_to_char[entry->ctx.prev_state] : 'X';
1392 if (entry->type == TRACE_WAKE)
1393 S = '+';
1360 SEQ_PUT_HEX_FIELD_RET(s, entry->ctx.prev_pid); 1394 SEQ_PUT_HEX_FIELD_RET(s, entry->ctx.prev_pid);
1361 SEQ_PUT_HEX_FIELD_RET(s, entry->ctx.prev_prio); 1395 SEQ_PUT_HEX_FIELD_RET(s, entry->ctx.prev_prio);
1362 SEQ_PUT_HEX_FIELD_RET(s, S); 1396 SEQ_PUT_HEX_FIELD_RET(s, S);