[compiler-rt] r231151 - [UBSan] Add testcases for -fsanitize=shift-base and -fsanitize=shift-exponent.

Alexey Samsonov vonosmas at gmail.com
Thu Mar 5 13:52:59 PST 2015


Nevermind, I think I see where the problem is. I will investigate this
and/or revert the patch shortly. Sorry for the breakage!

On Thu, Mar 5, 2015 at 1:52 PM, Renato Golin <renato.golin at linaro.org>
wrote:

> Hi Alexey,
>
> Unfortunately, I don't have access to that board. Gabor, can you have
> a look at which of the RUN lines is failing on that test?
>
> cheers,
> --renato
>
> On 5 March 2015 at 21:47, Alexey Samsonov <vonosmas at gmail.com> wrote:
> >
> > On Thu, Mar 5, 2015 at 11:56 AM, Renato Golin <renato.golin at linaro.org>
> > wrote:
> >>
> >> Hi Alexey,
> >>
> >> Not sure you saw this, but this commit actually breaks AArch64 bots:
> >>
> >>
> >>
> http://lab.llvm.org:8011/builders/clang-native-aarch64-full/builds/485/steps/ninja%20check%201/logs/UBSan-Standalone-aarch64%3A%3Ashift.cpp
> >
> >
> > No, I've missed that. Sorry =/
> > It's not at all clear why this failure happens.
> > First of all, which of the RUN lines is failing? Judging from the output,
> > it's this one:
> >
> >
> /home/debianbot/work/buildbot/slave/clang-native-aarch64-full/stage1/./bin/clang
> > --driver-mode=g++  -DTOO_LOW -DOP='<<' -fsanitize=shift-base
> > -fno-sanitize-recover=shift
> >
> /home/debianbot/work/buildbot/slave/clang-native-aarch64-full/llvm/projects/compiler-rt/test/ubsan/TestCases/Integer/shift.cpp
> > -o
> >
> /home/debianbot/work/buildbot/slave/clang-native-aarch64-full/stage1/projects/compiler-rt/test/ubsan/Standalone-aarch64/TestCases/Integer/Output/shift.cpp.tmp
> > &&
> >
> /home/debianbot/work/buildbot/slave/clang-native-aarch64-full/stage1/projects/compiler-rt/test/ubsan/Standalone-aarch64/TestCases/Integer/Output/shift.cpp.tmp
> >
> > Can you verify that the resulting executable indeed fails with UBSan
> error?
> > If yes, what is the objdump of main() function in this case?
> >
> >>
> >>
> >>
> >> cheers,
> >> --renato
> >>
> >> On 3 March 2015 at 22:15, Alexey Samsonov <vonosmas at gmail.com> wrote:
> >> > Author: samsonov
> >> > Date: Tue Mar  3 16:15:44 2015
> >> > New Revision: 231151
> >> >
> >> > URL: http://llvm.org/viewvc/llvm-project?rev=231151&view=rev
> >> > Log:
> >> > [UBSan] Add testcases for -fsanitize=shift-base and
> >> > -fsanitize=shift-exponent.
> >> >
> >> > Modified:
> >> >     compiler-rt/trunk/test/ubsan/TestCases/Integer/shift.cpp
> >> >     compiler-rt/trunk/test/ubsan/TestCases/Misc/coverage-levels.cc
> >> >
> >> > Modified: compiler-rt/trunk/test/ubsan/TestCases/Integer/shift.cpp
> >> > URL:
> >> >
> http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/test/ubsan/TestCases/Integer/shift.cpp?rev=231151&r1=231150&r2=231151&view=diff
> >> >
> >> >
> ==============================================================================
> >> > --- compiler-rt/trunk/test/ubsan/TestCases/Integer/shift.cpp
> (original)
> >> > +++ compiler-rt/trunk/test/ubsan/TestCases/Integer/shift.cpp Tue Mar
> 3
> >> > 16:15:44 2015
> >> > @@ -1,13 +1,20 @@
> >> > -// RUN: %clangxx -DLSH_OVERFLOW -DOP='<<' -fsanitize=shift %s -o %t
> &&
> >> > %run %t 2>&1 | FileCheck %s --check-prefix=CHECK-LSH_OVERFLOW
> >> > -// RUN: %clangxx -DLSH_OVERFLOW -DOP='<<=' -fsanitize=shift %s -o %t
> &&
> >> > %run %t 2>&1 | FileCheck %s --check-prefix=CHECK-LSH_OVERFLOW
> >> > -// RUN: %clangxx -DTOO_LOW -DOP='<<' -fsanitize=shift %s -o %t &&
> %run
> >> > %t 2>&1 | FileCheck %s --check-prefix=CHECK-TOO_LOW
> >> > -// RUN: %clangxx -DTOO_LOW -DOP='>>' -fsanitize=shift %s -o %t &&
> %run
> >> > %t 2>&1 | FileCheck %s --check-prefix=CHECK-TOO_LOW
> >> > -// RUN: %clangxx -DTOO_LOW -DOP='<<=' -fsanitize=shift %s -o %t &&
> %run
> >> > %t 2>&1 | FileCheck %s --check-prefix=CHECK-TOO_LOW
> >> > -// RUN: %clangxx -DTOO_LOW -DOP='>>=' -fsanitize=shift %s -o %t &&
> %run
> >> > %t 2>&1 | FileCheck %s --check-prefix=CHECK-TOO_LOW
> >> > -// RUN: %clangxx -DTOO_HIGH -DOP='<<' -fsanitize=shift %s -o %t &&
> %run
> >> > %t 2>&1 | FileCheck %s --check-prefix=CHECK-TOO_HIGH
> >> > -// RUN: %clangxx -DTOO_HIGH -DOP='>>' -fsanitize=shift %s -o %t &&
> %run
> >> > %t 2>&1 | FileCheck %s --check-prefix=CHECK-TOO_HIGH
> >> > -// RUN: %clangxx -DTOO_HIGH -DOP='<<=' -fsanitize=shift %s -o %t &&
> >> > %run %t 2>&1 | FileCheck %s --check-prefix=CHECK-TOO_HIGH
> >> > -// RUN: %clangxx -DTOO_HIGH -DOP='>>=' -fsanitize=shift %s -o %t &&
> >> > %run %t 2>&1 | FileCheck %s --check-prefix=CHECK-TOO_HIGH
> >> > +// RUN: %clangxx -DLSH_OVERFLOW -DOP='<<' -fsanitize=shift-base
> >> > -fno-sanitize-recover=shift %s -o %t && not %run %t 2>&1 | FileCheck
> %s
> >> > --check-prefix=CHECK-LSH_OVERFLOW
> >> > +// RUN: %clangxx -DLSH_OVERFLOW -DOP='<<=' -fsanitize=shift
> >> > -fno-sanitize-recover=shift %s -o %t && not %run %t 2>&1 | FileCheck
> %s
> >> > --check-prefix=CHECK-LSH_OVERFLOW
> >> > +// RUN: %clangxx -DTOO_LOW -DOP='<<' -fsanitize=shift-exponent
> >> > -fno-sanitize-recover=shift %s -o %t && not %run %t 2>&1 | FileCheck
> %s
> >> > --check-prefix=CHECK-TOO_LOW
> >> > +// RUN: %clangxx -DTOO_LOW -DOP='>>' -fsanitize=shift
> >> > -fno-sanitize-recover=shift %s -o %t && not %run %t 2>&1 | FileCheck
> %s
> >> > --check-prefix=CHECK-TOO_LOW
> >> > +// RUN: %clangxx -DTOO_LOW -DOP='<<=' -fsanitize=shift
> >> > -fno-sanitize-recover=shift %s -o %t && not %run %t 2>&1 | FileCheck
> %s
> >> > --check-prefix=CHECK-TOO_LOW
> >> > +// RUN: %clangxx -DTOO_LOW -DOP='>>=' -fsanitize=shift
> >> > -fno-sanitize-recover=shift %s -o %t && not %run %t 2>&1 | FileCheck
> %s
> >> > --check-prefix=CHECK-TOO_LOW
> >> > +// RUN: %clangxx -DTOO_HIGH -DOP='<<' -fsanitize=shift-exponent
> >> > -fno-sanitize-recover=shift %s -o %t && not %run %t 2>&1 | FileCheck
> %s
> >> > --check-prefix=CHECK-TOO_HIGH
> >> > +// RUN: %clangxx -DTOO_HIGH -DOP='>>' -fsanitize=shift
> >> > -fno-sanitize-recover=shift %s -o %t && not %run %t 2>&1 | FileCheck
> %s
> >> > --check-prefix=CHECK-TOO_HIGH
> >> > +// RUN: %clangxx -DTOO_HIGH -DOP='<<=' -fsanitize=shift
> >> > -fno-sanitize-recover=shift %s -o %t && not %run %t 2>&1 | FileCheck
> %s
> >> > --check-prefix=CHECK-TOO_HIGH
> >> > +// RUN: %clangxx -DTOO_HIGH -DOP='>>=' -fsanitize=shift
> >> > -fno-sanitize-recover=shift %s -o %t && not %run %t 2>&1 | FileCheck
> %s
> >> > --check-prefix=CHECK-TOO_HIGH
> >> > +
> >> > +// RUN: %clangxx -DLSH_OVERFLOW -DOP='<<' -fsanitize=shift-exponent
> >> > -fno-sanitize-recover=shift %s -o %t && %run %t
> >> > +// RUN: %clangxx -DLSH_OVERFLOW -DOP='>>' -fsanitize=shift-exponent
> >> > -fno-sanitize-recover=shift %s -o %t && %run %t
> >> > +// RUN: %clangxx -DTOO_LOW -DOP='<<' -fsanitize=shift-base
> >> > -fno-sanitize-recover=shift %s -o %t && %run %t
> >> > +// RUN: %clangxx -DTOO_LOW -DOP='>>' -fsanitize=shift-base
> >> > -fno-sanitize-recover=shift %s -o %t && %run %t
> >> > +// RUN: %clangxx -DTOO_HIGH -DOP='<<' -fsanitize=shift-base
> >> > -fno-sanitize-recover=shift %s -o %t && %run %t
> >> > +// RUN: %clangxx -DTOO_HIGH -DOP='>>' -fsanitize=shift-base
> >> > -fno-sanitize-recover=shift %s -o %t && %run %t
> >> >
> >> >  #include <stdint.h>
> >> >
> >> > @@ -20,18 +27,19 @@ int main() {
> >> >    b <<= 1; // still ok, unsigned
> >> >
> >> >  #ifdef LSH_OVERFLOW
> >> > -  // CHECK-LSH_OVERFLOW: shift.cpp:24:5: runtime error: left shift of
> >> > negative value -2147483648
> >> > +  // CHECK-LSH_OVERFLOW: shift.cpp:[[@LINE+1]]:5: runtime error: left
> >> > shift of negative value -2147483648
> >> >    a OP 1;
> >> >  #endif
> >> >
> >> >  #ifdef TOO_LOW
> >> > -  // CHECK-TOO_LOW: shift.cpp:29:5: runtime error: shift exponent -3
> is
> >> > negative
> >> > +  a = 0;
> >> > +  // CHECK-TOO_LOW: shift.cpp:[[@LINE+1]]:5: runtime error: shift
> >> > exponent -3 is negative
> >> >    a OP (-3);
> >> >  #endif
> >> >
> >> >  #ifdef TOO_HIGH
> >> >    a = 0;
> >> > -  // CHECK-TOO_HIGH: shift.cpp:35:5: runtime error: shift exponent 32
> >> > is too large for 32-bit type 'int'
> >> > +  // CHECK-TOO_HIGH: shift.cpp:[[@LINE+1]]:5: runtime error: shift
> >> > exponent 32 is too large for 32-bit type 'int'
> >> >    a OP 32;
> >> >  #endif
> >> >  }
> >> >
> >> > Modified:
> compiler-rt/trunk/test/ubsan/TestCases/Misc/coverage-levels.cc
> >> > URL:
> >> >
> http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/test/ubsan/TestCases/Misc/coverage-levels.cc?rev=231151&r1=231150&r2=231151&view=diff
> >> >
> >> >
> ==============================================================================
> >> > --- compiler-rt/trunk/test/ubsan/TestCases/Misc/coverage-levels.cc
> >> > (original)
> >> > +++ compiler-rt/trunk/test/ubsan/TestCases/Misc/coverage-levels.cc Tue
> >> > Mar  3 16:15:44 2015
> >> > @@ -35,4 +35,4 @@ int main(int argc, char **argv) {
> >> >  // to dump coverage.
> >> >  // CHECK1:  1 PCs written
> >> >  // CHECK2:  3 PCs written
> >> > -// CHECK3:  4 PCs written
> >> > +// CHECK3:  3 PCs written
> >> >
> >> >
> >> > _______________________________________________
> >> > llvm-commits mailing list
> >> > llvm-commits at cs.uiuc.edu
> >> > http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits
> >
> >
> >
> >
> > --
> > Alexey Samsonov
> > vonosmas at gmail.com
>



-- 
Alexey Samsonov
vonosmas at gmail.com
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20150305/f2c7a33e/attachment.html>


More information about the llvm-commits mailing list