Merge pull request #132 from nielsAD/master
[libffi.git] / Makefile.am
index f2373fa..1dcdc81 100644 (file)
@@ -2,42 +2,55 @@
 
 AUTOMAKE_OPTIONS = foreign subdir-objects
 
+ACLOCAL_AMFLAGS = -I m4
+
 SUBDIRS = include testsuite man
 
-EXTRA_DIST = LICENSE ChangeLog.v1 ChangeLog.libgcj configure.host      \
-        src/aarch64/ffi.c src/aarch64/ffitarget.h                      \
-        src/alpha/ffi.c src/alpha/osf.S src/alpha/ffitarget.h          \
-        src/arm/ffi.c src/arm/sysv.S src/arm/ffitarget.h               \
-        src/avr32/ffi.c src/avr32/sysv.S src/avr32/ffitarget.h         \
-        src/cris/ffi.c src/cris/sysv.S src/cris/ffitarget.h            \
-        src/ia64/ffi.c src/ia64/ffitarget.h src/ia64/ia64_flags.h      \
-        src/ia64/unix.S src/mips/ffi.c src/mips/n32.S src/mips/o32.S   \
-        src/mips/ffitarget.h src/m32r/ffi.c src/m32r/sysv.S            \
-        src/m32r/ffitarget.h src/m68k/ffi.c src/m68k/sysv.S            \
-        src/m68k/ffitarget.h src/powerpc/ffi.c src/powerpc/sysv.S      \
-        src/powerpc/linux64.S src/powerpc/linux64_closure.S            \
-        src/powerpc/ppc_closure.S src/powerpc/asm.h                    \
-       src/powerpc/aix.S src/powerpc/darwin.S                          \
-       src/powerpc/aix_closure.S src/powerpc/darwin_closure.S          \
-       src/powerpc/ffi_darwin.c src/powerpc/ffitarget.h                \
-       src/s390/ffi.c src/s390/sysv.S src/s390/ffitarget.h             \
-       src/sh/ffi.c src/sh/sysv.S src/sh/ffitarget.h src/sh64/ffi.c    \
-       src/sh64/sysv.S src/sh64/ffitarget.h src/sparc/v8.S             \
-       src/sparc/v9.S src/sparc/ffitarget.h src/sparc/ffi.c            \
-       src/x86/darwin64.S src/x86/ffi.c src/x86/sysv.S                 \
-       src/x86/win32.S src/x86/darwin.S src/x86/win64.S                \
-       src/x86/freebsd.S src/x86/ffi64.c src/x86/unix64.S              \
-       src/x86/ffitarget.h src/pa/ffitarget.h src/pa/ffi.c             \
-       src/pa/linux.S src/pa/hpux32.S src/frv/ffi.c src/bfin/ffi.c     \
-       src/bfin/ffitarget.h src/bfin/sysv.S src/frv/eabi.S             \
-       src/frv/ffitarget.h src/dlmalloc.c src/tile/ffi.c               \
-       src/tile/ffitarget.h src/tile/tile.S libtool-version            \
+EXTRA_DIST = LICENSE ChangeLog.v1 ChangeLog.libgcj                     \
+        src/aarch64/ffi.c src/aarch64/ffitarget.h src/aarch64/sysv.S   \
+        src/alpha/ffi.c src/alpha/osf.S                        \
+        src/alpha/ffitarget.h src/arc/ffi.c src/arc/arcompact.S        \
+        src/arc/ffitarget.h src/arm/ffi.c src/arm/sysv.S               \
+        src/arm/ffitarget.h src/avr32/ffi.c src/avr32/sysv.S           \
+        src/avr32/ffitarget.h src/cris/ffi.c src/cris/sysv.S           \
+        src/cris/ffitarget.h src/ia64/ffi.c src/ia64/ffitarget.h       \
+        src/ia64/ia64_flags.h src/ia64/unix.S src/mips/ffi.c           \
+        src/mips/n32.S src/mips/o32.S src/metag/ffi.c                  \
+        src/metag/ffitarget.h src/metag/sysv.S src/moxie/ffi.c         \
+        src/moxie/ffitarget.h src/moxie/eabi.S src/mips/ffitarget.h    \
+        src/m32r/ffi.c src/m32r/sysv.S src/m32r/ffitarget.h            \
+        src/m68k/ffi.c src/m68k/sysv.S src/m68k/ffitarget.h            \
+        src/m88k/ffi.c src/m88k/obsd.S src/m88k/ffitarget.h            \
+        src/microblaze/ffi.c src/microblaze/sysv.S                     \
+        src/microblaze/ffitarget.h                                     \
+        src/nios2/ffi.c src/nios2/ffitarget.h src/nios2/sysv.S         \
+        src/powerpc/ffi.c src/powerpc/ffi_powerpc.h                    \
+        src/powerpc/ffi_sysv.c src/powerpc/ffi_linux64.c               \
+        src/powerpc/sysv.S src/powerpc/linux64.S                       \
+        src/powerpc/linux64_closure.S src/powerpc/ppc_closure.S        \
+        src/powerpc/asm.h src/powerpc/aix.S src/powerpc/darwin.S       \
+        src/powerpc/aix_closure.S src/powerpc/darwin_closure.S         \
+        src/powerpc/ffi_darwin.c src/powerpc/ffitarget.h               \
+        src/s390/ffi.c src/s390/sysv.S src/s390/ffitarget.h            \
+        src/sh/ffi.c src/sh/sysv.S src/sh/ffitarget.h src/sh64/ffi.c   \
+        src/sh64/sysv.S src/sh64/ffitarget.h src/sparc/v8.S            \
+        src/sparc/v9.S src/sparc/ffitarget.h src/sparc/ffi.c           \
+        src/x86/darwin64.S src/x86/ffi.c src/x86/sysv.S                \
+        src/x86/win32.S src/x86/darwin.S src/x86/win64.S               \
+        src/x86/freebsd.S src/x86/ffi64.c src/x86/unix64.S             \
+        src/x86/ffitarget.h src/pa/ffitarget.h src/pa/ffi.c            \
+        src/pa/linux.S src/pa/hpux32.S src/frv/ffi.c src/bfin/ffi.c    \
+        src/bfin/ffitarget.h src/bfin/sysv.S src/frv/eabi.S            \
+        src/frv/ffitarget.h src/dlmalloc.c src/tile/ffi.c              \
+        src/tile/ffitarget.h src/tile/tile.S libtool-version           \
+        src/vax/ffi.c src/vax/ffitarget.h src/vax/elfbsd.S             \
+        src/xtensa/ffitarget.h src/xtensa/ffi.c src/xtensa/sysv.S      \
         ChangeLog.libffi m4/libtool.m4 m4/lt~obsolete.m4               \
         m4/ltoptions.m4 m4/ltsugar.m4 m4/ltversion.m4                  \
         m4/ltversion.m4 src/arm/gentramp.sh src/debug.c msvcc.sh       \
