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