From 414fa87d30810b0e8bff4b6c1b4211d31b8c065e Mon Sep 17 00:00:00 2001 From: Eric Beckmann Date: Tue, 13 Jun 2017 00:16:32 +0000 Subject: [PATCH] Update the test framework for llvm-cvtres to be more comprehensive. Summary: Added test cases for multiple machine types, file merging, multiple languages, and more resource types. Also fixed new bugs these tests exposed. Subscribers: javed.absar, llvm-commits, hiraditya Differential Revision: https://reviews.llvm.org/D34047 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@305258 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/llvm/Object/WindowsResource.h | 10 +- lib/Object/WindowsResource.cpp | 36 ++- test/tools/llvm-cvtres/Inputs/combined.obj.coff | Bin 0 -> 4040 bytes test/tools/llvm-cvtres/Inputs/languages.rc | 36 +++ test/tools/llvm-cvtres/Inputs/languages.res | Bin 0 -> 452 bytes .../llvm-cvtres/Inputs/test_resource.obj.coff.arm | Bin 0 -> 3472 bytes .../llvm-cvtres/Inputs/test_resource.obj.coff.x64 | Bin 0 -> 3472 bytes test/tools/llvm-cvtres/basic.test | 4 - test/tools/llvm-cvtres/combined.test | 313 +++++++++++++++++++++ test/tools/llvm-cvtres/help.test | 13 + test/tools/llvm-cvtres/machine.test | 59 ++++ test/tools/llvm-cvtres/object.test | 225 ++++++++------- test/tools/llvm-cvtres/parse.test | 2 +- test/tools/llvm-readobj/resources.test | 230 ++++++++------- tools/llvm-readobj/COFFDumper.cpp | 45 ++- 15 files changed, 748 insertions(+), 225 deletions(-) create mode 100644 test/tools/llvm-cvtres/Inputs/combined.obj.coff create mode 100644 test/tools/llvm-cvtres/Inputs/languages.rc create mode 100644 test/tools/llvm-cvtres/Inputs/languages.res create mode 100644 test/tools/llvm-cvtres/Inputs/test_resource.obj.coff.arm create mode 100644 test/tools/llvm-cvtres/Inputs/test_resource.obj.coff.x64 delete mode 100644 test/tools/llvm-cvtres/basic.test create mode 100644 test/tools/llvm-cvtres/combined.test create mode 100644 test/tools/llvm-cvtres/help.test create mode 100644 test/tools/llvm-cvtres/machine.test diff --git a/include/llvm/Object/WindowsResource.h b/include/llvm/Object/WindowsResource.h index c5189329d3e..33f396cc6f2 100644 --- a/include/llvm/Object/WindowsResource.h +++ b/include/llvm/Object/WindowsResource.h @@ -159,14 +159,16 @@ public: TreeNode(uint16_t MajorVersion, uint16_t MinorVersion, uint32_t Characteristics); - void addEntry(const ResourceEntryRef &Entry); - TreeNode &addTypeNode(const ResourceEntryRef &Entry); - TreeNode &addNameNode(const ResourceEntryRef &Entry); + void addEntry(const ResourceEntryRef &Entry, bool &IsNewTypeString, + bool &IsNewNameString); + TreeNode &addTypeNode(const ResourceEntryRef &Entry, bool &IsNewTypeString); + TreeNode &addNameNode(const ResourceEntryRef &Entry, bool &IsNewNameString); TreeNode &addLanguageNode(const ResourceEntryRef &Entry); TreeNode &addChild(uint32_t ID, bool IsDataNode = false, uint16_t MajorVersion = 0, uint16_t MinorVersion = 0, uint32_t Characteristics = 0); - TreeNode &addChild(ArrayRef NameRef); + TreeNode &addChild(ArrayRef NameRef, bool &IsNewString); + bool IsDataNode = false; uint32_t StringIndex; uint32_t DataIndex; diff --git a/lib/Object/WindowsResource.cpp b/lib/Object/WindowsResource.cpp index 3a1ed9a907a..a7e126da52a 100644 --- a/lib/Object/WindowsResource.cpp +++ b/lib/Object/WindowsResource.cpp @@ -133,17 +133,19 @@ Error WindowsResourceParser::parse(WindowsResource *WR) { ResourceEntryRef Entry = EntryOrErr.get(); bool End = false; while (!End) { - Data.push_back(Entry.getData()); - if (Entry.checkTypeString()) + bool IsNewTypeString = false; + bool IsNewNameString = false; + + Root.addEntry(Entry, IsNewTypeString, IsNewNameString); + + if (IsNewTypeString) StringTable.push_back(Entry.getTypeString()); - if (Entry.checkNameString()) + if (IsNewNameString) StringTable.push_back(Entry.getNameString()); - Root.addEntry(Entry); - RETURN_IF_ERROR(Entry.moveNext(End)); } @@ -155,9 +157,11 @@ void WindowsResourceParser::printTree() const { Root.print(Writer, "Resource Tree"); } -void WindowsResourceParser::TreeNode::addEntry(const ResourceEntryRef &Entry) { - TreeNode &TypeNode = addTypeNode(Entry); - TreeNode &NameNode = TypeNode.addNameNode(Entry); +void WindowsResourceParser::TreeNode::addEntry(const ResourceEntryRef &Entry, + bool &IsNewTypeString, + bool &IsNewNameString) { + TreeNode &TypeNode = addTypeNode(Entry, IsNewTypeString); + TreeNode &NameNode = TypeNode.addNameNode(Entry, IsNewNameString); NameNode.addLanguageNode(Entry); } @@ -171,7 +175,6 @@ WindowsResourceParser::TreeNode::TreeNode(uint16_t MajorVersion, uint32_t Characteristics) : IsDataNode(true), MajorVersion(MajorVersion), MinorVersion(MinorVersion), Characteristics(Characteristics) { - if (IsDataNode) DataIndex = DataCount++; } @@ -194,17 +197,19 @@ WindowsResourceParser::TreeNode::createDataNode(uint16_t MajorVersion, } WindowsResourceParser::TreeNode & -WindowsResourceParser::TreeNode::addTypeNode(const ResourceEntryRef &Entry) { +WindowsResourceParser::TreeNode::addTypeNode(const ResourceEntryRef &Entry, + bool &IsNewTypeString) { if (Entry.checkTypeString()) - return addChild(Entry.getTypeString()); + return addChild(Entry.getTypeString(), IsNewTypeString); else return addChild(Entry.getTypeID()); } WindowsResourceParser::TreeNode & -WindowsResourceParser::TreeNode::addNameNode(const ResourceEntryRef &Entry) { +WindowsResourceParser::TreeNode::addNameNode(const ResourceEntryRef &Entry, + bool &IsNewNameString) { if (Entry.checkNameString()) - return addChild(Entry.getNameString()); + return addChild(Entry.getNameString(), IsNewNameString); else return addChild(Entry.getNameID()); } @@ -232,7 +237,8 @@ WindowsResourceParser::TreeNode &WindowsResourceParser::TreeNode::addChild( } WindowsResourceParser::TreeNode & -WindowsResourceParser::TreeNode::addChild(ArrayRef NameRef) { +WindowsResourceParser::TreeNode::addChild(ArrayRef NameRef, + bool &IsNewString) { std::string NameString; ArrayRef CorrectedName; std::vector EndianCorrectedName; @@ -248,6 +254,7 @@ WindowsResourceParser::TreeNode::addChild(ArrayRef NameRef) { auto Child = StringChildren.find(NameString); if (Child == StringChildren.end()) { auto NewChild = createStringNode(); + IsNewString = true; WindowsResourceParser::TreeNode &Node = *NewChild; StringChildren.emplace(NameString, std::move(NewChild)); return Node; @@ -296,7 +303,6 @@ class WindowsResourceCOFFWriter { public: WindowsResourceCOFFWriter(StringRef OutputFile, Machine MachineType, const WindowsResourceParser &Parser, Error &E); - Error write(); private: diff --git a/test/tools/llvm-cvtres/Inputs/combined.obj.coff b/test/tools/llvm-cvtres/Inputs/combined.obj.coff new file mode 100644 index 0000000000000000000000000000000000000000..bbb670b258e7d0f4228d78a56f37e4a30331a0f0 GIT binary patch literal 4040 zcmd5f{q8J}-9>h7|J1X0 z_MY>d@7(vyy*G!8rIGH{TkZ3R7Lg&G$tf15^9C1hzxW4x4c-p*M>ePf()jPc@N{E6p%24<|W=c}SewTq5I(XqoV z$g(|Cap-PQ)>M0mAQ$OEk*JzHq8f#(iK_M?Xo~J}hz1|U58*N6LDy(L_fta47H#Rm zGh%bq(u(SvXNcY~@HyA@Uq1Q3_S!cIORB%PIp8Du1Nck?r4qLQYLu!Sin~yfMW;zA z+-`CxE*HvuYr!mx5r%3^=1~H*2t*qsheuHrm&PaAmh%~#^K4nUR7Yr0PNmpR4IkNwKGxlULa@6t`QKC9TZ9Im4c( zC?%?WLoU>0iz(S`N_mrU&;fh4qG|=H7P}XZqg2CSnpl-#!qE(hi>2~3qH=VR3Xroo z^&)4}U4wi!@^i=&khdd8HX&>-79+kl3}NL!dLTLQyn~g#1SpGMLURnS4c?9LtVJ{{mqoJrY)15ZM%k=h zA~xQbCW13bM+}3Yc;cH7=dE zXy`G~?qboxtHqLqFO!msn667H+ofdQDFW6l+jYwd-XN7pmR+J`fewc#r?|z5LePRt z311~i)p${o`Q5tf=Z2CJ3Eyx&9qlMpWIj{SM0o}8ltf;Z9L1W-7m7|%*F-J281yif zdaxGfVn%ZCJ{+Wl^aFZ19iD``+4!)Bqp?+o_*M)gd&b58f5`s*`}geG+9#WprJqS)^4?#|B6 z>gwtM|M20%m6erY%zzna#{K*E@7=rC)6>({)z#9{a`foYXOaOnH#ejF-rio2A3l6| z?b@}ICr?gC27dA4#i600zP`Tx{{9;`Zk#%GDgqg@Lsuc z1^ipLZk<1WJ}Mc6*4EZLckW!ieEE6E;Iy^1UA=nsImw`*k5S1l^m`Ju_5Y1f|9d0% zZDLpw+Lh@_1Cu&dF7~bWJ?;E-un9U6z)1YN`Hx4R`u^$}^^aB#eoc4tqwpV;`bPTb zLFtykFGu`;=MOYQ;rG|jc=~Ag*HOPe3V-N(3QDyjT~YWWJ_=0{_@8xt1#ei2FrL$m z+l!0`_6sMKk#49WsZ>k?&Nl+=a&plQXbSwyX7Xb>`;WniAc5Lw1@#R>g r5lf1hj|(YzmBpGJABwE9dc%+`Yi}rGHJjOiF{sVfm1gqvShp>){E?nGIy#CkzV$ysQ)109Fq z0*Kbk0v4i+?Prb0V}F_l0Hg}xM;iVcXL{@|l#R z%hJ7dNs-e`JQZ_FtheMd>nUgJN^*r(x)d*``^O)jz;Gi@b0>1v85=4yF|?9yTE~_2 z7Sg4JHC>rSW!m&zv=Z~kVl>tZcDE>iu8OhiKrv R0qm*!V|DxqM|j-=z5t?pVOszI literal 0 HcmV?d00001 diff --git a/test/tools/llvm-cvtres/Inputs/test_resource.obj.coff.arm b/test/tools/llvm-cvtres/Inputs/test_resource.obj.coff.arm new file mode 100644 index 0000000000000000000000000000000000000000..ca2f9a4fd04e46fcc3a6829aec59f56f0837cd69 GIT binary patch literal 3472 zcmd5o3(xDi?omQz2{2e zNBszcWEu%0k_;TnSQHaSvc<14%}mgcxn%4Q!%P>QjIR(rGDn7vjqZ2e18h5J-Ts-U z_x7IiJHK=8efPfh-rFuD(TgQ3O3I!lN+UxAt4G?Y@5(4NO`>vv=!0ovs?DRcbymOX zcW2nLrd=m2M1L|j*+f#%e9MTe;5f7 z{R%tC=n=` zc33EACko;LsQ@jnM>*PgXiuPBfc6YpG&90;9Y9=149+>00sk3z4%!DXegUgg1UyZk z;0|<}i54L z#*5uC3(o!iI0rs32mW9RUmZ18%tul*5Nq3_-DHii%VKQ)T|`Qxy_mL839Y4kd^XT# zR0pgg+KRT2<^wG@G`5q0z6oy$-uogj3-P_4HUZfT&l@z4mICGIrL@rSI^cZ^p0$YP zyd25>IgIG7MsDtxi06p^Gc3fb#BZC0cwJHrjc0tJq46B^+FOWcZ;_#0g0|Sus-Qh% zXz7$h{g}r^7~y8D&0%_$zJ@mw-n6MI82=bBz-vbWuG13!Kjh%SgZuXF3j_kXuE**B z&lu8XD^B>k(2_RR!|Jix>Cr-ybJ`Q&ST{YHMrHojZ5` z{{5pzj~+U7C=S25xw)&WtFf`Mv$Jz#WTd91=Gd`gCLe(Z4jhPyZE0yi+TPyY?(Xio zx;m3zU0q#SSsBALO>-Fc?%lh4_ilfGe@{#i%|!-&`SRtlv9Y0{q2b}-n>TNsK7Be48Llf=u8fb5kB*Mwd0Sgsa(MA$JoPJ%bFU05L>{4&0EaMv&eA{g9tR7sy;r?Y??q-Dk~ZTgAQX*)H;SVSAi`rM;^ z(DZvSKG_&C+dKwyP9MWb)(m#5LL}D`*s;;bIzUTR=nj_+0*6cMd*EfrDE|v}8DJhA?Vy$V9U2d^(CiR^-_7U`8Ohx%S=jqmkA2 b`e)od`Q-XT~mx zkM$9XNi`ZvBq>-LX%G`j(#BV*rX)Z}ZBqKfP_vCzib4#J)RLm5W&52Oz}+qE+Wx6$ z@7;UOcfND(Yj*D)Z{aEQ^sVQM`>&9e$DS$ z;>etG9Zw?qlex(jl7c1=Ws;XQ&3lIEr%BEf#yp08Lp2lTuab&2*{?~mr&RXrtZ@5$ z(puGHRLDMElXO|r-}B3wYWO{}9SY|eMO}o7AyAqy|6Aj`kKT2?_(kgCnlnEPhlqX! zo&u+ngmkF%Z@N(Jf!rK=gk6r! zUP~v>``-9HksOejQQ%j%``s1d8%nvXi5UTB?lS3d+AWG^xXZ;t-S8@^l;y}=A?2$T z6^2jIE2S;@Qjw~bYtp7dsF^wTOou&dIde)CpR``p^sTu$5@sNIcI#LzJ9il+0wvS7 zBnmo-f|wu`pymD8g?0|w<7nrhJ&P92wD4L75Z4uhbB?9Je+Hg|_F;@)z%CU5PZKD( z4V`A7MaZ;p-q+#J`v)!%b|APFI38JkHiOearXtWh47{2XM2Ush&Vrwv2}cK)XTX#3 zV0X=cbH6{%f)C7sKb*u@MvWEgVT%T0ZAY}5>@jwEjLpA`NQtx;(k3dQ)s&CVI@*Zp zf>lJD(H7ENpv9)fb~4bn;4Q&(Uj$|$zSq(QARFO%ljhK3pd7uJ=9^v@yl=y^8qu7W zBe_498NJ!e&HWPb8u5RIjd+*%X|oaUORA~yiqAJSUSr;S8}aHbFty9j7MfZ$wC7AM z9gKdg;{uFuBlhMXJx^c5n*ndyWEISR43kdnNWgVU!vBZt-@kv)o;`s;z%YzB{hvB@ z%JLpMbm-ibEva&KxNL^iBZEY<=s;jF(zI5r*-o1O{CdBzP`J=dw6*G#EBC}j~=!72;8@CUrcOsb2HN3y?eK}x3{LI z#^N72a-^!NDu!v9)-dkexpVvW?f(A$zP`TJ*4AUkj?G90c;UhY+033V`F0@BO{n^OG`_9GQ4eVZQ$Ry zapU5}iwVgfw70k4ym|B5wQEm82B)j5tD~di3CW;gjtR+6_3tF%=>Hp`;g@FN%SAE8 z-L1}+4NU6Eekrse^r-jakrwDE0ORp*75_f*DD+4FM0lcV`G*vzr`+g!EPQV}iiXuwgcwYkkc!;7)9R4T0XW@-0an^ITb$gm| z>%8z%B^jnFlSVtpP35S3?J1+3&{X)@X89(_-$^*xQmKnx#+gJoF*#0$CQwoVBkaA0 zQ%#_7_#jSUm3;6k_%^^@#T1BOa@SB5eTtJV3EUtpHBV{FPn1qusS(BkT2J;D9-o7j z-;41n=7`zmF<2w_!s4-e(VGV|Akudznuy{S4cyE{uUw}1WUn}N4JSnxJ*rQ4D?Uxc zeZ5lDbid-;Zr;r~cb-SB*kxC|t?n>J$>(=one5i>4hLVyEhO^YgO|l7@Y_eUM80?M zJ<}%en+M+<9!umq2VbSY!CObPEO9wZVbtW1g=9MUb`*hR=Q#3UMj*Ml&K+~3k(JKc aXk>-MnSwqeqE=)%#293`qhK20ar_N2mTfcu literal 0 HcmV?d00001 diff --git a/test/tools/llvm-cvtres/basic.test b/test/tools/llvm-cvtres/basic.test deleted file mode 100644 index fcebef22f65..00000000000 --- a/test/tools/llvm-cvtres/basic.test +++ /dev/null @@ -1,4 +0,0 @@ -; RUN: llvm-cvtres /h > %t -; RUN: FileCheck -input-file=%t %s -check-prefix=HELP_TEST - -; HELP_TEST: OVERVIEW: Resource Converter diff --git a/test/tools/llvm-cvtres/combined.test b/test/tools/llvm-cvtres/combined.test new file mode 100644 index 00000000000..bb3b4dbc736 --- /dev/null +++ b/test/tools/llvm-cvtres/combined.test @@ -0,0 +1,313 @@ +// Check that cvtres properly handles merging multiple .res files. +// The inputs were generated with the following commands, using the original Windows +// rc.exe: +// > rc /fo test_resource.res /nologo test_resource.rc +// > rc /fo languages.res /nologo languages.rc +// The object file we are comparing against was generated with this command using +// the original Windows cvtres.exe. +// > cvtres /machine:X86 /readonly /nologo /out:combined.obj.coff \ +// languages.res test_resource.res + +RUN: llvm-cvtres /out:%t %p/Inputs/languages.res %p/Inputs/test_resource.res +RUN: llvm-readobj -coff-resources -section-data %t | FileCheck %s + +CHECK: Resources [ +CHECK-NEXT: Total Number of Resources: 12 +CHECK-DAG: Number of String Entries: 1 +CHECK-NEXT: Number of ID Entries: 5 +CHECK-NEXT: Type: STRINGARRAY [ +CHECK-NEXT: Table Offset: 0x40 +CHECK-NEXT: Number of String Entries: 1 +CHECK-NEXT: Number of ID Entries: 0 +CHECK-NEXT: Name: MYRESOURCE [ +CHECK-NEXT: Table Offset: 0xE8 +CHECK-NEXT: Number of String Entries: 0 +CHECK-NEXT: Number of ID Entries: 1 +CHECK-NEXT: Language: (ID 1033) [ +CHECK-NEXT: Entry Offset: 0x1D8 +CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +CHECK-NEXT: Major Version: 0 +CHECK-NEXT: Minor Version: 0 +CHECK-NEXT: Characteristics: 0 +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-NEXT: Type: kRT_BITMAP (ID 2) [ +CHECK-NEXT: Table Offset: 0x58 +CHECK-NEXT: Number of String Entries: 2 +CHECK-NEXT: Number of ID Entries: 0 +CHECK-NEXT: Name: CURSOR [ +CHECK-NEXT: Table Offset: 0x100 +CHECK-NEXT: Number of String Entries: 0 +CHECK-NEXT: Number of ID Entries: 1 +CHECK-NEXT: Language: (ID 1033) [ +CHECK-NEXT: Entry Offset: 0x1E8 +CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +CHECK-NEXT: Major Version: 0 +CHECK-NEXT: Minor Version: 0 +CHECK-NEXT: Characteristics: 0 +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-NEXT: Name: OKAY [ +CHECK-NEXT: Table Offset: 0x118 +CHECK-NEXT: Number of String Entries: 0 +CHECK-NEXT: Number of ID Entries: 1 +CHECK-NEXT: Language: (ID 1033) [ +CHECK-NEXT: Entry Offset: 0x1F8 +CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +CHECK-NEXT: Major Version: 0 +CHECK-NEXT: Minor Version: 0 +CHECK-NEXT: Characteristics: 0 +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-NEXT: Type: kRT_MENU (ID 4) [ +CHECK-NEXT: Table Offset: 0x78 +CHECK-NEXT: Number of String Entries: 1 +CHECK-NEXT: Number of ID Entries: 1 +CHECK-NEXT: Name: "EAT" [ +CHECK-NEXT: Table Offset: 0x130 +CHECK-NEXT: Number of String Entries: 0 +CHECK-NEXT: Number of ID Entries: 1 +CHECK-NEXT: Language: (ID 3081) [ +CHECK-NEXT: Entry Offset: 0x208 +CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +CHECK-NEXT: Major Version: 0 +CHECK-NEXT: Minor Version: 0 +CHECK-NEXT: Characteristics: 0 +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-NEXT: Name: (ID 14432) [ +CHECK-NEXT: Table Offset: 0x148 +CHECK-NEXT: Number of String Entries: 0 +CHECK-NEXT: Number of ID Entries: 1 +CHECK-NEXT: Language: (ID 2052) [ +CHECK-NEXT: Entry Offset: 0x218 +CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +CHECK-NEXT: Major Version: 0 +CHECK-NEXT: Minor Version: 0 +CHECK-NEXT: Characteristics: 0 +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-NEXT: Type: kRT_DIALOG (ID 5) [ +CHECK-NEXT: Table Offset: 0x98 +CHECK-NEXT: Number of String Entries: 1 +CHECK-NEXT: Number of ID Entries: 0 +CHECK-NEXT: Name: TESTDIALOG [ +CHECK-NEXT: Table Offset: 0x160 +CHECK-NEXT: Number of String Entries: 0 +CHECK-NEXT: Number of ID Entries: 1 +CHECK-NEXT: Language: (ID 1033) [ +CHECK-NEXT: Entry Offset: 0x228 +CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +CHECK-NEXT: Major Version: 0 +CHECK-NEXT: Minor Version: 0 +CHECK-NEXT: Characteristics: 0 +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-NEXT: Type: kRT_ACCELERATOR (ID 9) [ +CHECK-NEXT: Table Offset: 0xB0 +CHECK-NEXT: Number of String Entries: 1 +CHECK-NEXT: Number of ID Entries: 1 +CHECK-NEXT: Name: MYACCELERATORS [ +CHECK-NEXT: Table Offset: 0x178 +CHECK-NEXT: Number of String Entries: 0 +CHECK-NEXT: Number of ID Entries: 2 +CHECK-NEXT: Language: (ID 1033) [ +CHECK-NEXT: Entry Offset: 0x238 +CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +CHECK-NEXT: Major Version: 0 +CHECK-NEXT: Minor Version: 0 +CHECK-NEXT: Characteristics: 0 +CHECK-NEXT: ] +CHECK-NEXT: Language: (ID 2052) [ +CHECK-NEXT: Entry Offset: 0x248 +CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +CHECK-NEXT: Major Version: 0 +CHECK-NEXT: Minor Version: 0 +CHECK-NEXT: Characteristics: 0 +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-NEXT: Name: (ID 12) [ +CHECK-NEXT: Table Offset: 0x198 +CHECK-NEXT: Number of String Entries: 0 +CHECK-NEXT: Number of ID Entries: 1 +CHECK-NEXT: Language: (ID 1033) [ +CHECK-NEXT: Entry Offset: 0x258 +CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +CHECK-NEXT: Major Version: 0 +CHECK-NEXT: Minor Version: 0 +CHECK-NEXT: Characteristics: 0 +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-NEXT: Type: kRT_RCDATA (ID 10) [ +CHECK-NEXT: Table Offset: 0xD0 +CHECK-NEXT: Number of String Entries: 1 +CHECK-NEXT: Number of ID Entries: 0 +CHECK-NEXT: Name: RANDOMDAT [ +CHECK-NEXT: Table Offset: 0x1B0 +CHECK-NEXT: Number of String Entries: 0 +CHECK-NEXT: Number of ID Entries: 3 +CHECK-NEXT: Language: (ID 1033) [ +CHECK-NEXT: Entry Offset: 0x268 +CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +CHECK-NEXT: Major Version: 0 +CHECK-NEXT: Minor Version: 0 +CHECK-NEXT: Characteristics: 0 +CHECK-NEXT: ] +CHECK-NEXT: Language: (ID 2052) [ +CHECK-NEXT: Entry Offset: 0x278 +CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +CHECK-NEXT: Major Version: 0 +CHECK-NEXT: Minor Version: 0 +CHECK-NEXT: Characteristics: 0 +CHECK-NEXT: ] +CHECK-NEXT: Language: (ID 4103) [ +CHECK-NEXT: Entry Offset: 0x288 +CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +CHECK-NEXT: Major Version: 0 +CHECK-NEXT: Minor Version: 0 +CHECK-NEXT: Characteristics: 0 +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-DAG: .rsrc$02 Data ( +CHECK-NEXT: 0000: 74686973 20697320 61207261 6E646F6D |this is a random| +CHECK-NEXT: 0010: 20626974 206F6620 64617461 20746861 | bit of data tha| +CHECK-NEXT: 0020: 74206D65 616E7320 6E6F7468 696E6700 |t means nothing.| +CHECK-NEXT: 0030: A9230E14 F4F60000 7A686534 20736869 |.#......zhe4 shi| +CHECK-NEXT: 0040: 34207969 31676534 20737569 326A6931 |4 yi1ge4 sui2ji1| +CHECK-NEXT: 0050: 20646520 73687534 6A75342C 207A6865 | de shu4ju4, zhe| +CHECK-NEXT: 0060: 34207969 34776569 347A6865 20736865 |4 yi4wei4zhe she| +CHECK-NEXT: 0070: 6E326D65 00A9230E 14F4F600 00000000 |n2me..#.........| +CHECK-NEXT: 0080: 44696573 20697374 2065696E 207A7566 |Dies ist ein zuf| +CHECK-NEXT: 0090: C3A46C6C 69676573 20426974 20766F6E |..lliges Bit von| +CHECK-NEXT: 00A0: 20446174 656E2C20 64696520 6E696368 | Daten, die nich| +CHECK-NEXT: 00B0: 74732062 65646575 74657400 A9230E14 |ts bedeutet..#..| +CHECK-NEXT: 00C0: F4F60000 00000000 11000300 E7030000 |................| +CHECK-NEXT: 00D0: 0D004400 4C040000 82001200 BC010000 |..D.L...........| +CHECK-NEXT: 00E0: 11000300 E7030000 0D004400 4C040000 |..........D.L...| +CHECK-NEXT: 00F0: 82001200 BC010000 28000000 10000000 |........(.......| +CHECK-NEXT: 0100: 10000000 01001800 00000000 00030000 |................| +CHECK-NEXT: 0110: C40E0000 C40E0000 00000000 00000000 |................| +CHECK-NEXT: 0120: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0130: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0140: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0150: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0160: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0170: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0180: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0190: FFFFFFFF FF7F7F7F 7C7C7C78 78787575 |........|||xxxuu| +CHECK-NEXT: 01A0: 75FFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |u...............| +CHECK-NEXT: 01B0: FFFFFFFF FFFFFFFF FFFFFFFF 979797FF |................| +CHECK-NEXT: 01C0: FFFFFFFF FF838383 AAAAAADB DBDB7979 |..............yy| +CHECK-NEXT: 01D0: 79757575 FFFFFFFF FFFFFFFF FFFFFFFF |yuuu............| +CHECK-NEXT: 01E0: FFFFFFFF FFFFFFFF FFFFFFFF 9C9C9C98 |................| +CHECK-NEXT: 01F0: 9898FFFF FF888888 DBDBDBB7 B7B77D7D |..............}}| +CHECK-NEXT: 0200: 7DFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |}...............| +CHECK-NEXT: 0210: FFFFFFFF FFFFFFFF FFFFFFFF A0A0A09C |................| +CHECK-NEXT: 0220: 9C9C9393 93ADADAD F2F2F284 84848181 |................| +CHECK-NEXT: 0230: 81FFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0240: FFFFFFFF FFFFFFFF FFFFFFFF A4A4A4D7 |................| +CHECK-NEXT: 0250: D7D79D9D 9DD0D0D0 EEEEEE91 91918D8D |................| +CHECK-NEXT: 0260: 8DFFFFFF FFFFFF81 81817E7E 7EFFFFFF |..........~~~...| +CHECK-NEXT: 0270: FFFFFFFF FFFFFFFF FFFFFFFF A9A9A9F2 |................| +CHECK-NEXT: 0280: F2F2E5E5 E5E2E2E2 95959591 91918D8D |................| +CHECK-NEXT: 0290: 8D898989 868686FF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 02A0: FFFFFFFF FFFFFFFF FFFFFFFF ADADADF2 |................| +CHECK-NEXT: 02B0: F2F2E1E1 E1DFDFDF E7E7E7E4 E4E4BBBB |................| +CHECK-NEXT: 02C0: BB8E8E8E FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 02D0: FFFFFFFF FFFFFFFF FFFFFFFF B5B5B5F2 |................| +CHECK-NEXT: 02E0: F2F2E8E8 E8E7E7E7 EAEAEAC6 C6C69E9E |................| +CHECK-NEXT: 02F0: 9EFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0300: FFFFFFFF FFFFFFFF FFFFFFFF B9B9B9F4 |................| +CHECK-NEXT: 0310: F4F4ECEC ECEDEDED CBCBCBA7 A7A7FFFF |................| +CHECK-NEXT: 0320: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0330: FFFFFFFF FFFFFFFF FFFFFFFF BDBDBDF7 |................| +CHECK-NEXT: 0340: F7F7EFEF EFD0D0D0 AFAFAFFF FFFFFFFF |................| +CHECK-NEXT: 0350: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0360: FFFFFFFF FFFFFFFF FFFFFFFF C1C1C1F7 |................| +CHECK-NEXT: 0370: F7F7D5D5 D5B6B6B6 FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0380: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0390: FFFFFFFF FFFFFFFF FFFFFFFF C4C4C4D9 |................| +CHECK-NEXT: 03A0: D9D9BEBE BEFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 03B0: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 03C0: FFFFFFFF FFFFFFFF FFFFFFFF C8C8C8C5 |................| +CHECK-NEXT: 03D0: C5C5FFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 03E0: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 03F0: FFFFFFFF FFFFFFFF FFFFFFFF CBCBCBFF |................| +CHECK-NEXT: 0400: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0410: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0420: 28000000 10000000 10000000 01001800 |(...............| +CHECK-NEXT: 0430: 00000000 00030000 C40E0000 C40E0000 |................| +CHECK-NEXT: 0440: 00000000 00000000 FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0450: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0460: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0470: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0480: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0490: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 04A0: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 04B0: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 04C0: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 04D0: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 04E0: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 04F0: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0500: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0510: FFFFFFFF A0E3A901 B31801B3 1801B318 |................| +CHECK-NEXT: 0520: 01B31801 B31801B3 1861D06F FFFFFFFF |.........a.o....| +CHECK-NEXT: 0530: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0540: FFFFFFFF 01B31800 D7331CDB 49DBF9E2 |.........3..I...| +CHECK-NEXT: 0550: 9BEFAF00 D73300D7 3301B318 FFFFFFFF |.....3..3.......| +CHECK-NEXT: 0560: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0570: FFFFFFFF 01B31800 DE55F6FE F9DBFAE7 |.........U......| +CHECK-NEXT: 0580: FEFFFE86 EFAE00DE 5501B318 FFFFFFFF |........U.......| +CHECK-NEXT: 0590: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 05A0: FFFFFFFF 01B31800 E676DBFB EC00E676 |.........v.....v| +CHECK-NEXT: 05B0: 57EFA5FB FFFD55EE A401B318 FFFFFFFF |W.....U.........| +CHECK-NEXT: 05C0: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 05D0: FFFFFFFF 01B31800 ED9800ED 9800ED98 |................| +CHECK-NEXT: 05E0: 00ED9887 F7CFFEFF FF01B318 FFFFFFFF |................| +CHECK-NEXT: 05F0: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0600: FFFFFFFF 01B31800 F4BA00F4 BA00F4BA |................| +CHECK-NEXT: 0610: 00F4BA00 F4BA9CFB E401B318 FFFFFFFF |................| +CHECK-NEXT: 0620: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0630: FFFFFFFF 01B31800 FBDB00FB DB00FBDB |................| +CHECK-NEXT: 0640: 00FBDB00 FBDB00FB DB01B318 FFFFFFFF |................| +CHECK-NEXT: 0650: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0660: FFFFFFFF 9FE2A801 B31801B3 1801B318 |................| +CHECK-NEXT: 0670: 01B31801 B31801B3 1861D06F FFFFFFFF |.........a.o....| +CHECK-NEXT: 0680: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0690: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 06A0: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 06B0: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 06C0: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 06D0: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 06E0: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 06F0: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0700: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0710: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0720: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0730: FFFFFFFF FFFFFFFF FFFFFFFF FFFFFFFF |................| +CHECK-NEXT: 0740: FFFFFFFF FFFFFFFF 00000000 00006400 |..............d.| +CHECK-NEXT: 0750: 79007500 00000000 65007300 68006100 |y.u.....e.s.h.a.| +CHECK-NEXT: 0760: 6C006100 00008000 66006B00 61006F00 |l.a.....f.k.a.o.| +CHECK-NEXT: 0770: 79006100 00000000 0000C080 00000000 |y.a.............| +CHECK-NEXT: 0780: 02000A00 0A00C800 2C010000 00005400 |........,.....T.| +CHECK-NEXT: 0790: 65007300 74000000 01000250 00000000 |e.s.t......P....| +CHECK-NEXT: 07A0: 0A000A00 E6000E00 0100FFFF 82004300 |..............C.| +CHECK-NEXT: 07B0: 6F006E00 74006900 6E007500 65003A00 |o.n.t.i.n.u.e.:.| +CHECK-NEXT: 07C0: 00000000 00000150 00000000 42008600 |.......P....B...| +CHECK-NEXT: 07D0: A1000D00 0200FFFF 80002600 4F004B00 |..........&.O.K.| +CHECK-NEXT: 07E0: 00000000 00000000 11005800 A4000000 |..........X.....| +CHECK-NEXT: 07F0: 0D004800 2E160000 82001200 BC010000 |..H.............| +CHECK-NEXT: 0800: 00000000 00006400 66006900 73006800 |......d.f.i.s.h.| +CHECK-NEXT: 0810: 00000000 65007300 61006C00 61006400 |....e.s.a.l.a.d.| +CHECK-NEXT: 0820: 00008000 66006400 75006300 6B000000 |....f.d.u.c.k...| +CHECK-NEXT: 0830: 74686973 20697320 61207573 65722064 |this is a user d| +CHECK-NEXT: 0840: 6566696E 65642072 65736F75 72636500 |efined resource.| +CHECK-NEXT: 0850: 69742063 6F6E7461 696E7320 6D616E79 |it contains many| +CHECK-NEXT: 0860: 20737472 696E6773 00000000 00000000 | strings........| +CHECK-NEXT: ) diff --git a/test/tools/llvm-cvtres/help.test b/test/tools/llvm-cvtres/help.test new file mode 100644 index 00000000000..ed76e1f126e --- /dev/null +++ b/test/tools/llvm-cvtres/help.test @@ -0,0 +1,13 @@ +; RUN: llvm-cvtres /h > %t +; RUN: FileCheck -input-file=%t %s -check-prefix=HELP_TEST + +; HELP_TEST: OVERVIEW: Resource Converter +; HELP_TEST-DAG: USAGE: cvtres [options] +; HELP_TEST-DAG: OPTIONS: +; HELP_TEST-NEXT: /DEFINE:symbol +; HELP_TEST-NEXT: /FOLDDUPS: +; HELP_TEST-NEXT: /MACHINE:{ARM|EBC|IA64|X64|X86} +; HELP_TEST-DAG: /NOLOGO +; HELP_TEST-NEXT: /OUT:filename +; HELP_TEST-NEXT: /READONLY +; HELP_TEST-NEXT: /VERBOSE diff --git a/test/tools/llvm-cvtres/machine.test b/test/tools/llvm-cvtres/machine.test new file mode 100644 index 00000000000..58096d1d8ed --- /dev/null +++ b/test/tools/llvm-cvtres/machine.test @@ -0,0 +1,59 @@ +// Check that cvtres properly generates COFF for different machine types. The +// only things that changes with machine type are the machine constant listed +// in the COFF header, and the relocation types in the relocation tables. +// The input was generated with the following command, using the original Windows +// rc.exe: +// > rc /fo test_resource.res /nologo test_resource.rc +// The object files we are comparing against were generated with these commands +// using the original Windows cvtres.exe. +// > cvtres /machine:X86 /readonly /nologo /out:test_resource.obj.coff \ +// test_resource.res +// > cvtres /machine:X64 /readonly /nologo /out:test_resource.obj.coff.x64 \ +// test_resource.res +// > cvtres /machine:ARM /readonly /nologo /out:test_resource.obj.coff.x64 \ +// test_resource.res + +RUN: llvm-cvtres /machine:X86 /out:%t %p/Inputs/test_resource.res +RUN: llvm-readobj -h -relocations %t | FileCheck %s -check-prefix=X86 + +RUN: llvm-cvtres /machine:X64 /out:%t %p/Inputs/test_resource.res +RUN: llvm-readobj -h -relocations %t | FileCheck %s -check-prefix=X64 + +RUN: llvm-cvtres /machine:ARM /out:%t %p/Inputs/test_resource.res +RUN: llvm-readobj -h -relocations %t | FileCheck %s -check-prefix=ARM + +X86: Machine: IMAGE_FILE_MACHINE_I386 (0x14C) +X86-DAG: Relocations [ +X86-DAG: .rsrc$01 { +X86-NEXT: 0x1E8 IMAGE_REL_I386_DIR32NB $R000000 +X86-NEXT: 0x198 IMAGE_REL_I386_DIR32NB $R000018 +X86-NEXT: 0x1A8 IMAGE_REL_I386_DIR32NB $R000340 +X86-NEXT: 0x1C8 IMAGE_REL_I386_DIR32NB $R000668 +X86-NEXT: 0x1D8 IMAGE_REL_I386_DIR32NB $R000698 +X86-NEXT: 0x1F8 IMAGE_REL_I386_DIR32NB $R000708 +X86-NEXT: 0x1B8 IMAGE_REL_I386_DIR32NB $R000720 +X86-NEXT: 0x188 IMAGE_REL_I386_DIR32NB $R000750 + +X64: Machine: IMAGE_FILE_MACHINE_AMD64 (0x8664) +X64-DAG: Relocations [ +X64-DAG: .rsrc$01 { +X64-NEXT: 0x1E8 IMAGE_REL_AMD64_ADDR32NB $R000000 +X64-NEXT: 0x198 IMAGE_REL_AMD64_ADDR32NB $R000018 +X64-NEXT: 0x1A8 IMAGE_REL_AMD64_ADDR32NB $R000340 +X64-NEXT: 0x1C8 IMAGE_REL_AMD64_ADDR32NB $R000668 +X64-NEXT: 0x1D8 IMAGE_REL_AMD64_ADDR32NB $R000698 +X64-NEXT: 0x1F8 IMAGE_REL_AMD64_ADDR32NB $R000708 +X64-NEXT: 0x1B8 IMAGE_REL_AMD64_ADDR32NB $R000720 +X64-NEXT: 0x188 IMAGE_REL_AMD64_ADDR32NB $R000750 + +ARM: Machine: IMAGE_FILE_MACHINE_ARMNT (0x1C4) +ARM-DAG: Relocations [ +ARM-DAG: .rsrc$01 { +ARM-NEXT: 0x1E8 IMAGE_REL_ARM_ADDR32NB $R000000 +ARM-NEXT: 0x198 IMAGE_REL_ARM_ADDR32NB $R000018 +ARM-NEXT: 0x1A8 IMAGE_REL_ARM_ADDR32NB $R000340 +ARM-NEXT: 0x1C8 IMAGE_REL_ARM_ADDR32NB $R000668 +ARM-NEXT: 0x1D8 IMAGE_REL_ARM_ADDR32NB $R000698 +ARM-NEXT: 0x1F8 IMAGE_REL_ARM_ADDR32NB $R000708 +ARM-NEXT: 0x1B8 IMAGE_REL_ARM_ADDR32NB $R000720 +ARM-NEXT: 0x188 IMAGE_REL_ARM_ADDR32NB $R000750 diff --git a/test/tools/llvm-cvtres/object.test b/test/tools/llvm-cvtres/object.test index 8117ecc910c..12373e0ac7f 100644 --- a/test/tools/llvm-cvtres/object.test +++ b/test/tools/llvm-cvtres/object.test @@ -3,107 +3,138 @@ // rc.exe: // > rc /fo test_resource.res /nologo test_resource.rc // The object file we are comparing against was generated with this command using -// the original cvtres. -// > cvtres /machine:X86 /readonly /nologo /out:test_resource.o test_resource.res +// the original Windows cvtres.exe. +// > cvtres /machine:X86 /readonly /nologo /out:test_resource.obj.coff \ +// test_resource.res RUN: llvm-cvtres /out:%t %p/Inputs/test_resource.res RUN: llvm-readobj -coff-resources -section-data %t | FileCheck %s -CHECK: Resources [ -CHECK-NEXT: String Name Entries: 1 -CHECK-NEXT: ID Entries: 4 -CHECK-NEXT: Type: STRINGARRAY [ -CHECK-NEXT: String Name Entries: 1 -CHECK-NEXT: ID Entries: 0 -CHECK-NEXT: Name: MYRESOURCE [ -CHECK-NEXT: String Name Entries: 0 -CHECK-NEXT: ID Entries: 1 -CHECK-NEXT: Language: (ID 1033) [ -CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) -CHECK-NEXT: Major Version: 0 -CHECK-NEXT: Minor Version: 0 -CHECK-NEXT: ] -CHECK-NEXT: ] -CHECK-NEXT: ] -CHECK-NEXT: Type: kRT_BITMAP (ID 2) [ -CHECK-NEXT: String Name Entries: 2 -CHECK-NEXT: ID Entries: 0 -CHECK-NEXT: Name: CURSOR [ -CHECK-NEXT: String Name Entries: 0 -CHECK-NEXT: ID Entries: 1 -CHECK-NEXT: Language: (ID 1033) [ -CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) -CHECK-NEXT: Major Version: 0 -CHECK-NEXT: Minor Version: 0 -CHECK-NEXT: ] -CHECK-NEXT: ] -CHECK-NEXT: Name: OKAY [ -CHECK-NEXT: String Name Entries: 0 -CHECK-NEXT: ID Entries: 1 -CHECK-NEXT: Language: (ID 1033) [ -CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) -CHECK-NEXT: Major Version: 0 -CHECK-NEXT: Minor Version: 0 -CHECK-NEXT: ] -CHECK-NEXT: ] -CHECK-NEXT: ] -CHECK-NEXT: Type: kRT_MENU (ID 4) [ -CHECK-NEXT: String Name Entries: 1 -CHECK-NEXT: ID Entries: 1 -CHECK-NEXT: Name: "EAT" [ -CHECK-NEXT: String Name Entries: 0 -CHECK-NEXT: ID Entries: 1 -CHECK-NEXT: Language: (ID 3081) [ -CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) -CHECK-NEXT: Major Version: 0 -CHECK-NEXT: Minor Version: 0 -CHECK-NEXT: ] -CHECK-NEXT: ] -CHECK-NEXT: Name: (ID 14432) [ -CHECK-NEXT: String Name Entries: 0 -CHECK-NEXT: ID Entries: 1 -CHECK-NEXT: Language: (ID 2052) [ -CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) -CHECK-NEXT: Major Version: 0 -CHECK-NEXT: Minor Version: 0 -CHECK-NEXT: ] -CHECK-NEXT: ] -CHECK-NEXT: ] -CHECK-NEXT: Type: kRT_DIALOG (ID 5) [ -CHECK-NEXT: String Name Entries: 1 -CHECK-NEXT: ID Entries: 0 -CHECK-NEXT: Name: TESTDIALOG [ -CHECK-NEXT: String Name Entries: 0 -CHECK-NEXT: ID Entries: 1 -CHECK-NEXT: Language: (ID 1033) [ -CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) -CHECK-NEXT: Major Version: 0 -CHECK-NEXT: Minor Version: 0 -CHECK-NEXT: ] -CHECK-NEXT: ] -CHECK-NEXT: ] -CHECK-NEXT: Type: kRT_ACCELERATOR (ID 9) [ -CHECK-NEXT: String Name Entries: 1 -CHECK-NEXT: ID Entries: 1 -CHECK-NEXT: Name: MYACCELERATORS [ -CHECK-NEXT: String Name Entries: 0 -CHECK-NEXT: ID Entries: 1 -CHECK-NEXT: Language: (ID 1033) [ -CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) -CHECK-NEXT: Major Version: 0 -CHECK-NEXT: Minor Version: 0 -CHECK-NEXT: ] -CHECK-NEXT: ] -CHECK-NEXT: Name: (ID 12) [ -CHECK-NEXT: String Name Entries: 0 -CHECK-NEXT: ID Entries: 1 -CHECK-NEXT: Language: (ID 1033) [ -CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) -CHECK-NEXT: Major Version: 0 -CHECK-NEXT: Minor Version: 0 -CHECK-NEXT: ] -CHECK-NEXT: ] -CHECK-NEXT: ] +CHECK: Resources [ +CHECK-NEXT: Total Number of Resources: 8 +CHECK-DAG: Number of String Entries: 1 +CHECK-NEXT: Number of ID Entries: 4 +CHECK-NEXT: Type: STRINGARRAY [ +CHECK-NEXT: Table Offset: 0x38 +CHECK-NEXT: Number of String Entries: 1 +CHECK-NEXT: Number of ID Entries: 0 +CHECK-NEXT: Name: MYRESOURCE [ +CHECK-NEXT: Table Offset: 0xC8 +CHECK-NEXT: Number of String Entries: 0 +CHECK-NEXT: Number of ID Entries: 1 +CHECK-NEXT: Language: (ID 1033) [ +CHECK-NEXT: Entry Offset: 0x188 +CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +CHECK-NEXT: Major Version: 0 +CHECK-NEXT: Minor Version: 0 +CHECK-NEXT: Characteristics: 0 +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-NEXT: Type: kRT_BITMAP (ID 2) [ +CHECK-NEXT: Table Offset: 0x50 +CHECK-NEXT: Number of String Entries: 2 +CHECK-NEXT: Number of ID Entries: 0 +CHECK-NEXT: Name: CURSOR [ +CHECK-NEXT: Table Offset: 0xE0 +CHECK-NEXT: Number of String Entries: 0 +CHECK-NEXT: Number of ID Entries: 1 +CHECK-NEXT: Language: (ID 1033) [ +CHECK-NEXT: Entry Offset: 0x198 +CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +CHECK-NEXT: Major Version: 0 +CHECK-NEXT: Minor Version: 0 +CHECK-NEXT: Characteristics: 0 +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-NEXT: Name: OKAY [ +CHECK-NEXT: Table Offset: 0xF8 +CHECK-NEXT: Number of String Entries: 0 +CHECK-NEXT: Number of ID Entries: 1 +CHECK-NEXT: Language: (ID 1033) [ +CHECK-NEXT: Entry Offset: 0x1A8 +CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +CHECK-NEXT: Major Version: 0 +CHECK-NEXT: Minor Version: 0 +CHECK-NEXT: Characteristics: 0 +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-NEXT: Type: kRT_MENU (ID 4) [ +CHECK-NEXT: Table Offset: 0x70 +CHECK-NEXT: Number of String Entries: 1 +CHECK-NEXT: Number of ID Entries: 1 +CHECK-NEXT: Name: "EAT" [ +CHECK-NEXT: Table Offset: 0x110 +CHECK-NEXT: Number of String Entries: 0 +CHECK-NEXT: Number of ID Entries: 1 +CHECK-NEXT: Language: (ID 3081) [ +CHECK-NEXT: Entry Offset: 0x1B8 +CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +CHECK-NEXT: Major Version: 0 +CHECK-NEXT: Minor Version: 0 +CHECK-NEXT: Characteristics: 0 +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-NEXT: Name: (ID 14432) [ +CHECK-NEXT: Table Offset: 0x128 +CHECK-NEXT: Number of String Entries: 0 +CHECK-NEXT: Number of ID Entries: 1 +CHECK-NEXT: Language: (ID 2052) [ +CHECK-NEXT: Entry Offset: 0x1C8 +CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +CHECK-NEXT: Major Version: 0 +CHECK-NEXT: Minor Version: 0 +CHECK-NEXT: Characteristics: 0 +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-NEXT: Type: kRT_DIALOG (ID 5) [ +CHECK-NEXT: Table Offset: 0x90 +CHECK-NEXT: Number of String Entries: 1 +CHECK-NEXT: Number of ID Entries: 0 +CHECK-NEXT: Name: TESTDIALOG [ +CHECK-NEXT: Table Offset: 0x140 +CHECK-NEXT: Number of String Entries: 0 +CHECK-NEXT: Number of ID Entries: 1 +CHECK-NEXT: Language: (ID 1033) [ +CHECK-NEXT: Entry Offset: 0x1D8 +CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +CHECK-NEXT: Major Version: 0 +CHECK-NEXT: Minor Version: 0 +CHECK-NEXT: Characteristics: 0 +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-NEXT: Type: kRT_ACCELERATOR (ID 9) [ +CHECK-NEXT: Table Offset: 0xA8 +CHECK-NEXT: Number of String Entries: 1 +CHECK-NEXT: Number of ID Entries: 1 +CHECK-NEXT: Name: MYACCELERATORS [ +CHECK-NEXT: Table Offset: 0x158 +CHECK-NEXT: Number of String Entries: 0 +CHECK-NEXT: Number of ID Entries: 1 +CHECK-NEXT: Language: (ID 1033) [ +CHECK-NEXT: Entry Offset: 0x1E8 +CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +CHECK-NEXT: Major Version: 0 +CHECK-NEXT: Minor Version: 0 +CHECK-NEXT: Characteristics: 0 +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-NEXT: Name: (ID 12) [ +CHECK-NEXT: Table Offset: 0x170 +CHECK-NEXT: Number of String Entries: 0 +CHECK-NEXT: Number of ID Entries: 1 +CHECK-NEXT: Language: (ID 1033) [ +CHECK-NEXT: Entry Offset: 0x1F8 +CHECK-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +CHECK-NEXT: Major Version: 0 +CHECK-NEXT: Minor Version: 0 +CHECK-NEXT: Characteristics: 0 +CHECK-NEXT: ] +CHECK-NEXT: ] +CHECK-NEXT: ] CHECK-DAG: .rsrc$02 Data ( CHECK-NEXT: 0000: 11000300 E7030000 0D004400 4C040000 |..........D.L...| CHECK-NEXT: 0010: 82001200 BC010000 28000000 10000000 |........(.......| diff --git a/test/tools/llvm-cvtres/parse.test b/test/tools/llvm-cvtres/parse.test index 23911ada82e..58c47143e69 100644 --- a/test/tools/llvm-cvtres/parse.test +++ b/test/tools/llvm-cvtres/parse.test @@ -2,7 +2,7 @@ // rc.exe: // > rc /fo test_resource.res /nologo test_resource.rc -RUN: llvm-cvtres /verbose /out:%t %p/Inputs/test_resource.res | FileCheck %s +RUN: llvm-cvtres /verbose %p/Inputs/test_resource.res | FileCheck %s CHECK: Number of resources: 8 CHECK-NEXT: Resource Tree [ diff --git a/test/tools/llvm-readobj/resources.test b/test/tools/llvm-readobj/resources.test index 855ce5393b8..589a9c968aa 100644 --- a/test/tools/llvm-readobj/resources.test +++ b/test/tools/llvm-readobj/resources.test @@ -9,103 +9,135 @@ RUN: | FileCheck %s -check-prefix ZERO RUN: llvm-readobj -coff-resources %p/Inputs/resources/test_resource.obj.coff \ RUN: | FileCheck %s -check-prefix TEST_RES -ZERO: Resources [ -ZERO-NEXT: String Name Entries: 0 -ZERO-NEXT: ID Entries: 1 -ZERO-NEXT: Type: kRT_STRING (ID 6) [ -ZERO-NEXT: String Name Entries: 0 -ZERO-NEXT: ID Entries: 1 -ZERO-NEXT: Name: (ID 1) [ -ZERO-NEXT: String Name Entries: 0 -ZERO-NEXT: ID Entries: 1 -ZERO-NEXT: Language: (ID 1033) [ -ZERO-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) -ZERO-NEXT: Major Version: 0 -ZERO-NEXT: Minor Version: 0 -ZERO-NEXT: ] -ZERO-NEXT: ] -ZERO-NEXT: ] +ZERO: Resources [ +ZERO-NEXT: Total Number of Resources: 1 +ZERO-NEXT: Base Table Address: 0x188 +ZERO-DAG: Number of String Entries: 0 +ZERO-NEXT: Number of ID Entries: 1 +ZERO-NEXT: Type: kRT_STRING (ID 6) [ +ZERO-NEXT: Table Offset: 0x18 +ZERO-NEXT: Number of String Entries: 0 +ZERO-NEXT: Number of ID Entries: 1 +ZERO-NEXT: Name: (ID 1) [ +ZERO-NEXT: Table Offset: 0x30 +ZERO-NEXT: Number of String Entries: 0 +ZERO-NEXT: Number of ID Entries: 1 +ZERO-NEXT: Language: (ID 1033) [ +ZERO-NEXT: Entry Offset: 0x48 +ZERO-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +ZERO-NEXT: Major Version: 0 +ZERO-NEXT: Minor Version: 0 +ZERO-NEXT: Characteristics: 0 +ZERO-NEXT: ] +ZERO-NEXT: ] +ZERO-NEXT: ] - -TEST_RES: Resources [ -TEST_RES-NEXT: String Name Entries: 0 -TEST_RES-NEXT: ID Entries: 4 -TEST_RES-NEXT: Type: kRT_BITMAP (ID 2) [ -TEST_RES-NEXT: String Name Entries: 2 -TEST_RES-NEXT: ID Entries: 0 -TEST_RES-NEXT: Name: CURSOR [ -TEST_RES-NEXT: String Name Entries: 0 -TEST_RES-NEXT: ID Entries: 1 -TEST_RES-NEXT: Language: (ID 1033) [ -TEST_RES-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) -TEST_RES-NEXT: Major Version: 0 -TEST_RES-NEXT: Minor Version: 0 -TEST_RES-NEXT: ] -TEST_RES-NEXT: ] -TEST_RES-NEXT: Name: OKAY [ -TEST_RES-NEXT: String Name Entries: 0 -TEST_RES-NEXT: ID Entries: 1 -TEST_RES-NEXT: Language: (ID 1033) [ -TEST_RES-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) -TEST_RES-NEXT: Major Version: 0 -TEST_RES-NEXT: Minor Version: 0 -TEST_RES-NEXT: ] -TEST_RES-NEXT: ] -TEST_RES-NEXT: ] -TEST_RES-NEXT: Type: kRT_MENU (ID 4) [ -TEST_RES-NEXT: String Name Entries: 1 -TEST_RES-NEXT: ID Entries: 1 -TEST_RES-NEXT: Name: "EAT" [ -TEST_RES-NEXT: String Name Entries: 0 -TEST_RES-NEXT: ID Entries: 1 -TEST_RES-NEXT: Language: (ID 3081) [ -TEST_RES-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) -TEST_RES-NEXT: Major Version: 0 -TEST_RES-NEXT: Minor Version: 0 -TEST_RES-NEXT: ] -TEST_RES-NEXT: ] -TEST_RES-NEXT: Name: (ID 14432) [ -TEST_RES-NEXT: String Name Entries: 0 -TEST_RES-NEXT: ID Entries: 1 -TEST_RES-NEXT: Language: (ID 2052) [ -TEST_RES-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) -TEST_RES-NEXT: Major Version: 0 -TEST_RES-NEXT: Minor Version: 0 -TEST_RES-NEXT: ] -TEST_RES-NEXT: ] -TEST_RES-NEXT: ] -TEST_RES-NEXT: Type: kRT_DIALOG (ID 5) [ -TEST_RES-NEXT: String Name Entries: 1 -TEST_RES-NEXT: ID Entries: 0 -TEST_RES-NEXT: Name: TESTDIALOG [ -TEST_RES-NEXT: String Name Entries: 0 -TEST_RES-NEXT: ID Entries: 1 -TEST_RES-NEXT: Language: (ID 1033) [ -TEST_RES-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) -TEST_RES-NEXT: Major Version: 0 -TEST_RES-NEXT: Minor Version: 0 -TEST_RES-NEXT: ] -TEST_RES-NEXT: ] -TEST_RES-NEXT: ] -TEST_RES-NEXT: Type: kRT_ACCELERATOR (ID 9) [ -TEST_RES-NEXT: String Name Entries: 1 -TEST_RES-NEXT: ID Entries: 1 -TEST_RES-NEXT: Name: MYACCELERATORS [ -TEST_RES-NEXT: String Name Entries: 0 -TEST_RES-NEXT: ID Entries: 1 -TEST_RES-NEXT: Language: (ID 1033) [ -TEST_RES-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) -TEST_RES-NEXT: Major Version: 0 -TEST_RES-NEXT: Minor Version: 0 -TEST_RES-NEXT: ] -TEST_RES-NEXT: ] -TEST_RES-NEXT: Name: (ID 12) [ -TEST_RES-NEXT: String Name Entries: 0 -TEST_RES-NEXT: ID Entries: 1 -TEST_RES-NEXT: Language: (ID 1033) [ -TEST_RES-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) -TEST_RES-NEXT: Major Version: 0 -TEST_RES-NEXT: Minor Version: 0 -TEST_RES-NEXT: ] -TEST_RES-NEXT: ] -TEST_RES-NEXT: ] +TEST_RES: Resources [ +TEST_RES-NEXT: Total Number of Resources: 7 +TEST_RES-NEXT: Base Table Address: 0x1C0 +TEST_RES-DAG: Number of String Entries: 0 +TEST_RES-NEXT: Number of ID Entries: 4 +TEST_RES-NEXT: Type: kRT_BITMAP (ID 2) [ +TEST_RES-NEXT: Table Offset: 0x30 +TEST_RES-NEXT: Number of String Entries: 2 +TEST_RES-NEXT: Number of ID Entries: 0 +TEST_RES-NEXT: Name: CURSOR [ +TEST_RES-NEXT: Table Offset: 0xA8 +TEST_RES-NEXT: Number of String Entries: 0 +TEST_RES-NEXT: Number of ID Entries: 1 +TEST_RES-NEXT: Language: (ID 1033) [ +TEST_RES-NEXT: Entry Offset: 0x150 +TEST_RES-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +TEST_RES-NEXT: Major Version: 0 +TEST_RES-NEXT: Minor Version: 0 +TEST_RES-NEXT: Characteristics: 0 +TEST_RES-NEXT: ] +TEST_RES-NEXT: ] +TEST_RES-NEXT: Name: OKAY [ +TEST_RES-NEXT: Table Offset: 0xC0 +TEST_RES-NEXT: Number of String Entries: 0 +TEST_RES-NEXT: Number of ID Entries: 1 +TEST_RES-NEXT: Language: (ID 1033) [ +TEST_RES-NEXT: Entry Offset: 0x160 +TEST_RES-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +TEST_RES-NEXT: Major Version: 0 +TEST_RES-NEXT: Minor Version: 0 +TEST_RES-NEXT: Characteristics: 0 +TEST_RES-NEXT: ] +TEST_RES-NEXT: ] +TEST_RES-NEXT: ] +TEST_RES-NEXT: Type: kRT_MENU (ID 4) [ +TEST_RES-NEXT: Table Offset: 0x50 +TEST_RES-NEXT: Number of String Entries: 1 +TEST_RES-NEXT: Number of ID Entries: 1 +TEST_RES-NEXT: Name: "EAT" [ +TEST_RES-NEXT: Table Offset: 0xD8 +TEST_RES-NEXT: Number of String Entries: 0 +TEST_RES-NEXT: Number of ID Entries: 1 +TEST_RES-NEXT: Language: (ID 3081) [ +TEST_RES-NEXT: Entry Offset: 0x170 +TEST_RES-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +TEST_RES-NEXT: Major Version: 0 +TEST_RES-NEXT: Minor Version: 0 +TEST_RES-NEXT: Characteristics: 0 +TEST_RES-NEXT: ] +TEST_RES-NEXT: ] +TEST_RES-NEXT: Name: (ID 14432) [ +TEST_RES-NEXT: Table Offset: 0xF0 +TEST_RES-NEXT: Number of String Entries: 0 +TEST_RES-NEXT: Number of ID Entries: 1 +TEST_RES-NEXT: Language: (ID 2052) [ +TEST_RES-NEXT: Entry Offset: 0x180 +TEST_RES-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +TEST_RES-NEXT: Major Version: 0 +TEST_RES-NEXT: Minor Version: 0 +TEST_RES-NEXT: Characteristics: 0 +TEST_RES-NEXT: ] +TEST_RES-NEXT: ] +TEST_RES-NEXT: ] +TEST_RES-NEXT: Type: kRT_DIALOG (ID 5) [ +TEST_RES-NEXT: Table Offset: 0x70 +TEST_RES-NEXT: Number of String Entries: 1 +TEST_RES-NEXT: Number of ID Entries: 0 +TEST_RES-NEXT: Name: TESTDIALOG [ +TEST_RES-NEXT: Table Offset: 0x108 +TEST_RES-NEXT: Number of String Entries: 0 +TEST_RES-NEXT: Number of ID Entries: 1 +TEST_RES-NEXT: Language: (ID 1033) [ +TEST_RES-NEXT: Entry Offset: 0x190 +TEST_RES-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +TEST_RES-NEXT: Major Version: 0 +TEST_RES-NEXT: Minor Version: 0 +TEST_RES-NEXT: Characteristics: 0 +TEST_RES-NEXT: ] +TEST_RES-NEXT: ] +TEST_RES-NEXT: ] +TEST_RES-NEXT: Type: kRT_ACCELERATOR (ID 9) [ +TEST_RES-NEXT: Table Offset: 0x88 +TEST_RES-NEXT: Number of String Entries: 1 +TEST_RES-NEXT: Number of ID Entries: 1 +TEST_RES-NEXT: Name: MYACCELERATORS [ +TEST_RES-NEXT: Table Offset: 0x120 +TEST_RES-NEXT: Number of String Entries: 0 +TEST_RES-NEXT: Number of ID Entries: 1 +TEST_RES-NEXT: Language: (ID 1033) [ +TEST_RES-NEXT: Entry Offset: 0x1A0 +TEST_RES-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +TEST_RES-NEXT: Major Version: 0 +TEST_RES-NEXT: Minor Version: 0 +TEST_RES-NEXT: Characteristics: 0 +TEST_RES-NEXT: ] +TEST_RES-NEXT: ] +TEST_RES-NEXT: Name: (ID 12) [ +TEST_RES-NEXT: Table Offset: 0x138 +TEST_RES-NEXT: Number of String Entries: 0 +TEST_RES-NEXT: Number of ID Entries: 1 +TEST_RES-NEXT: Language: (ID 1033) [ +TEST_RES-NEXT: Entry Offset: 0x1B0 +TEST_RES-NEXT: Time/Date Stamp: 1970-01-01 00:00:00 (0x0) +TEST_RES-NEXT: Major Version: 0 +TEST_RES-NEXT: Minor Version: 0 +TEST_RES-NEXT: Characteristics: 0 +TEST_RES-NEXT: ] +TEST_RES-NEXT: ] +TEST_RES-NEXT: ] diff --git a/tools/llvm-readobj/COFFDumper.cpp b/tools/llvm-readobj/COFFDumper.cpp index 6223c09a4de..216c9adad9a 100644 --- a/tools/llvm-readobj/COFFDumper.cpp +++ b/tools/llvm-readobj/COFFDumper.cpp @@ -124,6 +124,10 @@ private: uint32_t RelocOffset, uint32_t Offset, StringRef *RelocSym = nullptr); + uint32_t countTotalTableEntries(ResourceSectionRef RSF, + const coff_resource_dir_table &Table, + StringRef Level); + void printResourceDirectoryTable(ResourceSectionRef RSF, const coff_resource_dir_table &Table, StringRef Level); @@ -1526,6 +1530,11 @@ void COFFDumper::printCOFFResources() { if ((Name == ".rsrc") || (Name == ".rsrc$01")) { ResourceSectionRef RSF(Ref); auto &BaseTable = unwrapOrError(RSF.getBaseTable()); + W.printNumber("Total Number of Resources", + countTotalTableEntries(RSF, BaseTable, "Type")); + W.printHex("Base Table Address", + Obj->getCOFFSection(S)->PointerToRawData); + W.startLine() << "\n"; printResourceDirectoryTable(RSF, BaseTable, "Type"); } if (opts::SectionData) @@ -1533,15 +1542,35 @@ void COFFDumper::printCOFFResources() { } } +uint32_t +COFFDumper::countTotalTableEntries(ResourceSectionRef RSF, + const coff_resource_dir_table &Table, + StringRef Level) { + uint32_t TotalEntries = 0; + for (int i = 0; i < Table.NumberOfNameEntries + Table.NumberOfIDEntries; + i++) { + auto Entry = unwrapOrError(getResourceDirectoryTableEntry(Table, i)); + if (Entry.Offset.isSubDir()) { + StringRef NextLevel; + if (Level == "Name") + NextLevel = "Language"; + else + NextLevel = "Name"; + auto &NextTable = unwrapOrError(RSF.getEntrySubDir(Entry)); + TotalEntries += countTotalTableEntries(RSF, NextTable, NextLevel); + } else { + TotalEntries += 1; + } + } + return TotalEntries; +} + void COFFDumper::printResourceDirectoryTable( ResourceSectionRef RSF, const coff_resource_dir_table &Table, StringRef Level) { - W.printNumber("String Name Entries", Table.NumberOfNameEntries); - W.printNumber("ID Entries", Table.NumberOfIDEntries); - char FormattedTime[20] = {}; - time_t TDS = time_t(Table.TimeDateStamp); - strftime(FormattedTime, 20, "%Y-%m-%d %H:%M:%S", gmtime(&TDS)); + W.printNumber("Number of String Entries", Table.NumberOfNameEntries); + W.printNumber("Number of ID Entries", Table.NumberOfIDEntries); // Iterate through level in resource directory tree. for (int i = 0; i < Table.NumberOfNameEntries + Table.NumberOfIDEntries; @@ -1578,6 +1607,7 @@ void COFFDumper::printResourceDirectoryTable( Name = StringRef(IDStr); ListScope ResourceType(W, Level.str() + Name.str()); if (Entry.Offset.isSubDir()) { + W.printHex("Table Offset", Entry.Offset.value()); StringRef NextLevel; if (Level == "Name") NextLevel = "Language"; @@ -1586,9 +1616,14 @@ void COFFDumper::printResourceDirectoryTable( auto &NextTable = unwrapOrError(RSF.getEntrySubDir(Entry)); printResourceDirectoryTable(RSF, NextTable, NextLevel); } else { + W.printHex("Entry Offset", Entry.Offset.value()); + char FormattedTime[20] = {}; + time_t TDS = time_t(Table.TimeDateStamp); + strftime(FormattedTime, 20, "%Y-%m-%d %H:%M:%S", gmtime(&TDS)); W.printHex("Time/Date Stamp", FormattedTime, Table.TimeDateStamp); W.printNumber("Major Version", Table.MajorVersion); W.printNumber("Minor Version", Table.MinorVersion); + W.printNumber("Characteristics", Table.Characteristics); } } } -- 2.11.0