-       generate-ios-source-and-headers.py                              \
-        generate-osx-source-and-headers.py                             \
-        libffi.xcodeproj/project.pbxproj src/arm/trampoline.S
+        generate-darwin-source-and-headers.py                          \
+        libffi.xcodeproj/project.pbxproj src/arm/trampoline.S          \
+        libtool-ldflags ChangeLog.libffi-3.1
 
 info_TEXINFOS = doc/libffi.texi
 
@@ -51,39 +64,39 @@ info_TEXINFOS = doc/libffi.texi
 # values defined in terms of make variables, as is the case for CC and
 # friends when we are called from the top level Makefile.
 AM_MAKEFLAGS = \
-       "AR_FLAGS=$(AR_FLAGS)" \
-       "CC_FOR_BUILD=$(CC_FOR_BUILD)" \
-       "CFLAGS=$(CFLAGS)" \
-       "CXXFLAGS=$(CXXFLAGS)" \
-       "CFLAGS_FOR_BUILD=$(CFLAGS_FOR_BUILD)" \
-       "CFLAGS_FOR_TARGET=$(CFLAGS_FOR_TARGET)" \
-       "INSTALL=$(INSTALL)" \
-       "INSTALL_DATA=$(INSTALL_DATA)" \
-       "INSTALL_PROGRAM=$(INSTALL_PROGRAM)" \
-       "INSTALL_SCRIPT=$(INSTALL_SCRIPT)" \
-       "JC1FLAGS=$(JC1FLAGS)" \
-       "LDFLAGS=$(LDFLAGS)" \
-       "LIBCFLAGS=$(LIBCFLAGS)" \
-       "LIBCFLAGS_FOR_TARGET=$(LIBCFLAGS_FOR_TARGET)" \
-       "MAKE=$(MAKE)" \
-       "MAKEINFO=$(MAKEINFO) $(MAKEINFOFLAGS)" \
-       "PICFLAG=$(PICFLAG)" \
-       "PICFLAG_FOR_TARGET=$(PICFLAG_FOR_TARGET)" \
-       "RUNTESTFLAGS=$(RUNTESTFLAGS)" \
-       "SHELL=$(SHELL)" \
-       "exec_prefix=$(exec_prefix)" \
-       "infodir=$(infodir)" \
-       "libdir=$(libdir)" \
-       "mandir=$(mandir)" \
-       "prefix=$(prefix)" \
-       "AR=$(AR)" \
-       "AS=$(AS)" \
-       "CC=$(CC)" \
-       "CXX=$(CXX)" \
-       "LD=$(LD)" \
-       "NM=$(NM)" \
-       "RANLIB=$(RANLIB)" \
-       "DESTDIR=$(DESTDIR)"
+       'AR_FLAGS=$(AR_FLAGS)' \
+       'CC_FOR_BUILD=$(CC_FOR_BUILD)' \
+       'CFLAGS=$(CFLAGS)' \
+       'CXXFLAGS=$(CXXFLAGS)' \
+       'CFLAGS_FOR_BUILD=$(CFLAGS_FOR_BUILD)' \
+       'CFLAGS_FOR_TARGET=$(CFLAGS_FOR_TARGET)' \
+       'INSTALL=$(INSTALL)' \
+       'INSTALL_DATA=$(INSTALL_DATA)' \
+       'INSTALL_PROGRAM=$(INSTALL_PROGRAM)' \
+       'INSTALL_SCRIPT=$(INSTALL_SCRIPT)' \
+       'JC1FLAGS=$(JC1FLAGS)' \
+       'LDFLAGS=$(LDFLAGS)' \
+       'LIBCFLAGS=$(LIBCFLAGS)' \
+       'LIBCFLAGS_FOR_TARGET=$(LIBCFLAGS_FOR_TARGET)' \
+       'MAKE=$(MAKE)' \
+       'MAKEINFO=$(MAKEINFO) $(MAKEINFOFLAGS)' \
+       'PICFLAG=$(PICFLAG)' \
+       'PICFLAG_FOR_TARGET=$(PICFLAG_FOR_TARGET)' \
+       'RUNTESTFLAGS=$(RUNTESTFLAGS)' \
+       'SHELL=$(SHELL)' \
+       'exec_prefix=$(exec_prefix)' \
+       'infodir=$(infodir)' \
+       'libdir=$(libdir)' \
+       'mandir=$(mandir)' \
+       'prefix=$(prefix)' \
+       'AR=$(AR)' \
+       'AS=$(AS)' \
+       'CC=$(CC)' \
+       'CXX=$(CXX)' \
+       'LD=$(LD)' \
+       'NM=$(NM)' \
+       'RANLIB=$(RANLIB)' \
+       'DESTDIR=$(DESTDIR)'
 
 # Subdir rules rely on $(FLAGS_TO_PASS)
 FLAGS_TO_PASS = $(AM_MAKEFLAGS)
