forked from OSchip/llvm-project
47 lines
1.6 KiB
ArmAsm
47 lines
1.6 KiB
ArmAsm
## 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, also test that `--time-trace` is not needed if the other two are used.
|
|
# RUN: %lld --time-trace-file=%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, also test that `--time-trace` is not needed if the other two are used.
|
|
# RUN: %lld --time-trace-file=- --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
|