Report warnings rather than errors, so that llvm-readobj doesn't bail out on malformed inputs.
Details
- Reviewers
- jhenderson - Esme - daltenty - hubert.reinterpretcast - MaskRay - sfertile 
- Group Reviewers
- Restricted Project 
- Commits
- rG7151a8aada21: [PowerPC][AIX] llvm-readobj: Convert some errors to warnings.
Diff Detail
- Repository
- rG LLVM Github Monorepo
Event Timeline
| llvm/tools/llvm-readobj/XCOFFDumper.cpp | ||
|---|---|---|
| 139 | I don't know how to test it.  | |
| llvm/tools/llvm-readobj/XCOFFDumper.cpp | ||
|---|---|---|
| 139 | To test this, you'll probably need to craft an XCOFF object (probably using yaml2obj) to trigger the report of the error from Obj.relocations. You may need to expand on yaml2obj's existing behaviour to allow creating an invalid input. Just because something isn't tested already, doesn't mean it shouldn't be now, and this is a good chance to add the testing. | |
| llvm/test/tools/llvm-readobj/XCOFF/relocations32.yaml | ||
|---|---|---|
| 1 ↗ | (On Diff #363028) | This comment looks like it's been copied from somewhere else and doesn't make sense in this context. Please rewrite it. The test name suggests this is for generic dumping of 32-bit relocations, but I think your patch is about reporting of warnings, so the test name doesn't make much sense to me. | 
| 5–8 ↗ | (On Diff #363028) | If this test is just about checking the warnings, you can omit these 4 lines, as they aren't important. | 
| 11 ↗ | (On Diff #363028) | What's the full message here that you are matching? | 
| 17 ↗ | (On Diff #363028) | We generally remove execessive whitespace, so that values within a block line up vertically, but as far left as possible. | 
| 20 ↗ | (On Diff #363028) | I don't think you need this section? | 
| llvm/tools/llvm-readobj/XCOFFDumper.cpp | ||
| 153 | This still seems to be without a test? | |
| llvm/test/tools/llvm-readobj/XCOFF/relocations32.yaml | ||
|---|---|---|
| 11 ↗ | (On Diff #363028) | The warning occurs due to the invalid symbol index used to obtain the symbol name. Expected<StringRef> ErrOrSymbolName =
          Obj.getSymbolNameByIndex(Reloc.SymbolIndex);The full message is the following : | 
| llvm/tools/llvm-readobj/XCOFFDumper.cpp | ||
| 139 | I was not able to introduce an error to check this warning but I checked the other one. | |
| llvm/test/tools/llvm-readobj/XCOFF/report_warning.yaml | ||
|---|---|---|
| 1 ↗ | (On Diff #363436) | Two problems with this file name now: 1) use - not _ and 2) the test name needs to say which sort of warning this is testing, namely something like relocation-invalid.yaml. | 
| 2–6 ↗ | (On Diff #363436) | You can test the full path by doing the inline edit. You can also omit the leading {[.*}}, since FileCheck doesn't require full line matches by default. | 
| llvm/tools/llvm-readobj/XCOFFDumper.cpp | ||
| 139 | I've skimmed the XCOFFObjectFile code, and it looks like there should be a couple of possible ways of triggering an error in it. It might require enhancements to yaml2obj to allow creating an invalid object. There are many good examples of prior art for ELF of how to achieve this sort of thing. | |
Just some test tidying up now.
| llvm/test/tools/llvm-readobj/XCOFF/relocation-invalid.test | ||
|---|---|---|
| 1 ↗ | (On Diff #363720) | Add a comment to the top of this file explaining the purposes of the tests within. | 
| 15–16 ↗ | (On Diff #363720) | Delete excessive blank lines at EOF. | 
| llvm/test/tools/llvm-readobj/XCOFF/relocation-symbol-invalid.test | ||
| 1 ↗ | (On Diff #363720) | This can be merged into relocation-invalid.test, so you have two related test cases in the same file. I'd also name it relocations-invalid.test thinking about it. | 
| llvm/test/tools/llvm-readobj/XCOFF/relocations-invalid.test | ||
|---|---|---|
| 4 | I have seen this way of commenting in some ELF tests. | |
Hi Maryam.
Do you need someone to commit this for you? I don't think we were waiting for any further approvals (FWIW it LGTM also though). I made one small comment about removing some trailing whitespace, if you need someone to commit for you I can fix that and commit, just let me know.
| llvm/test/tools/llvm-readobj/XCOFF/relocations-invalid.test | ||
|---|---|---|
| 9 | Real minor nit: there is trailing whitespace at the end of this line. | |
Hi,
I removed the trailing whitespace. 
It would be great if you could commit it, thank you.
Use double hash for true comment markers in these tests.