@@ -96,6 +109,9 @@ noinst_LTLIBRARIES = libffi_convenience.la
 libffi_la_SOURCES = src/prep_cif.c src/types.c \
                src/raw_api.c src/java_raw_api.c src/closures.c
 
+pkgconfigdir = $(libdir)/pkgconfig
+pkgconfig_DATA = libffi.pc
+
 nodist_libffi_la_SOURCES =
 
 if FFI_DEBUG
@@ -109,10 +125,10 @@ if BFIN
 nodist_libffi_la_SOURCES += src/bfin/ffi.c src/bfin/sysv.S
 endif
 if X86
-nodist_libffi_la_SOURCES += src/x86/ffi.c src/x86/sysv.S
+nodist_libffi_la_SOURCES += src/x86/ffi.c src/x86/sysv.S src/x86/win32.S
 endif
 if X86_FREEBSD
-nodist_libffi_la_SOURCES += src/x86/ffi.c src/x86/freebsd.S
+nodist_libffi_la_SOURCES += src/x86/ffi.c src/x86/freebsd.S src/x86/win32.S
 endif
 if X86_WIN32
 nodist_libffi_la_SOURCES += src/x86/ffi.c src/x86/win32.S
@@ -122,6 +138,9 @@ nodist_libffi_la_SOURCES += src/x86/ffi.c src/x86/win64.S
 endif
 if X86_DARWIN
 nodist_libffi_la_SOURCES += src/x86/ffi.c src/x86/darwin.S src/x86/ffi64.c src/x86/darwin64.S
