2008-02-06 23:06:50 +00:00
|
|
|
#
|
|
|
|
# ***** BEGIN LICENSE BLOCK *****
|
|
|
|
# Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
|
|
|
#
|
|
|
|
# The contents of this file are subject to the Mozilla Public License Version
|
|
|
|
# 1.1 (the "License"); you may not use this file except in compliance with
|
|
|
|
# the License. You may obtain a copy of the License at
|
|
|
|
# http://www.mozilla.org/MPL/
|
|
|
|
#
|
|
|
|
# Software distributed under the License is distributed on an "AS IS" basis,
|
|
|
|
# WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
|
|
# for the specific language governing rights and limitations under the
|
|
|
|
# License.
|
|
|
|
#
|
|
|
|
# The Original Code is mozilla.org code.
|
|
|
|
#
|
|
|
|
# The Initial Developer of the Original Code is
|
|
|
|
# Mozilla Foundation
|
|
|
|
# Portions created by the Initial Developer are Copyright (C) 2008
|
|
|
|
# the Initial Developer. All Rights Reserved.
|
|
|
|
#
|
|
|
|
# Contributor(s):
|
|
|
|
# Ted Mielczarek <ted.mielczarek@gmail.com>
|
|
|
|
#
|
|
|
|
# Alternatively, the contents of this file may be used under the terms of
|
|
|
|
# either of the GNU General Public License Version 2 or later (the "GPL"),
|
|
|
|
# or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
|
|
# in which case the provisions of the GPL or the LGPL are applicable instead
|
|
|
|
# of those above. If you wish to allow use of your version of this file only
|
|
|
|
# under the terms of either the GPL or the LGPL, and not to allow others to
|
|
|
|
# use your version of this file under the terms of the MPL, indicate your
|
|
|
|
# decision by deleting the provisions above and replace them with the notice
|
|
|
|
# and other provisions required by the GPL or the LGPL. If you do not delete
|
|
|
|
# the provisions above, a recipient may use your version of this file under
|
|
|
|
# the terms of any one of the MPL, the GPL or the LGPL.
|
|
|
|
#
|
|
|
|
# ***** END LICENSE BLOCK *****
|
|
|
|
|
|
|
|
DEPTH = ../..
|
|
|
|
topsrcdir = @top_srcdir@
|
|
|
|
srcdir = @srcdir@
|
|
|
|
VPATH = @srcdir@
|
|
|
|
|
|
|
|
include $(DEPTH)/config/autoconf.mk
|
|
|
|
|
|
|
|
MODULE = jemalloc
|
|
|
|
|
2008-06-20 17:34:42 +00:00
|
|
|
# jemalloc.c properly uses 'static', so don't burden it with manually exposing
|
|
|
|
# symbols.
|
|
|
|
VISIBILITY_FLAGS=
|
|
|
|
|
2011-06-27 19:44:51 +00:00
|
|
|
CSRCS = jemalloc.c
|
|
|
|
EXPORTS = jemalloc.h jemalloc_types.h
|
|
|
|
LIBRARY_NAME = jemalloc
|
2011-08-23 13:43:17 +00:00
|
|
|
|
|
|
|
ifeq (WINNT,$(OS_TARGET))
|
2011-06-27 19:44:51 +00:00
|
|
|
FORCE_SHARED_LIB = 1
|
|
|
|
|
|
|
|
MOZ_MEMORY_LDFLAGS = # Don't link against ourselves
|
|
|
|
|
|
|
|
DEFFILE = $(srcdir)/jemalloc.def
|
|
|
|
|
|
|
|
LDFLAGS += -ENTRY:DllMain
|
|
|
|
|
|
|
|
NO_INSTALL_IMPORT_LIBRARY = 1
|
2009-04-20 10:56:23 +00:00
|
|
|
else # Not Windows
|
2008-02-06 23:06:50 +00:00
|
|
|
|
2008-04-30 07:14:44 +00:00
|
|
|
ifeq ($(OS_ARCH),SunOS)
|
|
|
|
ifndef GNU_CC
|
|
|
|
MODULE_OPTIMIZE_FLAGS = -xO5
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
2008-05-08 09:20:44 +00:00
|
|
|
# Build jemalloc as a shared lib. This is mandatory for Darwin, since a library
|
|
|
|
# init function is used on that platform.
|
2008-08-26 22:25:05 +00:00
|
|
|
ifeq ($(OS_ARCH),Darwin)
|
2008-02-06 23:06:50 +00:00
|
|
|
FORCE_SHARED_LIB= 1
|
2008-08-26 22:25:05 +00:00
|
|
|
else
|
2011-08-24 10:55:13 +00:00
|
|
|
# On Android, we're going to link jemalloc into mozutils, and that only works
|
|
|
|
# properly if we only build a fakelib, which won't happen if we DIST_INSTALL
|
|
|
|
ifneq ($(OS_TARGET),Android)
|
2008-08-26 22:25:05 +00:00
|
|
|
DIST_INSTALL = 1
|
2011-08-24 10:55:13 +00:00
|
|
|
endif
|
2008-08-26 22:25:05 +00:00
|
|
|
FORCE_STATIC_LIB= 1
|
|
|
|
endif
|
2008-02-06 23:06:50 +00:00
|
|
|
|
2008-02-25 20:25:25 +00:00
|
|
|
#XXX: PGO on Linux causes problems here
|
|
|
|
# See bug 419470
|
|
|
|
NO_PROFILE_GUIDED_OPTIMIZE = 1
|
2008-02-06 23:06:50 +00:00
|
|
|
endif
|
|
|
|
|
|
|
|
include $(topsrcdir)/config/rules.mk
|
|
|
|
|
|
|
|
ifeq (Darwin,$(OS_TARGET))
|
|
|
|
LDFLAGS += -init _jemalloc_darwin_init
|
2008-02-13 07:31:35 +00:00
|
|
|
endif
|
2011-06-27 19:44:51 +00:00
|
|
|
|
|
|
|
ifeq (WINNT,$(OS_TARGET))
|
|
|
|
# Roll our own custom logic here for the import library
|
|
|
|
|
|
|
|
###############################################################################
|
|
|
|
#
|
|
|
|
# Linking Mozilla itself to jemalloc is not particularly difficult. To do this
|
|
|
|
# we avoid linking directly to the Microsoft-provided CRT import libraries.
|
|
|
|
# Instead, we link to our own import library which we generate here. To
|
|
|
|
# replace the CRT's malloc/free/other memory management symbols we export
|
|
|
|
# our own versions out of jemalloc.dll. We then take the import library that
|
|
|
|
# the compiler generates for jemalloc.dll and combine it with the MS CRT import
|
|
|
|
# libraries. We put our library on the command line first, and the CRT symbols
|
|
|
|
# are discarded in favor of our versions!
|
|
|
|
#
|
|
|
|
# Unfortunately that was too easy. The CRT import library is not a standard
|
|
|
|
# import library that contains a list of symbols and whatnot. It also includes
|
|
|
|
# object files that are linked into generated programs. One of these,
|
|
|
|
# crtdll.obj is (as one might expect) linked into all DLLs that link against
|
|
|
|
# the CRT. This file does things like run static C++ constructors when the
|
|
|
|
# DLL is attached, call DllMain, etc.
|
|
|
|
#
|
|
|
|
# In the CRT source all malloc/free calls are made to malloc_crt and free_crt.
|
|
|
|
# In debug builds these are both defined to malloc_dbg and free_dbg. In opt
|
|
|
|
# builds malloc_crt is an actual function, implemented and exposed from the
|
|
|
|
# CRT. free_crt is, however, defined to be just plain old free. This works
|
|
|
|
# fine inside the CRT where malloc_crt and free operate on the same heap.
|
|
|
|
# Outside the CRT malloc_crt is in the CRT's heap, but free is in jemalloc's
|
|
|
|
# heap. This causes much pain at shutdown :-(
|
|
|
|
#
|
|
|
|
# The obvious solution here is to override malloc_crt too. Unfortunately,
|
|
|
|
# that doesn't work because the CRT expects to be able to call msize on this
|
|
|
|
# piece of memory deep inside the CRT, which will fail because it'll call the
|
|
|
|
# CRT's msize on a pointer in jemalloc's heap.
|
|
|
|
#
|
|
|
|
# Our solution to this is quite devious. We take apart the CRT's import lib
|
|
|
|
# and remove the problematic object file. We then poke at the object file's
|
|
|
|
# symbol table and replace '__imp__free' (which means grab free from some
|
|
|
|
# other DLL) with '__imp__frex'. Then we define our own dummy no-op function
|
|
|
|
# in jemalloc.dll and export it as frex. Then we put the CRT import lib
|
|
|
|
# back together with the patched crtdll.obj, glue it to the end of jemalloc's
|
|
|
|
# import library and link the rest of Mozilla to that.
|
|
|
|
#
|
|
|
|
# The result? A binary that uses jemalloc, doesn't crash, and leaks a tiny
|
|
|
|
# amount of memory (32 words per DLL in the 2010 CRT) at shutdown.
|
|
|
|
#
|
|
|
|
###############################################################################
|
|
|
|
|
2011-07-28 14:28:13 +00:00
|
|
|
libs:: mozcrt.lib
|
2011-06-27 19:44:51 +00:00
|
|
|
$(INSTALL) $(IFLAGS2) mozcrt.lib $(DIST)/lib
|
|
|
|
|
|
|
|
# And finally combine that with the jemalloc import library to get an import
|
|
|
|
# library that has our malloc/free/etc and the CRT's everything else
|
2011-07-28 14:28:13 +00:00
|
|
|
mozcrt.lib: $(IMPORT_LIBRARY) msvc_modified.lib
|
2011-06-27 19:44:51 +00:00
|
|
|
lib -OUT:$@ $^
|
|
|
|
|
|
|
|
# Put the fixed object file back in
|
2011-07-28 14:28:13 +00:00
|
|
|
msvc_modified.lib: msvc_removed.lib crtdll_fixed.obj
|
2011-06-27 19:44:51 +00:00
|
|
|
lib -OUT:$@ $^
|
|
|
|
|
|
|
|
# Fix the object file
|
2011-07-28 14:28:13 +00:00
|
|
|
crtdll_fixed.obj: crtdll.obj
|
2011-06-27 19:44:51 +00:00
|
|
|
$(PYTHON) $(srcdir)/fixcrt.py
|
2011-06-27 23:11:45 +00:00
|
|
|
|
|
|
|
# Find the path of crtdll.obj
|
2011-06-27 19:44:51 +00:00
|
|
|
CRTDLL_FULLPATH=$(subst \,\\,$(shell lib -list msvc_combined.lib | grep crtdll\\.obj))
|
|
|
|
|
|
|
|
# Remove the broken object file, only after we have extracted it
|
2011-07-28 14:28:13 +00:00
|
|
|
msvc_removed.lib: msvc_combined.lib crtdll.obj
|
2011-06-27 19:44:51 +00:00
|
|
|
lib -OUT:$@ msvc_combined.lib -REMOVE:$(CRTDLL_FULLPATH)
|
|
|
|
|
|
|
|
# Extract the broken object file out of the combined library
|
2011-07-28 14:28:13 +00:00
|
|
|
crtdll.obj: msvc_combined.lib
|
2011-06-27 19:44:51 +00:00
|
|
|
lib -OUT:$@ $^ -EXTRACT:$(CRTDLL_FULLPATH)
|
|
|
|
|
|
|
|
# Grab both CRT libraries and combine them into one library to simplify things
|
2011-07-28 14:28:13 +00:00
|
|
|
msvc_combined.lib:
|
2011-06-27 23:11:45 +00:00
|
|
|
lib -OUT:$@ $(WIN32_CRT_LIBS)
|
2011-06-27 19:44:51 +00:00
|
|
|
endif
|