This is an archive of the discontinued LLVM Phabricator instance.

[NewPM][ASan] Make ASan tests work under NPM
ClosedPublic

Authored by aeubanks on Jul 15 2020, 6:03 PM.

Details

Summary

Under NPM, the asan-globals-md analysis is required but cannot be run
within the asan function pass due to module analyses not being able to
run from a function pass. So this pins all tests using "-asan" to the
legacy PM and adds a corresponding RUN line with
-passes='require<asan-globals-md>,function(asan)'.

Now all tests in Instrumentation/AddressSanitizer pass when
-enable-new-pm is by default on.

Tests were automatically converted using the following python script and
failures were manually fixed up.

import sys
for i in sys.argv:

with open(i, 'r') as f:
    s = f.read()
with open(i, 'w') as f:
    for l in s.splitlines():
        if "RUN:" in l and ' -asan -asan-module ' in l and '\\' not in l:
            f.write(l.replace(' -asan -asan-module ', ' -asan -asan-module -enable-new-pm=0 '))
            f.write('\n')
            f.write(l.replace(' -asan -asan-module ', " -passes='require<asan-globals-md>,function(asan),module(asan-module)' "))
            f.write('\n')
        elif "RUN:" in l and ' -asan ' in l and '\\' not in l:
            f.write(l.replace(' -asan ', ' -asan -enable-new-pm=0 '))
            f.write('\n')
            f.write(l.replace(' -asan ', " -passes='require<asan-globals-md>,function(asan)' "))
            f.write('\n')
        else:
            f.write(l)
            f.write('\n')

See https://bugs.llvm.org/show_bug.cgi?id=46611.

Diff Detail

Event Timeline

aeubanks created this revision.Jul 15 2020, 6:03 PM
aeubanks edited the summary of this revision. (Show Details)Jul 15 2020, 6:04 PM
aeubanks planned changes to this revision.Jul 16 2020, 4:01 PM

There may be a better way as discussed in https://bugs.llvm.org/show_bug.cgi?id=46611

vitalybuka added inline comments.Jul 17 2020, 1:22 PM
llvm/test/Instrumentation/AddressSanitizer/adaptive_global_redzones.ll
1–4

I assumed that "-asan -asan-module" is a explicit way to call old pm and -passes= for newpm
should opt still use old pm for former even after switch to new PM by default?

aeubanks updated this revision to Diff 278931.Jul 17 2020, 4:40 PM
aeubanks marked an inline comment as done.

Add opt "passes" asan-pipeline/asan-function-pipeline
I'd rather not name "asan" to "asan-function" unless we rename the other sanitizers, for consistency. And there is some value in keeping the legacy PM and NPM pass names the same, even if it doesn't 100% work for asan.

llvm/test/Instrumentation/AddressSanitizer/adaptive_global_redzones.ll
1–4

"-foo-pass" at some point run under NPM once we flip the flag, to avoid having to touch the vast majority of tests.
-enable-new-pm=0 pins it to legacy PM even after the NPM flip.

vitalybuka accepted this revision.Jul 17 2020, 5:46 PM
This revision is now accepted and ready to land.Jul 17 2020, 5:46 PM
This revision was automatically updated to reflect the committed changes.