1e95ad93eSminglotus-6; Tests that `llvm-dis` could disassemble ThinLTO minimized bitcode 2e95ad93eSminglotus-6; (e.g., bitcode generated by `opt --thin-link-bitcode-file=<minimized-bitcode>`, 3e95ad93eSminglotus-6; or `clang -Xclang -fthin-link-bitcode=<minimized-bitcode>`) 4e95ad93eSminglotus-6 5e95ad93eSminglotus-6; %t.o is the thin-lto ready bitcode, and %t.thinlink.bc is the minimized bitcode. 6e95ad93eSminglotus-6; RUN: opt -thinlto-bc %s -thin-link-bitcode-file=%t.thinlink.bc -o %t.o 7e95ad93eSminglotus-6 8e95ad93eSminglotus-6; With default options, `llvm-dis` returns invalid record for ThinLTO minimized bitcode. 9e95ad93eSminglotus-6; RUN: not llvm-dis %t.thinlink.bc 2>&1 | FileCheck %s --check-prefix=INVALID-RECORD 10e95ad93eSminglotus-6 11e95ad93eSminglotus-6; INVALID-RECORD: Invalid record 12e95ad93eSminglotus-6 13e95ad93eSminglotus-6; Tests that `llvm-dis` could disassemble minimized bitcode with `--print-thinlto-index-only`, and verify its content. 14e95ad93eSminglotus-6; RUN: llvm-dis --print-thinlto-index-only %t.thinlink.bc -o - | FileCheck %s --check-prefix=DIS 15e95ad93eSminglotus-6 16e95ad93eSminglotus-6; Tests that `llvm-dis` could disassemble ThinLTO-ready bitcode with `--print-thinlto-index-only`, 17e95ad93eSminglotus-6; and verify its content. 18e95ad93eSminglotus-6; RUN: llvm-dis --print-thinlto-index-only %t.o -o - | FileCheck %s --check-prefix=DIS 19e95ad93eSminglotus-6 20e95ad93eSminglotus-6; DIS: ^0 = module: (path: "{{.*}}thinlto-index-disassembled-by-llvm-dis.ll.tmp 21*dda73336SMingming Liu; DIS: ^1 = gv: (name: "aplusb", summaries: (function: (module: ^0, flags: (linkage: external, visibility: default, notEligibleToImport: 0, live: 0, dsoLocal: 0, canAutoHide: 0, importType: definition), insts: 2))) ; guid = 22e95ad93eSminglotus-6 23e95ad93eSminglotus-6source_filename = "add.cpp" 24e95ad93eSminglotus-6target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128" 25e95ad93eSminglotus-6target triple = "x86_64-unknown-linux-gnu" 26e95ad93eSminglotus-6define i32 @aplusb(i32 %a, i32 %b) { 27e95ad93eSminglotus-6 %add = add i32 %b, %a 28e95ad93eSminglotus-6 ret i32 %add 29e95ad93eSminglotus-6} 30