+if X86_DARWIN32
+nodist_libffi_la_SOURCES += src/x86/win32.S
+endif
 endif
 if SPARC
 nodist_libffi_la_SOURCES += src/sparc/ffi.c src/sparc/v8.S src/sparc/v9.S
@@ -138,8 +157,20 @@ endif
 if M68K
 nodist_libffi_la_SOURCES += src/m68k/ffi.c src/m68k/sysv.S
 endif
+if M88K
+nodist_libffi_la_SOURCES += src/m88k/ffi.c src/m88k/obsd.S
+endif
+if MOXIE
+nodist_libffi_la_SOURCES += src/moxie/ffi.c src/moxie/eabi.S
+endif
+if MICROBLAZE
+nodist_libffi_la_SOURCES += src/microblaze/ffi.c src/microblaze/sysv.S
+endif
+if NIOS2
+nodist_libffi_la_SOURCES += src/nios2/sysv.S src/nios2/ffi.c
+endif
 if POWERPC
-nodist_libffi_la_SOURCES += src/powerpc/ffi.c src/powerpc/sysv.S src/powerpc/ppc_closure.S src/powerpc/linux64.S src/powerpc/linux64_closure.S
+nodist_libffi_la_SOURCES += src/powerpc/ffi.c src/powerpc/ffi_sysv.c src/powerpc/ffi_linux64.c src/powerpc/sysv.S src/powerpc/ppc_closure.S src/powerpc/linux64.S src/powerpc/linux64_closure.S
 endif
 if POWERPC_AIX
 nodist_libffi_la_SOURCES += src/powerpc/ffi_darwin.c src/powerpc/aix.S src/powerpc/aix_closure.S
@@ -148,11 +179,14 @@ if POWERPC_DARWIN
 nodist_libffi_la_SOURCES += src/powerpc/ffi_darwin.c src/powerpc/darwin.S src/powerpc/darwin_closure.S
 endif
 if POWERPC_FREEBSD
-nodist_libffi_la_SOURCES += src/powerpc/ffi.c src/powerpc/sysv.S src/powerpc/ppc_closure.S
+nodist_libffi_la_SOURCES += src/powerpc/ffi.c src/powerpc/ffi_sysv.c src/powerpc/sysv.S src/powerpc/ppc_closure.S
 endif
 if AARCH64
 nodist_libffi_la_SOURCES += src/aarch64/sysv.S src/aarch64/ffi.c
 endif
+if ARC
+nodist_libffi_la_SOURCES += src/arc/arcompact.S src/arc/ffi.c
+endif
 if ARM
 nodist_libffi_la_SOURCES += src/arm/sysv.S src/arm/ffi.c
 if FFI_EXEC_TRAMPOLINE_TABLE
@@ -189,14 +223,32 @@ endif
 if TILE
 nodist_libffi_la_SOURCES += src/tile/tile.S src/tile/ffi.c
 endif
+if XTENSA
+nodist_libffi_la_SOURCES += src/xtensa/sysv.S src/xtensa/ffi.c
+endif
+if METAG
+nodist_libffi_la_SOURCES += src/metag/sysv.S src/metag/ffi.c
+endif
+if VAX
+nodist_libffi_la_SOURCES += src/vax/elfbsd.S src/vax/ffi.c
+endif
 
 libffi_convenience_la_SOURCES = $(libffi_la_SOURCES)
 nodist_libffi_convenience_la_SOURCES = $(nodist_libffi_la_SOURCES)
 
-LTLDFLAGS = $(shell $(SHELL) $(top_srcdir)/../libtool-ldflags $(LDFLAGS))
+LTLDFLAGS = $(shell $(SHELL) $(top_srcdir)/libtool-ldflags $(LDFLAGS))
+
+AM_CFLAGS =
+if FFI_DEBUG
+# Build debug. Define FFI_DEBUG on the commandline so that, when building with
+# MSVC, it can link against the debug CRT.
+AM_CFLAGS += -DFFI_DEBUG
+endif
 
 libffi_la_LDFLAGS = -no-undefined -version-info `grep -v '^\#' $(srcdir)/libtool-version` $(LTLDFLAGS) $(AM_LTLDFLAGS)
 
 AM_CPPFLAGS = -I. -I$(top_srcdir)/include -Iinclude -I$(top_srcdir)/src
 AM_CCASFLAGS = $(AM_CPPFLAGS)
 
+dist-hook:
+       if [ -d $(top_srcdir)/.git ] ; then (cd $(top_srcdir); git log --no-decorate) ; else echo 'See git log for history.' ; fi > $(distdir)/ChangeLog