~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/tools/perf/Documentation/Build.txt

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /tools/perf/Documentation/Build.txt (Version linux-6.12-rc7) and /tools/perf/Documentation/Build.txt (Version policy-sample)


  1                                                   
  2 1) perf build                                     
  3 =============                                     
  4 The perf build process consists of several sep    
  5 which are linked together to form the perf bin    
  6   - libperf library (static)                      
  7   - perf builtin commands                         
  8   - traceevent library (static)                   
  9   - GTK ui library                                
 10                                                   
 11 Several makefiles govern the perf build:          
 12                                                   
 13   - Makefile                                      
 14     top level Makefile working as a wrapper th    
 15     Makefile.perf with a -j option to do paral    
 16                                                   
 17   - Makefile.perf                                 
 18     main makefile that triggers build of all p    
 19     installation and documentation processing.    
 20                                                   
 21   - tools/build/Makefile.build                    
 22     main makefile of the build framework          
 23                                                   
 24   - tools/build/Build.include                     
 25     build framework generic definitions           
 26                                                   
 27   - Build makefiles                               
 28     makefiles that defines build objects          
 29                                                   
 30 Please refer to tools/build/Documentation/Buil    
 31 information about build framework.                
 32                                                   
 33                                                   
 34 2) perf build                                     
 35 =============                                     
 36 The Makefile.perf triggers the build framework    
 37    perf, libperf, gtk                             
 38                                                   
 39 resulting in following objects:                   
 40   $ ls  *-in.o                                    
 41   gtk-in.o  libperf-in.o  perf-in.o               
 42                                                   
 43 Those objects are then used in final linking:     
 44   libperf-gtk.so <- gtk-in.o  libperf-in.o        
 45   perf           <- perf-in.o libperf-in.o        
 46                                                   
 47                                                   
 48 NOTE this description is omitting other librar    
 49      focusing on build framework outcomes         
 50                                                   
 51 3) Build with ASan or UBSan                       
 52 ==========================                        
 53   $ cd tools/perf                                 
 54   $ make DESTDIR=/usr                             
 55   $ make DESTDIR=/usr install                     
 56                                                   
 57 AddressSanitizer (or ASan) is a GCC feature th    
 58 such as buffer overflows and memory leaks.        
 59                                                   
 60   $ cd tools/perf                                 
 61   $ make DEBUG=1 EXTRA_CFLAGS='-fno-omit-frame    
 62   $ ASAN_OPTIONS=log_path=asan.log ./perf reco    
 63                                                   
 64 ASan outputs all detected issues into a log fi    
 65                                                   
 66 UndefinedBehaviorSanitizer (or UBSan) is a fas    
 67 supported by GCC. UBSan detects undefined beha    
 68                                                   
 69   $ cd tools/perf                                 
 70   $ make DEBUG=1 EXTRA_CFLAGS='-fno-omit-frame    
 71   $ UBSAN_OPTIONS=print_stacktrace=1 ./perf re    
 72                                                   
 73 If UBSan detects any problem at runtime, it ou    
 74                                                   
 75 4) Cross compilation                              
 76 ====================                              
 77 As Multiarch is commonly supported in Linux di    
 78 libraries for multiple architectures on the sa    
 79 Linux perf. For example, Aarch64 libraries and    
 80 an x86_64 machine, allowing us to compile perf    
 81                                                   
 82 Below is the command for building the perf wit    
 83                                                   
 84   $ cd /path/to/Linux                             
 85   $ make ARCH=arm64 CROSS_COMPILE=aarch64-linu    
 86                                                   
 87 For static linking, the option `LDFLAGS="-stat    
 88                                                   
 89   $ make ARCH=arm64 CROSS_COMPILE=aarch64-linu    
 90     LDFLAGS="-static" -C tools/perf               
 91                                                   
 92 In the embedded system world, a use case is to    
 93 configuration paths for cross building:           
 94                                                   
 95   $ PKG_CONFIG_SYSROOT_DIR="/path/to/cross/bui    
 96     PKG_CONFIG_LIBDIR="/usr/lib/:/usr/local/li    
 97     make ARCH=arm64 CROSS_COMPILE=aarch64-linu    
 98                                                   
 99 In this case, the variable PKG_CONFIG_SYSROOT_    
100 variable PKG_CONFIG_LIBDIR or PKG_CONFIG_PATH     
101 the library paths for cross compilation.          
                                                      

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php