If modified attribute list is invalid, reverting the change is a
low-cost maintainence solution as compared to examples like
this.
This will ensure that the ListReducer maintains the sanctity of any
new attribute dependencies added in the future/already present.
Details
Diff Detail
- Repository
- rG LLVM Github Monorepo
Unit Tests
Time | Test | |
---|---|---|
650 ms | x64 debian > LLVM.BugPoint::invalid-debuginfo.ll |
Event Timeline
Unfortunately, I haven't touched this code since about 2004. @modocache I see you've touched this somewhat more recently, can you take a look at this?
llvm/tools/bugpoint/CrashDebugger.cpp | ||
---|---|---|
386 | Can you use llvm::verifyModule instead of running the pass? |
llvm/tools/bugpoint/CrashDebugger.cpp | ||
---|---|---|
386 | Other parts of the CrashDebugger run the pass to verify llvm IR, hence I kept it the same. Let me know if I should still change to llvm::verifyModule. |
llvm/tools/bugpoint/CrashDebugger.cpp | ||
---|---|---|
386 | You bring up a good point, @Nirhar -- there's actually a lot of duplication in this file. I count 7 spots where the verifier pass is run, and this makes 8! Here's an example: https://github.com/llvm/llvm-project/blob/b4b532a9562a1ebca347edc566363fba0531115b/llvm/tools/bugpoint/CrashDebugger.cpp#L512-L520 I agree that it would be nicer to use llvm::verifyModule here; it accomplishes the same thing, but in a much simpler way. (And, I think it would be even better, in a separate patch, to change the other 7 spots to use verifyModule too -- and, ideally, have them print "verify failed!" and exit, like many of them seem to do.) |
llvm/tools/bugpoint/CrashDebugger.cpp | ||
---|---|---|
386 |
Sorry, typo here. I meant to write that it would be nice to 1) have these other spots use verifyModule, AND 2) unify them with a static helper function or something, such that we had one function that could verify a module and print "verify failed!" if verification failed. Right now that logic is duplicated a ton in this file. |
llvm/tools/bugpoint/CrashDebugger.cpp | ||
---|---|---|
386 | It would be easier yet to just delete bugpoint altogether and switch to using llvm-reduce. The attribute reducer there takes care to avoid introducing invalid attribute combinations |
llvm/tools/bugpoint/CrashDebugger.cpp | ||
---|---|---|
386 | I agree with you, let me refactor the code and then update the diff to incorporate your suggestions. |
Code Refactor
Used llvm::verifyModule to verify modules modified by CrashDebugger
Introduced function isValidModule to verify correctness of IR, for
the needs of CrashDebugger.
Please have a look at these changes.
Changing from running verification passes to llvm::verifyModule leads to the failure of the following test: Bugpoint/invalid-debuginfo.ll. I'm currently trying to understand why its failing.
Looks great!! Thank you for also updating the other call sites. I had a few additional comments, but once those are taken care of I can accept. (When I do, will you need me to merge this commit on your behalf?)
llvm/tools/bugpoint/CrashDebugger.cpp | ||
---|---|---|
73 | Please run clang-format on this patch; I can tell from some of the spacing here that this is not typical formatting. I believe clang-format should format this as static bool isValidModule(std::unique_ptr<Module> &M, bool exitOnFailure = true) {. There may be other formatting changes that would be applied to other parts of your patch as well. Also, there's a mix of capitalization conventions here. I believe the Coding Standards here -- https://llvm.org/docs/CodingStandards.html#name-types-functions-variables-and-enumerators-properly -- would have you name this ExitOnFailure, with a capital 'E'. | |
74 | I believe you don't need the parentheses here. | |
75 | I think this would be a little simpler if you checked the inverse: if (!llvm::verifyModule(*M.get(), &llvm::errs())) return true; if (ExitOnFailure) { llvm::errs() << "verify failed!\n"; exit(1); } return false; This removes a lot of nesting in your if statements, and I think looks nicer. | |
794 | No need to update this comment, IMHO. | |
795 | I believe this should use ExitOnFailure = false, right? | |
864 | Same as above; I don't believe this comment should change. Same goes for the 2 spots below in this patch. | |
865 | Same as above; I believe the previous behavior was to not exit. Same goes for the 2 spots below in this patch. |
Please have a look at these changes.
@modocache Can you please merge this commit on my behalf once you are satisfied with the changes?
Looks great, thanks!
Can you please merge this commit on my behalf once you are satisfied with the changes?
Sure thing!
Please run clang-format on this patch; I can tell from some of the spacing here that this is not typical formatting. I believe clang-format should format this as static bool isValidModule(std::unique_ptr<Module> &M, bool exitOnFailure = true) {. There may be other formatting changes that would be applied to other parts of your patch as well.
Also, there's a mix of capitalization conventions here. I believe the Coding Standards here -- https://llvm.org/docs/CodingStandards.html#name-types-functions-variables-and-enumerators-properly -- would have you name this ExitOnFailure, with a capital 'E'.