free(buffer);
 }
 
-void auxtrace_synth_error(struct perf_record_auxtrace_error *auxtrace_error, int type,
-                         int code, int cpu, pid_t pid, pid_t tid, u64 ip,
-                         const char *msg, u64 timestamp)
+void auxtrace_synth_guest_error(struct perf_record_auxtrace_error *auxtrace_error, int type,
+                               int code, int cpu, pid_t pid, pid_t tid, u64 ip,
+                               const char *msg, u64 timestamp,
+                               pid_t machine_pid, int vcpu)
 {
        size_t size;
 
        auxtrace_error->ip = ip;
        auxtrace_error->time = timestamp;
        strlcpy(auxtrace_error->msg, msg, MAX_AUXTRACE_ERROR_MSG);
-
-       size = (void *)auxtrace_error->msg - (void *)auxtrace_error +
-              strlen(auxtrace_error->msg) + 1;
+       if (machine_pid) {
+               auxtrace_error->fmt = 2;
+               auxtrace_error->machine_pid = machine_pid;
+               auxtrace_error->vcpu = vcpu;
+               size = sizeof(*auxtrace_error);
+       } else {
+               size = (void *)auxtrace_error->msg - (void *)auxtrace_error +
+                      strlen(auxtrace_error->msg) + 1;
+       }
        auxtrace_error->header.size = PERF_ALIGN(size, sizeof(u64));
 }
 
+void auxtrace_synth_error(struct perf_record_auxtrace_error *auxtrace_error, int type,
+                         int code, int cpu, pid_t pid, pid_t tid, u64 ip,
+                         const char *msg, u64 timestamp)
+{
+       auxtrace_synth_guest_error(auxtrace_error, type, code, cpu, pid, tid,
+                                  ip, msg, timestamp, 0, -1);
+}
+
 int perf_event__synthesize_auxtrace_info(struct auxtrace_record *itr,
                                         struct perf_tool *tool,
                                         struct perf_session *session,
        if (!e->fmt)
                msg = (const char *)&e->time;
 
+       if (e->fmt >= 2 && e->machine_pid)
+               ret += fprintf(fp, " machine_pid %d vcpu %d", e->machine_pid, e->vcpu);
+
        ret += fprintf(fp, " cpu %d pid %d tid %d ip %#"PRI_lx64" code %u: %s\n",
                       e->cpu, e->pid, e->tid, e->ip, e->code, msg);
        return ret;
 
                            bool needs_swap);
 void auxtrace_index__free(struct list_head *head);
 
+void auxtrace_synth_guest_error(struct perf_record_auxtrace_error *auxtrace_error, int type,
+                               int code, int cpu, pid_t pid, pid_t tid, u64 ip,
+                               const char *msg, u64 timestamp,
+                               pid_t machine_pid, int vcpu);
 void auxtrace_synth_error(struct perf_record_auxtrace_error *auxtrace_error, int type,
                          int code, int cpu, pid_t pid, pid_t tid, u64 ip,
                          const char *msg, u64 timestamp);
 
                msg = (const char *)&e->time;
        }
 
-       t = tuple_new(9);
+       t = tuple_new(11);
 
        tuple_set_u32(t, 0, e->type);
        tuple_set_u32(t, 1, e->code);
        tuple_set_u64(t, 6, tm);
        tuple_set_string(t, 7, msg);
        tuple_set_u32(t, 8, cpumode);
+       tuple_set_s32(t, 9, e->machine_pid);
+       tuple_set_s32(t, 10, e->vcpu);
 
        call_object(handler, t, handler_name);