## This test checks JSON output for DATA. # REQUIRES: x86-registered-target ## Show how library errors are reported in the output. # RUN: llvm-symbolizer "DATA %t-no-file.o 0" --output-style=JSON | \ # RUN: FileCheck %s -DMSG=%errc_ENOENT --check-prefix=NO-FILE --strict-whitespace --match-full-lines --implicit-check-not={{.}} # NO-FILE:[{"Address":"0x0","Error":{"Message":"[[MSG]]"},"ModuleName":"{{.*}}no-file.o"}] ## Handle invalid argument. # RUN: llvm-symbolizer "DATA tmp.o Z" --output-style=JSON | \ # RUN: FileCheck %s --check-prefix=INVARG --strict-whitespace --match-full-lines --implicit-check-not={{.}} # INVARG:[{"Error":{"Message":"unable to parse arguments: DATA tmp.o Z"},"ModuleName":"tmp.o"}] # RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %s -o %t.o ## Resolve out of range address. # RUN: llvm-symbolizer "DATA %t.o 0x10000000" --output-style=JSON | \ # RUN: FileCheck %s --check-prefix=NOT-FOUND --strict-whitespace --match-full-lines --implicit-check-not={{.}} # NOT-FOUND:[{"Address":"0x10000000","Data":{"Name":"","Size":"0x0","Start":"0x0"},"ModuleName":"{{.*}}.o"}] ## Resolve valid address. # RUN: llvm-symbolizer "DATA %t.o 0" --output-style=JSON | \ # RUN: FileCheck %s --strict-whitespace --match-full-lines --implicit-check-not={{.}} # CHECK:[{"Address":"0x0","Data":{"Name":"d1","Size":"0x8","Start":"0x0"},"ModuleName":"{{.*}}.o"}] ## Test multiple addresses on the command-line. # RUN: llvm-symbolizer -e=%t.o "DATA 2" "DATA 8" --output-style=JSON | \ # RUN: FileCheck %s --check-prefix=MULTI --strict-whitespace --match-full-lines --implicit-check-not={{.}} # MULTI:[{"Address":"0x2","Data":{"Name":"d1","Size":"0x8","Start":"0x0"},"ModuleName":"{{.*}}.o"},{"Address":"0x8","Data":{"Name":"d2","Size":"0x4","Start":"0x8"},"ModuleName":"{{.*}}.o"}] d1: .quad 0x1122334455667788 .size d1, 8 d2: .long 0x99aabbcc .size d2, 4