1*ae7aa9edSJez Ng; REQUIRES: x86
2*ae7aa9edSJez Ng; RUN: rm -rf %t; split-file %s %t
3*ae7aa9edSJez Ng
4*ae7aa9edSJez Ng; Test ThinLTO with time trace
5*ae7aa9edSJez Ng; RUN: opt -module-summary %t/f.s -o %t/f.o
6*ae7aa9edSJez Ng; RUN: opt -module-summary %t/g.s -o %t/g.o
7*ae7aa9edSJez Ng; RUN: %lld --time-trace --time-trace-granularity=0 -dylib %t/f.o %t/g.o -o %t/libTest.dylib
8*ae7aa9edSJez Ng; RUN: cat %t/libTest.dylib.time-trace \
9*ae7aa9edSJez Ng; RUN:   | %python -c 'import json, sys; json.dump(json.loads(sys.stdin.read()), sys.stdout, sort_keys=True, indent=2)' \
10*ae7aa9edSJez Ng; RUN:   | FileCheck %s
11*ae7aa9edSJez Ng
12*ae7aa9edSJez Ng; CHECK: "traceEvents": [
13*ae7aa9edSJez Ng; Check fields for an event are present
14*ae7aa9edSJez Ng; CHECK: "args":
15*ae7aa9edSJez Ng; CHECK-NEXT: "detail":
16*ae7aa9edSJez Ng; CHECK: "dur":
17*ae7aa9edSJez Ng; CHECK-NEXT: "name":
18*ae7aa9edSJez Ng; CHECK-NEXT: "ph":
19*ae7aa9edSJez Ng; CHECK-NEXT: "pid":
20*ae7aa9edSJez Ng; CHECK-NEXT: "tid":
21*ae7aa9edSJez Ng; CHECK-NEXT: "ts":
22*ae7aa9edSJez Ng
23*ae7aa9edSJez Ng; Check that an optimization event is present
24*ae7aa9edSJez Ng; CHECK: "name": "OptModule"
25*ae7aa9edSJez Ng
26*ae7aa9edSJez Ng;--- f.s
27*ae7aa9edSJez Ngtarget triple = "x86_64-apple-darwin"
28*ae7aa9edSJez Ngtarget datalayout = "e-m:o-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128"
29*ae7aa9edSJez Ng
30*ae7aa9edSJez Ngdeclare void @g(...)
31*ae7aa9edSJez Ng
32*ae7aa9edSJez Ngdefine void @f() {
33*ae7aa9edSJez Ngentry:
34*ae7aa9edSJez Ng  call void (...) @g()
35*ae7aa9edSJez Ng  ret void
36*ae7aa9edSJez Ng}
37*ae7aa9edSJez Ng
38*ae7aa9edSJez Ng;--- g.s
39*ae7aa9edSJez Ngtarget triple = "x86_64-apple-darwin"
40*ae7aa9edSJez Ngtarget datalayout = "e-m:o-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128"
41*ae7aa9edSJez Ng
42*ae7aa9edSJez Ngdefine void @g() {
43*ae7aa9edSJez Ngentry:
44*ae7aa9edSJez Ng  ret void
45*ae7aa9edSJez Ng}
46