You've already forked linux-packaging-mono
							
							
		
			
				
	
	
		
			96 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			96 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| ===========================
 | |
| Sanitizer special case list
 | |
| ===========================
 | |
| 
 | |
| .. contents::
 | |
|    :local:
 | |
| 
 | |
| Introduction
 | |
| ============
 | |
| 
 | |
| This document describes the way to disable or alter the behavior of
 | |
| sanitizer tools for certain source-level entities by providing a special
 | |
| file at compile-time.
 | |
| 
 | |
| Goal and usage
 | |
| ==============
 | |
| 
 | |
| User of sanitizer tools, such as :doc:`AddressSanitizer`, :doc:`ThreadSanitizer`
 | |
| or :doc:`MemorySanitizer` may want to disable or alter some checks for
 | |
| certain source-level entities to:
 | |
| 
 | |
| * speedup hot function, which is known to be correct;
 | |
| * ignore a function that does some low-level magic (e.g. walks through the
 | |
|   thread stack, bypassing the frame boundaries);
 | |
| * ignore a known problem.
 | |
| 
 | |
| To achieve this, user may create a file listing the entities they want to
 | |
| ignore, and pass it to clang at compile-time using
 | |
| ``-fsanitize-blacklist`` flag. See :doc:`UsersManual` for details.
 | |
| 
 | |
| Example
 | |
| =======
 | |
| 
 | |
| .. code-block:: bash
 | |
| 
 | |
|   $ cat foo.c
 | |
|   #include <stdlib.h>
 | |
|   void bad_foo() {
 | |
|     int *a = (int*)malloc(40);
 | |
|     a[10] = 1;
 | |
|   }
 | |
|   int main() { bad_foo(); }
 | |
|   $ cat blacklist.txt
 | |
|   # Ignore reports from bad_foo function.
 | |
|   fun:bad_foo
 | |
|   $ clang -fsanitize=address foo.c ; ./a.out
 | |
|   # AddressSanitizer prints an error report.
 | |
|   $ clang -fsanitize=address -fsanitize-blacklist=blacklist.txt foo.c ; ./a.out
 | |
|   # No error report here.
 | |
| 
 | |
| Format
 | |
| ======
 | |
| 
 | |
| Blacklists consist of entries, optionally grouped into sections. Empty lines and
 | |
| lines starting with "#" are ignored.
 | |
| 
 | |
| Section names are regular expressions written in square brackets that denote
 | |
| which sanitizer the following entries apply to. For example, ``[address]``
 | |
| specifies AddressSanitizer while ``[cfi-vcall|cfi-icall]`` specifies Control
 | |
| Flow Integrity virtual and indirect call checking. Entries without a section
 | |
| will be placed under the ``[*]`` section applying to all enabled sanitizers.
 | |
| 
 | |
| Entries contain an entity type, followed by a colon and a regular expression,
 | |
| specifying the names of the entities, optionally followed by an equals sign and
 | |
| a tool-specific category, e.g. ``fun:*ExampleFunc=example_category``.  The
 | |
| meaning of ``*`` in regular expression for entity names is different - it is
 | |
| treated as in shell wildcarding. Two generic entity types are ``src`` and
 | |
| ``fun``, which allow users to specify source files and functions, respectively.
 | |
| Some sanitizer tools may introduce custom entity types and categories - refer to
 | |
| tool-specific docs.
 | |
| 
 | |
| .. code-block:: bash
 | |
| 
 | |
|     # Lines starting with # are ignored.
 | |
|     # Turn off checks for the source file (use absolute path or path relative
 | |
|     # to the current working directory):
 | |
|     src:/path/to/source/file.c
 | |
|     # Turn off checks for a particular functions (use mangled names):
 | |
|     fun:MyFooBar
 | |
|     fun:_Z8MyFooBarv
 | |
|     # Extended regular expressions are supported:
 | |
|     fun:bad_(foo|bar)
 | |
|     src:bad_source[1-9].c
 | |
|     # Shell like usage of * is supported (* is treated as .*):
 | |
|     src:bad/sources/*
 | |
|     fun:*BadFunction*
 | |
|     # Specific sanitizer tools may introduce categories.
 | |
|     src:/special/path/*=special_sources
 | |
|     # Sections can be used to limit blacklist entries to specific sanitizers
 | |
|     [address]
 | |
|     fun:*BadASanFunc*
 | |
|     # Section names are regular expressions
 | |
|     [cfi-vcall|cfi-icall]
 | |
|     fun:*BadCfiCall
 | |
|     # Entries without sections are placed into [*] and apply to all sanitizers
 |