Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 1 | # The default target of this Makefile is... |
| 2 | all:: |
Ingo Molnar | e0143ba | 2009-03-23 21:29:59 +0100 | [diff] [blame] | 3 | |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 4 | # Define V=1 to have a more verbose compile. |
| 5 | # |
| 6 | # Define SNPRINTF_RETURNS_BOGUS if your are on a system which snprintf() |
| 7 | # or vsnprintf() return -1 instead of number of characters which would |
| 8 | # have been written to the final string if enough space had been available. |
| 9 | # |
| 10 | # Define FREAD_READS_DIRECTORIES if your are on a system which succeeds |
| 11 | # when attempting to read from an fopen'ed directory. |
| 12 | # |
| 13 | # Define NO_OPENSSL environment variable if you do not have OpenSSL. |
| 14 | # This also implies MOZILLA_SHA1. |
| 15 | # |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 16 | # Define CURLDIR=/foo/bar if your curl header and library files are in |
| 17 | # /foo/bar/include and /foo/bar/lib directories. |
| 18 | # |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 19 | # Define EXPATDIR=/foo/bar if your expat header and library files are in |
| 20 | # /foo/bar/include and /foo/bar/lib directories. |
| 21 | # |
| 22 | # Define NO_D_INO_IN_DIRENT if you don't have d_ino in your struct dirent. |
| 23 | # |
| 24 | # Define NO_D_TYPE_IN_DIRENT if your platform defines DT_UNKNOWN but lacks |
| 25 | # d_type in struct dirent (latest Cygwin -- will be fixed soonish). |
| 26 | # |
| 27 | # Define NO_C99_FORMAT if your formatted IO functions (printf/scanf et.al.) |
| 28 | # do not support the 'size specifiers' introduced by C99, namely ll, hh, |
| 29 | # j, z, t. (representing long long int, char, intmax_t, size_t, ptrdiff_t). |
| 30 | # some C compilers supported these specifiers prior to C99 as an extension. |
| 31 | # |
| 32 | # Define NO_STRCASESTR if you don't have strcasestr. |
| 33 | # |
| 34 | # Define NO_MEMMEM if you don't have memmem. |
| 35 | # |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 36 | # Define NO_STRTOUMAX if you don't have strtoumax in the C library. |
| 37 | # If your compiler also does not support long long or does not have |
| 38 | # strtoull, define NO_STRTOULL. |
| 39 | # |
| 40 | # Define NO_SETENV if you don't have setenv in the C library. |
| 41 | # |
| 42 | # Define NO_UNSETENV if you don't have unsetenv in the C library. |
| 43 | # |
| 44 | # Define NO_MKDTEMP if you don't have mkdtemp in the C library. |
| 45 | # |
| 46 | # Define NO_SYS_SELECT_H if you don't have sys/select.h. |
| 47 | # |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 48 | # Define NO_SYMLINK_HEAD if you never want .perf/HEAD to be a symbolic link. |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 49 | # Enable it on Windows. By default, symrefs are still used. |
| 50 | # |
| 51 | # Define NO_SVN_TESTS if you want to skip time-consuming SVN interoperability |
| 52 | # tests. These tests take up a significant amount of the total test time |
| 53 | # but are not needed unless you plan to talk to SVN repos. |
| 54 | # |
| 55 | # Define NO_FINK if you are building on Darwin/Mac OS X, have Fink |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 56 | # installed in /sw, but don't want PERF to link against any libraries |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 57 | # installed there. If defined you may specify your own (or Fink's) |
| 58 | # include directories and library directories by defining CFLAGS |
| 59 | # and LDFLAGS appropriately. |
| 60 | # |
| 61 | # Define NO_DARWIN_PORTS if you are building on Darwin/Mac OS X, |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 62 | # have DarwinPorts installed in /opt/local, but don't want PERF to |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 63 | # link against any libraries installed there. If defined you may |
| 64 | # specify your own (or DarwinPort's) include directories and |
| 65 | # library directories by defining CFLAGS and LDFLAGS appropriately. |
| 66 | # |
| 67 | # Define PPC_SHA1 environment variable when running make to make use of |
| 68 | # a bundled SHA1 routine optimized for PowerPC. |
| 69 | # |
| 70 | # Define ARM_SHA1 environment variable when running make to make use of |
| 71 | # a bundled SHA1 routine optimized for ARM. |
| 72 | # |
| 73 | # Define MOZILLA_SHA1 environment variable when running make to make use of |
| 74 | # a bundled SHA1 routine coming from Mozilla. It is GPL'd and should be fast |
| 75 | # on non-x86 architectures (e.g. PowerPC), while the OpenSSL version (default |
| 76 | # choice) has very fast version optimized for i586. |
| 77 | # |
| 78 | # Define NEEDS_SSL_WITH_CRYPTO if you need -lcrypto with -lssl (Darwin). |
| 79 | # |
| 80 | # Define NEEDS_LIBICONV if linking with libc is not enough (Darwin). |
| 81 | # |
| 82 | # Define NEEDS_SOCKET if linking with libc is not enough (SunOS, |
| 83 | # Patrick Mauritz). |
| 84 | # |
| 85 | # Define NO_MMAP if you want to avoid mmap. |
| 86 | # |
| 87 | # Define NO_PTHREADS if you do not have or do not want to use Pthreads. |
| 88 | # |
| 89 | # Define NO_PREAD if you have a problem with pread() system call (e.g. |
| 90 | # cygwin.dll before v1.5.22). |
| 91 | # |
| 92 | # Define NO_FAST_WORKING_DIRECTORY if accessing objects in pack files is |
| 93 | # generally faster on your platform than accessing the working directory. |
| 94 | # |
| 95 | # Define NO_TRUSTABLE_FILEMODE if your filesystem may claim to support |
| 96 | # the executable mode bit, but doesn't really do so. |
| 97 | # |
| 98 | # Define NO_IPV6 if you lack IPv6 support and getaddrinfo(). |
| 99 | # |
| 100 | # Define NO_SOCKADDR_STORAGE if your platform does not have struct |
| 101 | # sockaddr_storage. |
| 102 | # |
| 103 | # Define NO_ICONV if your libc does not properly support iconv. |
| 104 | # |
| 105 | # Define OLD_ICONV if your library has an old iconv(), where the second |
| 106 | # (input buffer pointer) parameter is declared with type (const char **). |
| 107 | # |
| 108 | # Define NO_DEFLATE_BOUND if your zlib does not have deflateBound. |
| 109 | # |
| 110 | # Define NO_R_TO_GCC_LINKER if your gcc does not like "-R/path/lib" |
| 111 | # that tells runtime paths to dynamic libraries; |
| 112 | # "-Wl,-rpath=/path/lib" is used instead. |
| 113 | # |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 114 | # Define USE_NSEC below if you want perf to care about sub-second file mtimes |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 115 | # and ctimes. Note that you need recent glibc (at least 2.2.4) for this, and |
| 116 | # it will BREAK YOUR LOCAL DIFFS! show-diff and anything using it will likely |
| 117 | # randomly break unless your underlying filesystem supports those sub-second |
| 118 | # times (my ext3 doesn't). |
| 119 | # |
| 120 | # Define USE_ST_TIMESPEC if your "struct stat" uses "st_ctimespec" instead of |
| 121 | # "st_ctim" |
| 122 | # |
| 123 | # Define NO_NSEC if your "struct stat" does not have "st_ctim.tv_nsec" |
| 124 | # available. This automatically turns USE_NSEC off. |
| 125 | # |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 126 | # Define USE_STDEV below if you want perf to care about the underlying device |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 127 | # change being considered an inode change from the update-index perspective. |
| 128 | # |
| 129 | # Define NO_ST_BLOCKS_IN_STRUCT_STAT if your platform does not have st_blocks |
| 130 | # field that counts the on-disk footprint in 512-byte blocks. |
| 131 | # |
| 132 | # Define ASCIIDOC8 if you want to format documentation with AsciiDoc 8 |
| 133 | # |
| 134 | # Define DOCBOOK_XSL_172 if you want to format man pages with DocBook XSL v1.72. |
| 135 | # |
| 136 | # Define NO_PERL_MAKEMAKER if you cannot use Makefiles generated by perl's |
| 137 | # MakeMaker (e.g. using ActiveState under Cygwin). |
| 138 | # |
| 139 | # Define NO_PERL if you do not want Perl scripts or libraries at all. |
| 140 | # |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 141 | # Define INTERNAL_QSORT to use Git's implementation of qsort(), which |
| 142 | # is a simplified version of the merge sort used in glibc. This is |
| 143 | # recommended if Git triggers O(n^2) behavior in your platform's qsort(). |
| 144 | # |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 145 | # Define NO_EXTERNAL_GREP if you don't want "perf grep" to ever call |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 146 | # your external grep (e.g., if your system lacks grep, if its grep is |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 147 | # broken, or spawning external process is slower than built-in grep perf has). |
Ingo Molnar | e0143ba | 2009-03-23 21:29:59 +0100 | [diff] [blame] | 148 | |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 149 | PERF-VERSION-FILE: .FORCE-PERF-VERSION-FILE |
Ingo Molnar | 148be2c | 2009-04-27 08:02:14 +0200 | [diff] [blame] | 150 | @$(SHELL_PATH) util/PERF-VERSION-GEN |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 151 | -include PERF-VERSION-FILE |
Ingo Molnar | e0143ba | 2009-03-23 21:29:59 +0100 | [diff] [blame] | 152 | |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 153 | uname_S := $(shell sh -c 'uname -s 2>/dev/null || echo not') |
| 154 | uname_M := $(shell sh -c 'uname -m 2>/dev/null || echo not') |
| 155 | uname_O := $(shell sh -c 'uname -o 2>/dev/null || echo not') |
| 156 | uname_R := $(shell sh -c 'uname -r 2>/dev/null || echo not') |
| 157 | uname_P := $(shell sh -c 'uname -p 2>/dev/null || echo not') |
| 158 | uname_V := $(shell sh -c 'uname -v 2>/dev/null || echo not') |
Peter Zijlstra | de9ac07 | 2009-04-08 15:01:31 +0200 | [diff] [blame] | 159 | |
Paul Mackerras | e24a72c | 2009-06-17 21:54:26 +1000 | [diff] [blame] | 160 | # If we're on a 64-bit kernel, use -m64 |
| 161 | ifneq ($(patsubst %64,%,$(uname_M)),$(uname_M)) |
| 162 | M64 := -m64 |
| 163 | endif |
| 164 | |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 165 | # CFLAGS and LDFLAGS are for the users to override from the command line. |
Peter Zijlstra | de9ac07 | 2009-04-08 15:01:31 +0200 | [diff] [blame] | 166 | |
Ingo Molnar | b8e6d82 | 2009-06-18 14:32:19 +0200 | [diff] [blame] | 167 | CFLAGS = $(M64) -ggdb3 -Wall -Wstrict-prototypes -Wmissing-declarations -Wmissing-prototypes -std=gnu99 -Wdeclaration-after-statement -Werror -O6 |
Ingo Molnar | ef281a1 | 2009-06-13 15:40:35 +0200 | [diff] [blame] | 168 | LDFLAGS = -lpthread -lrt -lelf -lm |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 169 | ALL_CFLAGS = $(CFLAGS) |
| 170 | ALL_LDFLAGS = $(LDFLAGS) |
| 171 | STRIP ?= strip |
| 172 | |
| 173 | # Among the variables below, these: |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 174 | # perfexecdir |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 175 | # template_dir |
| 176 | # mandir |
| 177 | # infodir |
| 178 | # htmldir |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 179 | # ETC_PERFCONFIG (but not sysconfdir) |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 180 | # can be specified as a relative path some/where/else; |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 181 | # this is interpreted as relative to $(prefix) and "perf" at |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 182 | # runtime figures out where they are based on the path to the executable. |
| 183 | # This can help installing the suite in a relocatable way. |
| 184 | |
| 185 | prefix = $(HOME) |
| 186 | bindir_relative = bin |
| 187 | bindir = $(prefix)/$(bindir_relative) |
| 188 | mandir = share/man |
| 189 | infodir = share/info |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 190 | perfexecdir = libexec/perf-core |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 191 | sharedir = $(prefix)/share |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 192 | template_dir = share/perf-core/templates |
| 193 | htmldir = share/doc/perf-doc |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 194 | ifeq ($(prefix),/usr) |
| 195 | sysconfdir = /etc |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 196 | ETC_PERFCONFIG = $(sysconfdir)/perfconfig |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 197 | else |
| 198 | sysconfdir = $(prefix)/etc |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 199 | ETC_PERFCONFIG = etc/perfconfig |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 200 | endif |
| 201 | lib = lib |
| 202 | # DESTDIR= |
| 203 | |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 204 | export prefix bindir sharedir sysconfdir |
| 205 | |
| 206 | CC = gcc |
| 207 | AR = ar |
| 208 | RM = rm -f |
| 209 | TAR = tar |
| 210 | FIND = find |
| 211 | INSTALL = install |
| 212 | RPMBUILD = rpmbuild |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 213 | PTHREAD_LIBS = -lpthread |
| 214 | |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 215 | # sparse is architecture-neutral, which means that we need to tell it |
| 216 | # explicitly what architecture to check for. Fix this up for yours.. |
| 217 | SPARSE_FLAGS = -D__BIG_ENDIAN__ -D__powerpc__ |
| 218 | |
| 219 | |
| 220 | |
| 221 | ### --- END CONFIGURATION SECTION --- |
| 222 | |
| 223 | # Those must not be GNU-specific; they are shared with perl/ which may |
| 224 | # be built by a different compiler. (Note that this is an artifact now |
| 225 | # but it still might be nice to keep that distinction.) |
| 226 | BASIC_CFLAGS = |
| 227 | BASIC_LDFLAGS = |
| 228 | |
| 229 | # Guard against environment variables |
| 230 | BUILTIN_OBJS = |
| 231 | BUILT_INS = |
| 232 | COMPAT_CFLAGS = |
| 233 | COMPAT_OBJS = |
| 234 | LIB_H = |
| 235 | LIB_OBJS = |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 236 | SCRIPT_PERL = |
| 237 | SCRIPT_SH = |
| 238 | TEST_PROGRAMS = |
| 239 | |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 240 | # |
| 241 | # No scripts right now: |
| 242 | # |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 243 | |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 244 | # SCRIPT_SH += perf-am.sh |
| 245 | |
| 246 | # |
| 247 | # No Perl scripts right now: |
| 248 | # |
| 249 | |
| 250 | # SCRIPT_PERL += perf-add--interactive.perl |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 251 | |
| 252 | SCRIPTS = $(patsubst %.sh,%,$(SCRIPT_SH)) \ |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 253 | $(patsubst %.perl,%,$(SCRIPT_PERL)) |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 254 | |
| 255 | # Empty... |
| 256 | EXTRA_PROGRAMS = |
| 257 | |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 258 | # ... and all the rest that could be moved out of bindir to perfexecdir |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 259 | PROGRAMS += $(EXTRA_PROGRAMS) |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 260 | |
| 261 | # |
Ingo Molnar | 125e702 | 2009-04-20 16:13:46 +0200 | [diff] [blame] | 262 | # Single 'perf' binary right now: |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 263 | # |
Ingo Molnar | 125e702 | 2009-04-20 16:13:46 +0200 | [diff] [blame] | 264 | PROGRAMS += perf |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 265 | |
| 266 | # List built-in command $C whose implementation cmd_$C() is not in |
| 267 | # builtin-$C.o but is linked in as part of some other command. |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 268 | # |
| 269 | # None right now: |
| 270 | # |
| 271 | # BUILT_INS += perf-init $X |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 272 | |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 273 | # what 'all' will build and 'install' will install, in perfexecdir |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 274 | ALL_PROGRAMS = $(PROGRAMS) $(SCRIPTS) |
| 275 | |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 276 | # what 'all' will build but not install in perfexecdir |
| 277 | OTHER_PROGRAMS = perf$X |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 278 | |
| 279 | # Set paths to tools early so that they can be used for version tests. |
| 280 | ifndef SHELL_PATH |
| 281 | SHELL_PATH = /bin/sh |
| 282 | endif |
| 283 | ifndef PERL_PATH |
| 284 | PERL_PATH = /usr/bin/perl |
| 285 | endif |
| 286 | |
| 287 | export PERL_PATH |
| 288 | |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 289 | LIB_FILE=libperf.a |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 290 | |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 291 | LIB_H += ../../include/linux/perf_counter.h |
Thomas Gleixner | 6eda583 | 2009-05-01 18:29:57 +0200 | [diff] [blame] | 292 | LIB_H += perf.h |
Peter Zijlstra | 7c6a1c6 | 2009-06-25 17:05:54 +0200 | [diff] [blame] | 293 | LIB_H += util/types.h |
Arnaldo Carvalho de Melo | 35a50c8 | 2009-05-18 16:24:49 -0300 | [diff] [blame] | 294 | LIB_H += util/list.h |
| 295 | LIB_H += util/rbtree.h |
Ingo Molnar | 148be2c | 2009-04-27 08:02:14 +0200 | [diff] [blame] | 296 | LIB_H += util/levenshtein.h |
| 297 | LIB_H += util/parse-options.h |
Ingo Molnar | 8ad8db3 | 2009-05-26 11:10:09 +0200 | [diff] [blame] | 298 | LIB_H += util/parse-events.h |
Ingo Molnar | 148be2c | 2009-04-27 08:02:14 +0200 | [diff] [blame] | 299 | LIB_H += util/quote.h |
| 300 | LIB_H += util/util.h |
| 301 | LIB_H += util/help.h |
| 302 | LIB_H += util/strbuf.h |
Arnaldo Carvalho de Melo | a0055ae | 2009-06-01 17:50:19 -0300 | [diff] [blame] | 303 | LIB_H += util/string.h |
Arnaldo Carvalho de Melo | 2590340 | 2009-06-30 19:01:20 -0300 | [diff] [blame^] | 304 | LIB_H += util/strlist.h |
Ingo Molnar | 148be2c | 2009-04-27 08:02:14 +0200 | [diff] [blame] | 305 | LIB_H += util/run-command.h |
Ingo Molnar | a930d2c | 2009-05-27 09:50:13 +0200 | [diff] [blame] | 306 | LIB_H += util/sigchain.h |
Arnaldo Carvalho de Melo | a2928c4 | 2009-05-28 14:55:04 -0300 | [diff] [blame] | 307 | LIB_H += util/symbol.h |
Ingo Molnar | 8fc0321 | 2009-06-04 15:19:47 +0200 | [diff] [blame] | 308 | LIB_H += util/color.h |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 309 | |
Ingo Molnar | 148be2c | 2009-04-27 08:02:14 +0200 | [diff] [blame] | 310 | LIB_OBJS += util/abspath.o |
| 311 | LIB_OBJS += util/alias.o |
| 312 | LIB_OBJS += util/config.o |
| 313 | LIB_OBJS += util/ctype.o |
Ingo Molnar | a930d2c | 2009-05-27 09:50:13 +0200 | [diff] [blame] | 314 | LIB_OBJS += util/environment.o |
Ingo Molnar | 148be2c | 2009-04-27 08:02:14 +0200 | [diff] [blame] | 315 | LIB_OBJS += util/exec_cmd.o |
| 316 | LIB_OBJS += util/help.o |
| 317 | LIB_OBJS += util/levenshtein.o |
| 318 | LIB_OBJS += util/parse-options.o |
Ingo Molnar | 8ad8db3 | 2009-05-26 11:10:09 +0200 | [diff] [blame] | 319 | LIB_OBJS += util/parse-events.o |
Ingo Molnar | 148be2c | 2009-04-27 08:02:14 +0200 | [diff] [blame] | 320 | LIB_OBJS += util/path.o |
Arnaldo Carvalho de Melo | 35a50c8 | 2009-05-18 16:24:49 -0300 | [diff] [blame] | 321 | LIB_OBJS += util/rbtree.o |
Ingo Molnar | 148be2c | 2009-04-27 08:02:14 +0200 | [diff] [blame] | 322 | LIB_OBJS += util/run-command.o |
| 323 | LIB_OBJS += util/quote.o |
| 324 | LIB_OBJS += util/strbuf.o |
Arnaldo Carvalho de Melo | a0055ae | 2009-06-01 17:50:19 -0300 | [diff] [blame] | 325 | LIB_OBJS += util/string.o |
Arnaldo Carvalho de Melo | 2590340 | 2009-06-30 19:01:20 -0300 | [diff] [blame^] | 326 | LIB_OBJS += util/strlist.o |
Ingo Molnar | 148be2c | 2009-04-27 08:02:14 +0200 | [diff] [blame] | 327 | LIB_OBJS += util/usage.o |
| 328 | LIB_OBJS += util/wrapper.o |
Ingo Molnar | a930d2c | 2009-05-27 09:50:13 +0200 | [diff] [blame] | 329 | LIB_OBJS += util/sigchain.o |
Arnaldo Carvalho de Melo | a2928c4 | 2009-05-28 14:55:04 -0300 | [diff] [blame] | 330 | LIB_OBJS += util/symbol.o |
Ingo Molnar | 8fc0321 | 2009-06-04 15:19:47 +0200 | [diff] [blame] | 331 | LIB_OBJS += util/color.o |
Ingo Molnar | a930d2c | 2009-05-27 09:50:13 +0200 | [diff] [blame] | 332 | LIB_OBJS += util/pager.o |
Peter Zijlstra | 7c6a1c6 | 2009-06-25 17:05:54 +0200 | [diff] [blame] | 333 | LIB_OBJS += util/header.o |
Frederic Weisbecker | 8cb76d9 | 2009-06-26 16:28:00 +0200 | [diff] [blame] | 334 | LIB_OBJS += util/callchain.o |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 335 | |
Ingo Molnar | 8035e42 | 2009-06-06 15:19:13 +0200 | [diff] [blame] | 336 | BUILTIN_OBJS += builtin-annotate.o |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 337 | BUILTIN_OBJS += builtin-help.o |
Ingo Molnar | 8035e42 | 2009-06-06 15:19:13 +0200 | [diff] [blame] | 338 | BUILTIN_OBJS += builtin-list.o |
Ingo Molnar | e33e0a4 | 2009-04-20 15:58:01 +0200 | [diff] [blame] | 339 | BUILTIN_OBJS += builtin-record.o |
Arnaldo Carvalho de Melo | 8fa66bd | 2009-05-18 12:45:42 -0300 | [diff] [blame] | 340 | BUILTIN_OBJS += builtin-report.o |
Ingo Molnar | ddcacfa | 2009-04-20 15:37:32 +0200 | [diff] [blame] | 341 | BUILTIN_OBJS += builtin-stat.o |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 342 | BUILTIN_OBJS += builtin-top.o |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 343 | |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 344 | PERFLIBS = $(LIB_FILE) |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 345 | EXTLIBS = |
| 346 | |
| 347 | # |
| 348 | # Platform specific tweaks |
| 349 | # |
| 350 | |
| 351 | # We choose to avoid "if .. else if .. else .. endif endif" |
| 352 | # because maintaining the nesting to match is a pain. If |
| 353 | # we had "elif" things would have been much nicer... |
| 354 | |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 355 | -include config.mak.autogen |
| 356 | -include config.mak |
| 357 | |
| 358 | ifeq ($(uname_S),Darwin) |
| 359 | ifndef NO_FINK |
| 360 | ifeq ($(shell test -d /sw/lib && echo y),y) |
| 361 | BASIC_CFLAGS += -I/sw/include |
| 362 | BASIC_LDFLAGS += -L/sw/lib |
| 363 | endif |
| 364 | endif |
| 365 | ifndef NO_DARWIN_PORTS |
| 366 | ifeq ($(shell test -d /opt/local/lib && echo y),y) |
| 367 | BASIC_CFLAGS += -I/opt/local/include |
| 368 | BASIC_LDFLAGS += -L/opt/local/lib |
| 369 | endif |
| 370 | endif |
| 371 | PTHREAD_LIBS = |
| 372 | endif |
| 373 | |
| 374 | ifndef CC_LD_DYNPATH |
| 375 | ifdef NO_R_TO_GCC_LINKER |
| 376 | # Some gcc does not accept and pass -R to the linker to specify |
| 377 | # the runtime dynamic library path. |
| 378 | CC_LD_DYNPATH = -Wl,-rpath, |
| 379 | else |
| 380 | CC_LD_DYNPATH = -R |
| 381 | endif |
| 382 | endif |
| 383 | |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 384 | ifdef ZLIB_PATH |
| 385 | BASIC_CFLAGS += -I$(ZLIB_PATH)/include |
| 386 | EXTLIBS += -L$(ZLIB_PATH)/$(lib) $(CC_LD_DYNPATH)$(ZLIB_PATH)/$(lib) |
| 387 | endif |
| 388 | EXTLIBS += -lz |
| 389 | |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 390 | ifdef NEEDS_SOCKET |
| 391 | EXTLIBS += -lsocket |
| 392 | endif |
| 393 | ifdef NEEDS_NSL |
| 394 | EXTLIBS += -lnsl |
| 395 | endif |
| 396 | ifdef NO_D_TYPE_IN_DIRENT |
| 397 | BASIC_CFLAGS += -DNO_D_TYPE_IN_DIRENT |
| 398 | endif |
| 399 | ifdef NO_D_INO_IN_DIRENT |
| 400 | BASIC_CFLAGS += -DNO_D_INO_IN_DIRENT |
| 401 | endif |
| 402 | ifdef NO_ST_BLOCKS_IN_STRUCT_STAT |
| 403 | BASIC_CFLAGS += -DNO_ST_BLOCKS_IN_STRUCT_STAT |
| 404 | endif |
| 405 | ifdef USE_NSEC |
| 406 | BASIC_CFLAGS += -DUSE_NSEC |
| 407 | endif |
| 408 | ifdef USE_ST_TIMESPEC |
| 409 | BASIC_CFLAGS += -DUSE_ST_TIMESPEC |
| 410 | endif |
| 411 | ifdef NO_NSEC |
| 412 | BASIC_CFLAGS += -DNO_NSEC |
| 413 | endif |
| 414 | ifdef NO_C99_FORMAT |
| 415 | BASIC_CFLAGS += -DNO_C99_FORMAT |
| 416 | endif |
| 417 | ifdef SNPRINTF_RETURNS_BOGUS |
| 418 | COMPAT_CFLAGS += -DSNPRINTF_RETURNS_BOGUS |
| 419 | COMPAT_OBJS += compat/snprintf.o |
| 420 | endif |
| 421 | ifdef FREAD_READS_DIRECTORIES |
| 422 | COMPAT_CFLAGS += -DFREAD_READS_DIRECTORIES |
| 423 | COMPAT_OBJS += compat/fopen.o |
| 424 | endif |
| 425 | ifdef NO_SYMLINK_HEAD |
| 426 | BASIC_CFLAGS += -DNO_SYMLINK_HEAD |
| 427 | endif |
| 428 | ifdef NO_STRCASESTR |
| 429 | COMPAT_CFLAGS += -DNO_STRCASESTR |
| 430 | COMPAT_OBJS += compat/strcasestr.o |
| 431 | endif |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 432 | ifdef NO_STRTOUMAX |
| 433 | COMPAT_CFLAGS += -DNO_STRTOUMAX |
| 434 | COMPAT_OBJS += compat/strtoumax.o |
| 435 | endif |
| 436 | ifdef NO_STRTOULL |
| 437 | COMPAT_CFLAGS += -DNO_STRTOULL |
| 438 | endif |
| 439 | ifdef NO_SETENV |
| 440 | COMPAT_CFLAGS += -DNO_SETENV |
| 441 | COMPAT_OBJS += compat/setenv.o |
| 442 | endif |
| 443 | ifdef NO_MKDTEMP |
| 444 | COMPAT_CFLAGS += -DNO_MKDTEMP |
| 445 | COMPAT_OBJS += compat/mkdtemp.o |
| 446 | endif |
| 447 | ifdef NO_UNSETENV |
| 448 | COMPAT_CFLAGS += -DNO_UNSETENV |
| 449 | COMPAT_OBJS += compat/unsetenv.o |
| 450 | endif |
| 451 | ifdef NO_SYS_SELECT_H |
| 452 | BASIC_CFLAGS += -DNO_SYS_SELECT_H |
| 453 | endif |
| 454 | ifdef NO_MMAP |
| 455 | COMPAT_CFLAGS += -DNO_MMAP |
| 456 | COMPAT_OBJS += compat/mmap.o |
| 457 | else |
| 458 | ifdef USE_WIN32_MMAP |
| 459 | COMPAT_CFLAGS += -DUSE_WIN32_MMAP |
| 460 | COMPAT_OBJS += compat/win32mmap.o |
| 461 | endif |
| 462 | endif |
| 463 | ifdef NO_PREAD |
| 464 | COMPAT_CFLAGS += -DNO_PREAD |
| 465 | COMPAT_OBJS += compat/pread.o |
| 466 | endif |
| 467 | ifdef NO_FAST_WORKING_DIRECTORY |
| 468 | BASIC_CFLAGS += -DNO_FAST_WORKING_DIRECTORY |
| 469 | endif |
| 470 | ifdef NO_TRUSTABLE_FILEMODE |
| 471 | BASIC_CFLAGS += -DNO_TRUSTABLE_FILEMODE |
| 472 | endif |
| 473 | ifdef NO_IPV6 |
| 474 | BASIC_CFLAGS += -DNO_IPV6 |
| 475 | endif |
| 476 | ifdef NO_UINTMAX_T |
| 477 | BASIC_CFLAGS += -Duintmax_t=uint32_t |
| 478 | endif |
| 479 | ifdef NO_SOCKADDR_STORAGE |
| 480 | ifdef NO_IPV6 |
| 481 | BASIC_CFLAGS += -Dsockaddr_storage=sockaddr_in |
| 482 | else |
| 483 | BASIC_CFLAGS += -Dsockaddr_storage=sockaddr_in6 |
| 484 | endif |
| 485 | endif |
| 486 | ifdef NO_INET_NTOP |
| 487 | LIB_OBJS += compat/inet_ntop.o |
| 488 | endif |
| 489 | ifdef NO_INET_PTON |
| 490 | LIB_OBJS += compat/inet_pton.o |
| 491 | endif |
| 492 | |
| 493 | ifdef NO_ICONV |
| 494 | BASIC_CFLAGS += -DNO_ICONV |
| 495 | endif |
| 496 | |
| 497 | ifdef OLD_ICONV |
| 498 | BASIC_CFLAGS += -DOLD_ICONV |
| 499 | endif |
| 500 | |
| 501 | ifdef NO_DEFLATE_BOUND |
| 502 | BASIC_CFLAGS += -DNO_DEFLATE_BOUND |
| 503 | endif |
| 504 | |
| 505 | ifdef PPC_SHA1 |
| 506 | SHA1_HEADER = "ppc/sha1.h" |
| 507 | LIB_OBJS += ppc/sha1.o ppc/sha1ppc.o |
| 508 | else |
| 509 | ifdef ARM_SHA1 |
| 510 | SHA1_HEADER = "arm/sha1.h" |
| 511 | LIB_OBJS += arm/sha1.o arm/sha1_arm.o |
| 512 | else |
| 513 | ifdef MOZILLA_SHA1 |
| 514 | SHA1_HEADER = "mozilla-sha1/sha1.h" |
| 515 | LIB_OBJS += mozilla-sha1/sha1.o |
| 516 | else |
| 517 | SHA1_HEADER = <openssl/sha.h> |
| 518 | EXTLIBS += $(LIB_4_CRYPTO) |
| 519 | endif |
| 520 | endif |
| 521 | endif |
| 522 | ifdef NO_PERL_MAKEMAKER |
| 523 | export NO_PERL_MAKEMAKER |
| 524 | endif |
| 525 | ifdef NO_HSTRERROR |
| 526 | COMPAT_CFLAGS += -DNO_HSTRERROR |
| 527 | COMPAT_OBJS += compat/hstrerror.o |
| 528 | endif |
| 529 | ifdef NO_MEMMEM |
| 530 | COMPAT_CFLAGS += -DNO_MEMMEM |
| 531 | COMPAT_OBJS += compat/memmem.o |
| 532 | endif |
| 533 | ifdef INTERNAL_QSORT |
| 534 | COMPAT_CFLAGS += -DINTERNAL_QSORT |
| 535 | COMPAT_OBJS += compat/qsort.o |
| 536 | endif |
| 537 | ifdef RUNTIME_PREFIX |
| 538 | COMPAT_CFLAGS += -DRUNTIME_PREFIX |
| 539 | endif |
| 540 | |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 541 | ifdef DIR_HAS_BSD_GROUP_SEMANTICS |
| 542 | COMPAT_CFLAGS += -DDIR_HAS_BSD_GROUP_SEMANTICS |
| 543 | endif |
| 544 | ifdef NO_EXTERNAL_GREP |
| 545 | BASIC_CFLAGS += -DNO_EXTERNAL_GREP |
| 546 | endif |
| 547 | |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 548 | ifeq ($(PERL_PATH),) |
| 549 | NO_PERL=NoThanks |
| 550 | endif |
| 551 | |
| 552 | QUIET_SUBDIR0 = +$(MAKE) -C # space to separate -C and subdir |
| 553 | QUIET_SUBDIR1 = |
| 554 | |
| 555 | ifneq ($(findstring $(MAKEFLAGS),w),w) |
| 556 | PRINT_DIR = --no-print-directory |
| 557 | else # "make -w" |
| 558 | NO_SUBDIR = : |
| 559 | endif |
| 560 | |
| 561 | ifneq ($(findstring $(MAKEFLAGS),s),s) |
| 562 | ifndef V |
| 563 | QUIET_CC = @echo ' ' CC $@; |
| 564 | QUIET_AR = @echo ' ' AR $@; |
| 565 | QUIET_LINK = @echo ' ' LINK $@; |
| 566 | QUIET_BUILT_IN = @echo ' ' BUILTIN $@; |
| 567 | QUIET_GEN = @echo ' ' GEN $@; |
| 568 | QUIET_SUBDIR0 = +@subdir= |
| 569 | QUIET_SUBDIR1 = ;$(NO_SUBDIR) echo ' ' SUBDIR $$subdir; \ |
| 570 | $(MAKE) $(PRINT_DIR) -C $$subdir |
| 571 | export V |
| 572 | export QUIET_GEN |
| 573 | export QUIET_BUILT_IN |
| 574 | endif |
| 575 | endif |
| 576 | |
| 577 | ifdef ASCIIDOC8 |
| 578 | export ASCIIDOC8 |
| 579 | endif |
| 580 | |
| 581 | # Shell quote (do not use $(call) to accommodate ancient setups); |
| 582 | |
| 583 | SHA1_HEADER_SQ = $(subst ','\'',$(SHA1_HEADER)) |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 584 | ETC_PERFCONFIG_SQ = $(subst ','\'',$(ETC_PERFCONFIG)) |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 585 | |
| 586 | DESTDIR_SQ = $(subst ','\'',$(DESTDIR)) |
| 587 | bindir_SQ = $(subst ','\'',$(bindir)) |
| 588 | bindir_relative_SQ = $(subst ','\'',$(bindir_relative)) |
| 589 | mandir_SQ = $(subst ','\'',$(mandir)) |
| 590 | infodir_SQ = $(subst ','\'',$(infodir)) |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 591 | perfexecdir_SQ = $(subst ','\'',$(perfexecdir)) |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 592 | template_dir_SQ = $(subst ','\'',$(template_dir)) |
| 593 | htmldir_SQ = $(subst ','\'',$(htmldir)) |
| 594 | prefix_SQ = $(subst ','\'',$(prefix)) |
| 595 | |
| 596 | SHELL_PATH_SQ = $(subst ','\'',$(SHELL_PATH)) |
| 597 | PERL_PATH_SQ = $(subst ','\'',$(PERL_PATH)) |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 598 | |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 599 | LIBS = $(PERFLIBS) $(EXTLIBS) |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 600 | |
| 601 | BASIC_CFLAGS += -DSHA1_HEADER='$(SHA1_HEADER_SQ)' \ |
| 602 | $(COMPAT_CFLAGS) |
| 603 | LIB_OBJS += $(COMPAT_OBJS) |
| 604 | |
| 605 | ALL_CFLAGS += $(BASIC_CFLAGS) |
| 606 | ALL_LDFLAGS += $(BASIC_LDFLAGS) |
| 607 | |
| 608 | export TAR INSTALL DESTDIR SHELL_PATH |
| 609 | |
| 610 | |
| 611 | ### Build rules |
| 612 | |
| 613 | SHELL = $(SHELL_PATH) |
| 614 | |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 615 | all:: shell_compatibility_test $(ALL_PROGRAMS) $(BUILT_INS) $(OTHER_PROGRAMS) PERF-BUILD-OPTIONS |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 616 | ifneq (,$X) |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 617 | $(foreach p,$(patsubst %$X,%,$(filter %$X,$(ALL_PROGRAMS) $(BUILT_INS) perf$X)), test '$p' -ef '$p$X' || $(RM) '$p';) |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 618 | endif |
| 619 | |
| 620 | all:: |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 621 | |
| 622 | please_set_SHELL_PATH_to_a_more_modern_shell: |
| 623 | @$$(:) |
| 624 | |
| 625 | shell_compatibility_test: please_set_SHELL_PATH_to_a_more_modern_shell |
| 626 | |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 627 | strip: $(PROGRAMS) perf$X |
| 628 | $(STRIP) $(STRIP_OPTS) $(PROGRAMS) perf$X |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 629 | |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 630 | perf.o: perf.c common-cmds.h PERF-CFLAGS |
| 631 | $(QUIET_CC)$(CC) -DPERF_VERSION='"$(PERF_VERSION)"' \ |
| 632 | '-DPERF_HTML_PATH="$(htmldir_SQ)"' \ |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 633 | $(ALL_CFLAGS) -c $(filter %.c,$^) |
| 634 | |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 635 | perf$X: perf.o $(BUILTIN_OBJS) $(PERFLIBS) |
| 636 | $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ perf.o \ |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 637 | $(BUILTIN_OBJS) $(ALL_LDFLAGS) $(LIBS) |
| 638 | |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 639 | builtin-help.o: builtin-help.c common-cmds.h PERF-CFLAGS |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 640 | $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) \ |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 641 | '-DPERF_HTML_PATH="$(htmldir_SQ)"' \ |
| 642 | '-DPERF_MAN_PATH="$(mandir_SQ)"' \ |
| 643 | '-DPERF_INFO_PATH="$(infodir_SQ)"' $< |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 644 | |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 645 | $(BUILT_INS): perf$X |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 646 | $(QUIET_BUILT_IN)$(RM) $@ && \ |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 647 | ln perf$X $@ 2>/dev/null || \ |
| 648 | ln -s perf$X $@ 2>/dev/null || \ |
| 649 | cp perf$X $@ |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 650 | |
Ingo Molnar | 148be2c | 2009-04-27 08:02:14 +0200 | [diff] [blame] | 651 | common-cmds.h: util/generate-cmdlist.sh command-list.txt |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 652 | |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 653 | common-cmds.h: $(wildcard Documentation/perf-*.txt) |
Ingo Molnar | 148be2c | 2009-04-27 08:02:14 +0200 | [diff] [blame] | 654 | $(QUIET_GEN)util/generate-cmdlist.sh > $@+ && mv $@+ $@ |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 655 | |
| 656 | $(patsubst %.sh,%,$(SCRIPT_SH)) : % : %.sh |
| 657 | $(QUIET_GEN)$(RM) $@ $@+ && \ |
| 658 | sed -e '1s|#!.*/sh|#!$(SHELL_PATH_SQ)|' \ |
| 659 | -e 's|@SHELL_PATH@|$(SHELL_PATH_SQ)|' \ |
| 660 | -e 's|@@PERL@@|$(PERL_PATH_SQ)|g' \ |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 661 | -e 's/@@PERF_VERSION@@/$(PERF_VERSION)/g' \ |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 662 | -e 's/@@NO_CURL@@/$(NO_CURL)/g' \ |
| 663 | $@.sh >$@+ && \ |
| 664 | chmod +x $@+ && \ |
| 665 | mv $@+ $@ |
| 666 | |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 667 | configure: configure.ac |
| 668 | $(QUIET_GEN)$(RM) $@ $<+ && \ |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 669 | sed -e 's/@@PERF_VERSION@@/$(PERF_VERSION)/g' \ |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 670 | $< > $<+ && \ |
| 671 | autoconf -o $@ $<+ && \ |
| 672 | $(RM) $<+ |
| 673 | |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 674 | # These can record PERF_VERSION |
| 675 | perf.o perf.spec \ |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 676 | $(patsubst %.sh,%,$(SCRIPT_SH)) \ |
| 677 | $(patsubst %.perl,%,$(SCRIPT_PERL)) \ |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 678 | : PERF-VERSION-FILE |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 679 | |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 680 | %.o: %.c PERF-CFLAGS |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 681 | $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) $< |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 682 | %.s: %.c PERF-CFLAGS |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 683 | $(QUIET_CC)$(CC) -S $(ALL_CFLAGS) $< |
| 684 | %.o: %.S |
| 685 | $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) $< |
| 686 | |
Ingo Molnar | 148be2c | 2009-04-27 08:02:14 +0200 | [diff] [blame] | 687 | util/exec_cmd.o: util/exec_cmd.c PERF-CFLAGS |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 688 | $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) \ |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 689 | '-DPERF_EXEC_PATH="$(perfexecdir_SQ)"' \ |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 690 | '-DBINDIR="$(bindir_relative_SQ)"' \ |
| 691 | '-DPREFIX="$(prefix_SQ)"' \ |
| 692 | $< |
| 693 | |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 694 | builtin-init-db.o: builtin-init-db.c PERF-CFLAGS |
| 695 | $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) -DDEFAULT_PERF_TEMPLATE_DIR='"$(template_dir_SQ)"' $< |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 696 | |
Ingo Molnar | 148be2c | 2009-04-27 08:02:14 +0200 | [diff] [blame] | 697 | util/config.o: util/config.c PERF-CFLAGS |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 698 | $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) -DETC_PERFCONFIG='"$(ETC_PERFCONFIG_SQ)"' $< |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 699 | |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 700 | perf-%$X: %.o $(PERFLIBS) |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 701 | $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) $(LIBS) |
| 702 | |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 703 | $(LIB_OBJS) $(BUILTIN_OBJS): $(LIB_H) |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 704 | $(patsubst perf-%$X,%.o,$(PROGRAMS)): $(LIB_H) $(wildcard */*.h) |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 705 | builtin-revert.o wt-status.o: wt-status.h |
| 706 | |
| 707 | $(LIB_FILE): $(LIB_OBJS) |
| 708 | $(QUIET_AR)$(RM) $@ && $(AR) rcs $@ $(LIB_OBJS) |
| 709 | |
Ingo Molnar | c1c2365 | 2009-05-30 12:38:51 +0200 | [diff] [blame] | 710 | doc: |
| 711 | $(MAKE) -C Documentation all |
| 712 | |
| 713 | man: |
| 714 | $(MAKE) -C Documentation man |
| 715 | |
| 716 | html: |
| 717 | $(MAKE) -C Documentation html |
| 718 | |
| 719 | info: |
| 720 | $(MAKE) -C Documentation info |
| 721 | |
| 722 | pdf: |
| 723 | $(MAKE) -C Documentation pdf |
| 724 | |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 725 | TAGS: |
| 726 | $(RM) TAGS |
| 727 | $(FIND) . -name '*.[hcS]' -print | xargs etags -a |
| 728 | |
| 729 | tags: |
| 730 | $(RM) tags |
| 731 | $(FIND) . -name '*.[hcS]' -print | xargs ctags -a |
| 732 | |
| 733 | cscope: |
| 734 | $(RM) cscope* |
| 735 | $(FIND) . -name '*.[hcS]' -print | xargs cscope -b |
| 736 | |
| 737 | ### Detect prefix changes |
| 738 | TRACK_CFLAGS = $(subst ','\'',$(ALL_CFLAGS)):\ |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 739 | $(bindir_SQ):$(perfexecdir_SQ):$(template_dir_SQ):$(prefix_SQ) |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 740 | |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 741 | PERF-CFLAGS: .FORCE-PERF-CFLAGS |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 742 | @FLAGS='$(TRACK_CFLAGS)'; \ |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 743 | if test x"$$FLAGS" != x"`cat PERF-CFLAGS 2>/dev/null`" ; then \ |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 744 | echo 1>&2 " * new build flags or prefix"; \ |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 745 | echo "$$FLAGS" >PERF-CFLAGS; \ |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 746 | fi |
| 747 | |
| 748 | # We need to apply sq twice, once to protect from the shell |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 749 | # that runs PERF-BUILD-OPTIONS, and then again to protect it |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 750 | # and the first level quoting from the shell that runs "echo". |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 751 | PERF-BUILD-OPTIONS: .FORCE-PERF-BUILD-OPTIONS |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 752 | @echo SHELL_PATH=\''$(subst ','\'',$(SHELL_PATH_SQ))'\' >$@ |
| 753 | @echo TAR=\''$(subst ','\'',$(subst ','\'',$(TAR)))'\' >>$@ |
| 754 | @echo NO_CURL=\''$(subst ','\'',$(subst ','\'',$(NO_CURL)))'\' >>$@ |
| 755 | @echo NO_PERL=\''$(subst ','\'',$(subst ','\'',$(NO_PERL)))'\' >>$@ |
| 756 | |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 757 | ### Testing rules |
| 758 | |
Ingo Molnar | 6f06ccb | 2009-04-20 15:22:22 +0200 | [diff] [blame] | 759 | # |
| 760 | # None right now: |
| 761 | # |
| 762 | # TEST_PROGRAMS += test-something$X |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 763 | |
| 764 | all:: $(TEST_PROGRAMS) |
| 765 | |
| 766 | # GNU make supports exporting all variables by "export" without parameters. |
| 767 | # However, the environment gets quite big, and some programs have problems |
| 768 | # with that. |
| 769 | |
| 770 | export NO_SVN_TESTS |
| 771 | |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 772 | check: common-cmds.h |
| 773 | if sparse; \ |
| 774 | then \ |
Ingo Molnar | 148be2c | 2009-04-27 08:02:14 +0200 | [diff] [blame] | 775 | for i in *.c */*.c; \ |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 776 | do \ |
| 777 | sparse $(ALL_CFLAGS) $(SPARSE_FLAGS) $$i || exit; \ |
| 778 | done; \ |
| 779 | else \ |
| 780 | echo 2>&1 "Did you mean 'make test'?"; \ |
| 781 | exit 1; \ |
| 782 | fi |
| 783 | |
| 784 | remove-dashes: |
| 785 | ./fixup-builtins $(BUILT_INS) $(PROGRAMS) $(SCRIPTS) |
| 786 | |
| 787 | ### Installation rules |
| 788 | |
| 789 | ifneq ($(filter /%,$(firstword $(template_dir))),) |
| 790 | template_instdir = $(template_dir) |
| 791 | else |
| 792 | template_instdir = $(prefix)/$(template_dir) |
| 793 | endif |
| 794 | export template_instdir |
| 795 | |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 796 | ifneq ($(filter /%,$(firstword $(perfexecdir))),) |
| 797 | perfexec_instdir = $(perfexecdir) |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 798 | else |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 799 | perfexec_instdir = $(prefix)/$(perfexecdir) |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 800 | endif |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 801 | perfexec_instdir_SQ = $(subst ','\'',$(perfexec_instdir)) |
| 802 | export perfexec_instdir |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 803 | |
| 804 | install: all |
| 805 | $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(bindir_SQ)' |
Ingo Molnar | 7fbd554 | 2009-05-30 12:38:51 +0200 | [diff] [blame] | 806 | $(INSTALL) perf$X '$(DESTDIR_SQ)$(bindir_SQ)' |
Mike Galbraith | c1079ab | 2009-06-02 10:17:34 +0200 | [diff] [blame] | 807 | ifdef BUILT_INS |
| 808 | $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(perfexec_instdir_SQ)' |
| 809 | $(INSTALL) $(BUILT_INS) '$(DESTDIR_SQ)$(perfexec_instdir_SQ)' |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 810 | ifneq (,$X) |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 811 | $(foreach p,$(patsubst %$X,%,$(filter %$X,$(ALL_PROGRAMS) $(BUILT_INS) perf$X)), $(RM) '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/$p';) |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 812 | endif |
Mike Galbraith | c1079ab | 2009-06-02 10:17:34 +0200 | [diff] [blame] | 813 | endif |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 814 | |
Ingo Molnar | c1c2365 | 2009-05-30 12:38:51 +0200 | [diff] [blame] | 815 | install-doc: |
| 816 | $(MAKE) -C Documentation install |
| 817 | |
| 818 | install-man: |
| 819 | $(MAKE) -C Documentation install-man |
| 820 | |
| 821 | install-html: |
| 822 | $(MAKE) -C Documentation install-html |
| 823 | |
| 824 | install-info: |
| 825 | $(MAKE) -C Documentation install-info |
| 826 | |
| 827 | install-pdf: |
| 828 | $(MAKE) -C Documentation install-pdf |
| 829 | |
| 830 | quick-install-doc: |
| 831 | $(MAKE) -C Documentation quick-install |
| 832 | |
| 833 | quick-install-man: |
| 834 | $(MAKE) -C Documentation quick-install-man |
| 835 | |
| 836 | quick-install-html: |
| 837 | $(MAKE) -C Documentation quick-install-html |
| 838 | |
| 839 | |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 840 | ### Maintainer's dist rules |
Mike Galbraith | c1079ab | 2009-06-02 10:17:34 +0200 | [diff] [blame] | 841 | # |
| 842 | # None right now |
| 843 | # |
| 844 | # |
| 845 | # perf.spec: perf.spec.in |
| 846 | # sed -e 's/@@VERSION@@/$(PERF_VERSION)/g' < $< > $@+ |
| 847 | # mv $@+ $@ |
| 848 | # |
| 849 | # PERF_TARNAME=perf-$(PERF_VERSION) |
| 850 | # dist: perf.spec perf-archive$(X) configure |
| 851 | # ./perf-archive --format=tar \ |
| 852 | # --prefix=$(PERF_TARNAME)/ HEAD^{tree} > $(PERF_TARNAME).tar |
| 853 | # @mkdir -p $(PERF_TARNAME) |
| 854 | # @cp perf.spec configure $(PERF_TARNAME) |
| 855 | # @echo $(PERF_VERSION) > $(PERF_TARNAME)/version |
| 856 | # $(TAR) rf $(PERF_TARNAME).tar \ |
| 857 | # $(PERF_TARNAME)/perf.spec \ |
| 858 | # $(PERF_TARNAME)/configure \ |
| 859 | # $(PERF_TARNAME)/version |
| 860 | # @$(RM) -r $(PERF_TARNAME) |
| 861 | # gzip -f -9 $(PERF_TARNAME).tar |
| 862 | # |
| 863 | # htmldocs = perf-htmldocs-$(PERF_VERSION) |
| 864 | # manpages = perf-manpages-$(PERF_VERSION) |
| 865 | # dist-doc: |
| 866 | # $(RM) -r .doc-tmp-dir |
| 867 | # mkdir .doc-tmp-dir |
| 868 | # $(MAKE) -C Documentation WEBDOC_DEST=../.doc-tmp-dir install-webdoc |
| 869 | # cd .doc-tmp-dir && $(TAR) cf ../$(htmldocs).tar . |
| 870 | # gzip -n -9 -f $(htmldocs).tar |
| 871 | # : |
| 872 | # $(RM) -r .doc-tmp-dir |
| 873 | # mkdir -p .doc-tmp-dir/man1 .doc-tmp-dir/man5 .doc-tmp-dir/man7 |
| 874 | # $(MAKE) -C Documentation DESTDIR=./ \ |
| 875 | # man1dir=../.doc-tmp-dir/man1 \ |
| 876 | # man5dir=../.doc-tmp-dir/man5 \ |
| 877 | # man7dir=../.doc-tmp-dir/man7 \ |
| 878 | # install |
| 879 | # cd .doc-tmp-dir && $(TAR) cf ../$(manpages).tar . |
| 880 | # gzip -n -9 -f $(manpages).tar |
| 881 | # $(RM) -r .doc-tmp-dir |
| 882 | # |
| 883 | # rpm: dist |
| 884 | # $(RPMBUILD) -ta $(PERF_TARNAME).tar.gz |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 885 | |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 886 | ### Cleaning rules |
| 887 | |
| 888 | distclean: clean |
Mike Galbraith | c1079ab | 2009-06-02 10:17:34 +0200 | [diff] [blame] | 889 | # $(RM) configure |
Ingo Molnar | e0143ba | 2009-03-23 21:29:59 +0100 | [diff] [blame] | 890 | |
| 891 | clean: |
Ingo Molnar | 148be2c | 2009-04-27 08:02:14 +0200 | [diff] [blame] | 892 | $(RM) *.o */*.o $(LIB_FILE) |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 893 | $(RM) $(ALL_PROGRAMS) $(BUILT_INS) perf$X |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 894 | $(RM) $(TEST_PROGRAMS) |
| 895 | $(RM) *.spec *.pyc *.pyo */*.pyc */*.pyo common-cmds.h TAGS tags cscope* |
| 896 | $(RM) -r autom4te.cache |
| 897 | $(RM) config.log config.mak.autogen config.mak.append config.status config.cache |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 898 | $(RM) -r $(PERF_TARNAME) .doc-tmp-dir |
| 899 | $(RM) $(PERF_TARNAME).tar.gz perf-core_$(PERF_VERSION)-*.tar.gz |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 900 | $(RM) $(htmldocs).tar.gz $(manpages).tar.gz |
Ingo Molnar | c1c2365 | 2009-05-30 12:38:51 +0200 | [diff] [blame] | 901 | $(MAKE) -C Documentation/ clean |
Ingo Molnar | 6f06ccb | 2009-04-20 15:22:22 +0200 | [diff] [blame] | 902 | $(RM) PERF-VERSION-FILE PERF-CFLAGS PERF-BUILD-OPTIONS |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 903 | |
| 904 | .PHONY: all install clean strip |
| 905 | .PHONY: shell_compatibility_test please_set_SHELL_PATH_to_a_more_modern_shell |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 906 | .PHONY: .FORCE-PERF-VERSION-FILE TAGS tags cscope .FORCE-PERF-CFLAGS |
| 907 | .PHONY: .FORCE-PERF-BUILD-OPTIONS |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 908 | |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 909 | ### Make sure built-ins do not have dups and listed in perf.c |
Ingo Molnar | d24e473 | 2009-04-20 13:32:07 +0200 | [diff] [blame] | 910 | # |
| 911 | check-builtins:: |
| 912 | ./check-builtins.sh |
| 913 | |
| 914 | ### Test suite coverage testing |
| 915 | # |
Mike Galbraith | c1079ab | 2009-06-02 10:17:34 +0200 | [diff] [blame] | 916 | # None right now |
| 917 | # |
| 918 | # .PHONY: coverage coverage-clean coverage-build coverage-report |
| 919 | # |
| 920 | # coverage: |
| 921 | # $(MAKE) coverage-build |
| 922 | # $(MAKE) coverage-report |
| 923 | # |
| 924 | # coverage-clean: |
| 925 | # rm -f *.gcda *.gcno |
| 926 | # |
| 927 | # COVERAGE_CFLAGS = $(CFLAGS) -O0 -ftest-coverage -fprofile-arcs |
| 928 | # COVERAGE_LDFLAGS = $(CFLAGS) -O0 -lgcov |
| 929 | # |
| 930 | # coverage-build: coverage-clean |
| 931 | # $(MAKE) CFLAGS="$(COVERAGE_CFLAGS)" LDFLAGS="$(COVERAGE_LDFLAGS)" all |
| 932 | # $(MAKE) CFLAGS="$(COVERAGE_CFLAGS)" LDFLAGS="$(COVERAGE_LDFLAGS)" \ |
| 933 | # -j1 test |
| 934 | # |
| 935 | # coverage-report: |
| 936 | # gcov -b *.c */*.c |
| 937 | # grep '^function.*called 0 ' *.c.gcov */*.c.gcov \ |
| 938 | # | sed -e 's/\([^:]*\)\.gcov: *function \([^ ]*\) called.*/\1: \2/' \ |
| 939 | # | tee coverage-untested-functions |