if (trace_flags & TRACE_ITER_CONTEXT_INFO) {
                SEQ_PUT_FIELD_RET(s, entry->pid);
-               SEQ_PUT_FIELD_RET(s, entry->cpu);
+               SEQ_PUT_FIELD_RET(s, iter->cpu);
                SEQ_PUT_FIELD_RET(s, iter->ts);
        }
 
 
        trace_assign_type(it, entry);
 
        if (entry->type == TRACE_HW_BRANCHES) {
-               if (trace_seq_printf(seq, "%4d  ", entry->cpu) &&
+               if (trace_seq_printf(seq, "%4d  ", iter->cpu) &&
                    seq_print_ip_sym(seq, it->to, symflags) &&
                    trace_seq_printf(seq, "\t  <-  ") &&
                    seq_print_ip_sym(seq, it->from, symflags) &&
        entry   = ring_buffer_event_data(event);
        tracing_generic_entry_update(&entry->ent, 0, from);
        entry->ent.type = TRACE_HW_BRANCHES;
-       entry->ent.cpu = cpu;
        entry->from = from;
        entry->to   = to;
        ring_buffer_unlock_commit(tr->buffer, event, irq2);
 
        unsigned long secs = (unsigned long)t;
 
        return trace_seq_printf(s, "%16s-%-5d [%03d] %5lu.%06lu: ",
-                               comm, entry->pid, entry->cpu, secs, usec_rem);
+                               comm, entry->pid, iter->cpu, secs, usec_rem);
 }
 
 int trace_print_lat_context(struct trace_iterator *iter)
                char *comm = trace_find_cmdline(entry->pid);
                ret = trace_seq_printf(s, "%16s %5d %3d %d %08x %08lx [%08lx]"
                                       " %ld.%03ldms (+%ld.%03ldms): ", comm,
-                                      entry->pid, entry->cpu, entry->flags,
+                                      entry->pid, iter->cpu, entry->flags,
                                       entry->preempt_count, iter->idx,
                                       ns2usecs(iter->ts),
                                       abs_usecs / USEC_PER_MSEC,
                                       rel_usecs / USEC_PER_MSEC,
                                       rel_usecs % USEC_PER_MSEC);
        } else {
-               ret = lat_print_generic(s, entry, entry->cpu);
+               ret = lat_print_generic(s, entry, iter->cpu);
                if (ret)
                        ret = lat_print_timestamp(s, abs_usecs, rel_usecs);
        }