================
@@ -43,13 +44,55 @@ static StringRef getImageName(const OffloadBinary &OB) {
}
}
-static void printBinary(const OffloadBinary &OB, uint64_t Index) {
- outs() << "\nOFFLOADING IMAGE [" << Index << "]:\n";
- outs() << left_justify("kind", 16) << getImageName(OB) << "\n";
- outs() << left_justify("arch", 16) << OB.getArch() << "\n";
- outs() << left_justify("triple", 16) << OB.getTriple() << "\n";
- outs() << left_justify("producer", 16)
- << getOffloadKindName(OB.getOffloadKind()) << "\n";
+/// Print metadata from an OffloadBinary.
+static void printOffloadBinaryMetadata(const OffloadBinary &OB,
+ uint64_t level) {
+ outs().indent(level * 2) << left_justify("kind", 16) << getImageName(OB)
+ << "\n";
+ outs().indent(level * 2) << left_justify("arch", 16) << OB.getArch() << "\n";
+ outs().indent(level * 2) << left_justify("triple", 16) << OB.getTriple()
+ << "\n";
+ outs().indent(level * 2) << left_justify("producer", 16)
+ << getOffloadKindName(OB.getOffloadKind()) << "\n";
+
+ StringRef InnerImage = OB.getImage();
+ outs().indent(level * 2) << left_justify("image size", 16)
+ << InnerImage.size() << " bytes\n";
+}
+
+static void printBinary(const OffloadBinary &OB, uint64_t Index,
+ uint64_t Level = 0, std::string ParentIndex = "") {
+ outs() << "\n";
+ outs().indent(Level * 2) << "OFFLOADING IMAGE [" << ParentIndex << Index
+ << "]:\n";
+
+ printOffloadBinaryMetadata(OB, Level);
+
+ StringRef ImageData = OB.getImage();
+ if (identify_magic(ImageData) != file_magic::offload_binary)
+ return;
+
+ MemoryBufferRef InnerBuffer(ImageData, "inner-offload-binary");
+ SmallVector<OffloadFile> InnerBinaries;
+ auto Err = extractOffloadBinaries(InnerBuffer, InnerBinaries);
----------------
jh7370 wrote:
Nit: too much `auto`: this isn't one of the cases where `auto` aids readability.
https://github.com/llvm/llvm-project/pull/185425
_______________________________________________
cfe-commits mailing list
[email protected]
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits