[compiler-rt] r205413 - [msan] Add __msan_check_mem_is_initialized.

Alexey Samsonov samsonov at google.com
Wed Apr 2 05:42:09 PDT 2014


Do you have a test for this?

On Wed, Apr 2, 2014 at 3:50 PM, Evgeniy Stepanov
<eugeni.stepanov at gmail.com> wrote:
> Author: eugenis
> Date: Wed Apr  2 06:50:42 2014
> New Revision: 205413
>
> URL: http://llvm.org/viewvc/llvm-project?rev=205413&view=rev
> Log:
> [msan] Add __msan_check_mem_is_initialized.
>
> An assert()-like function that checks that a memory range is fully initialized.
>
> Modified:
>     compiler-rt/trunk/include/sanitizer/msan_interface.h
>     compiler-rt/trunk/lib/msan/msan.cc
>     compiler-rt/trunk/lib/msan/msan_interface_internal.h
>
> Modified: compiler-rt/trunk/include/sanitizer/msan_interface.h
> URL: http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/include/sanitizer/msan_interface.h?rev=205413&r1=205412&r2=205413&view=diff
> ==============================================================================
> --- compiler-rt/trunk/include/sanitizer/msan_interface.h (original)
> +++ compiler-rt/trunk/include/sanitizer/msan_interface.h Wed Apr  2 06:50:42 2014
> @@ -54,6 +54,10 @@ extern "C" {
>       memory range, or -1 if the whole range is good. */
>    intptr_t __msan_test_shadow(const volatile void *x, size_t size);
>
> +  /* Checks that memory range is fully initialized, and reports an error if it
> +   * is not. */
> +  void __msan_check_mem_is_initialized(const volatile void *x, size_t size);
> +
>    /* Set exit code when error(s) were detected.
>       Value of 0 means don't change the program exit code. */
>    void __msan_set_exit_code(int exit_code);
>
> Modified: compiler-rt/trunk/lib/msan/msan.cc
> URL: http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/lib/msan/msan.cc?rev=205413&r1=205412&r2=205413&view=diff
> ==============================================================================
> --- compiler-rt/trunk/lib/msan/msan.cc (original)
> +++ compiler-rt/trunk/lib/msan/msan.cc Wed Apr  2 06:50:42 2014
> @@ -383,6 +383,22 @@ sptr __msan_test_shadow(const void *x, u
>    return -1;
>  }
>
> +void __msan_check_mem_is_initialized(const void *x, uptr size) {
> +  if (!__msan::flags()->report_umrs) return;
> +  sptr offset = __msan_test_shadow(x, size) < 0;
> +  if (offset < 0)
> +    return;
> +
> +  GET_CALLER_PC_BP_SP;
> +  (void)sp;
> +  __msan::PrintWarningWithOrigin(pc, bp,
> +                                 __msan_get_origin(((char *)x) + offset));
> +  if (__msan::flags()->halt_on_error) {
> +    Printf("Exiting\n");
> +    Die();
> +  }
> +}
> +
>  int __msan_set_poison_in_malloc(int do_poison) {
>    int old = flags()->poison_in_malloc;
>    flags()->poison_in_malloc = do_poison;
>
> Modified: compiler-rt/trunk/lib/msan/msan_interface_internal.h
> URL: http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/lib/msan/msan_interface_internal.h?rev=205413&r1=205412&r2=205413&view=diff
> ==============================================================================
> --- compiler-rt/trunk/lib/msan/msan_interface_internal.h (original)
> +++ compiler-rt/trunk/lib/msan/msan_interface_internal.h Wed Apr  2 06:50:42 2014
> @@ -65,6 +65,9 @@ SANITIZER_INTERFACE_ATTRIBUTE
>  sptr __msan_test_shadow(const void *x, uptr size);
>
>  SANITIZER_INTERFACE_ATTRIBUTE
> +void __msan_check_mem_is_initialized(const void *x, uptr size);
> +
> +SANITIZER_INTERFACE_ATTRIBUTE
>  void __msan_set_origin(const void *a, uptr size, u32 origin);
>  SANITIZER_INTERFACE_ATTRIBUTE
>  void __msan_set_alloca_origin(void *a, uptr size, const char *descr);
>
>
> _______________________________________________
> llvm-commits mailing list
> llvm-commits at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits



-- 
Alexey Samsonov, MSK



More information about the llvm-commits mailing list