## When running main twice, we'll also output the time trace JSON twice, which ## breaks JSON parsing. # XFAIL: main-run-twice # REQUIRES: x86 # RUN: llvm-mc -filetype=obj -triple=x86_64-apple-darwin %s -o %t.o ## Test implicit trace file name # RUN: %lld --time-trace --time-trace-granularity=0 -o %t1.macho %t.o # RUN: cat %t1.macho.time-trace \ # RUN: | %python -c 'import json, sys; json.dump(json.loads(sys.stdin.read()), sys.stdout, sort_keys=True, indent=2)' \ # RUN: | FileCheck %s ## Test specified trace file name. # RUN: %lld --time-trace=%t2.json --time-trace-granularity=0 -o %t2.macho %t.o # RUN: cat %t2.json \ # RUN: | %python -c 'import json, sys; json.dump(json.loads(sys.stdin.read()), sys.stdout, sort_keys=True, indent=2)' \ # RUN: | FileCheck %s ## Test trace requested to stdout. # RUN: %lld --time-trace=- --time-trace-granularity=0 -o %t3.macho %t.o \ # RUN: | %python -c 'import json, sys; json.dump(json.loads(sys.stdin.read()), sys.stdout, sort_keys=True, indent=2)' \ # RUN: | FileCheck %s # CHECK: "beginningOfTime": {{[0-9]{16},}} # CHECK-NEXT: "traceEvents": [ ## Check one event has correct fields # CHECK: "dur": # CHECK-NEXT: "name": # CHECK-NEXT: "ph": # CHECK-NEXT: "pid": # CHECK-NEXT: "tid": # CHECK-NEXT: "ts": ## Check there is an ExecuteLinker event # CHECK: "name": "ExecuteLinker" ## Check process_name entry field # CHECK: "name": "ld64.lld{{(.exe)?}}" # CHECK: "name": "process_name" # CHECK: "name": "thread_name" .globl _main _main: ret