summaryrefslogtreecommitdiff
path: root/volk/lib/Makefile.am
diff options
context:
space:
mode:
Diffstat (limited to 'volk/lib/Makefile.am')
-rw-r--r--volk/lib/Makefile.am311
1 files changed, 311 insertions, 0 deletions
diff --git a/volk/lib/Makefile.am b/volk/lib/Makefile.am
new file mode 100644
index 000000000..896d568e6
--- /dev/null
+++ b/volk/lib/Makefile.am
@@ -0,0 +1,311 @@
+#
+# Copyright 2010,2011 Free Software Foundation, Inc.
+#
+# This file is part of GNU Radio
+#
+# GNU Radio is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 3, or (at your option)
+# any later version.
+#
+# GNU Radio is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License along
+# with this program; if not, write to the Free Software Foundation, Inc.,
+# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+
+include $(top_srcdir)/Makefile.common
+
+#FIXME: forcing the top_builddir for distcheck seems like a bit
+# of a hack. Figure out the right way to do this to find built
+# volk_config.h and volk_tables.h
+
+AM_CPPFLAGS = $(STD_DEFINES_AND_INCLUDES) $(CPPUNIT_CPPFLAGS) \
+ -I$(top_builddir)/include \
+ $(LV_CXXFLAGS) $(WITH_INCLUDES)
+
+
+# We build 2 libraries and 1 executable here. One library contains
+# everything except the libcppunit QA code, and one contains only the
+# libcppunit-based QA code. The C++ QA code is especially recommended
+# when you have general purpose C or C++ code that may not get
+# thoroughly exercised by building and running a GR block. The
+# executable runs the QA code at "make check" time.
+#
+# N.B., If there's a SWIG generated shared library and associated
+# python code, it will be contained in ../python, not here. (That
+# code is conditionally built depending on the state of the
+# --without-python configure option.) However, the .i should be here
+# next to the .h that it's based on.
+
+
+# list of programs run by "make check" and "make distcheck"
+#TESTS = test_all
+
+
+lib_LTLIBRARIES = \
+ libvolk.la \
+ libvolk_runtime.la \
+ libvolk_qa.la
+
+EXTRA_DIST = \
+ volk_mktables.c \
+ volk_rank_archs.h \
+ volk_proccpu_sim.c
+
+# ----------------------------------------------------------------
+# The main library
+# ----------------------------------------------------------------
+
+libvolk_runtime_la_SOURCES = \
+ $(platform_CODE) \
+ volk_runtime.c \
+ volk_init.c \
+ volk_rank_archs.c
+
+libvolk_la_SOURCES = \
+ $(platform_CODE) \
+ volk.c \
+ volk_environment_init.c
+
+
+libvolk_la_LDFLAGS = $(NO_UNDEFINED) -version-info 0:0:0
+libvolk_runtime_la_LDFLAGS = $(NO_UNDEFINED) -version-info 0:0:0
+
+libvolk_la_LIBADD =
+
+
+
+# ----------------------------------------------------------------
+# The QA library. Note libvolk.la in LIBADD
+# ----------------------------------------------------------------
+libvolk_qa_la_SOURCES = \
+ qa_volk.cc \
+ qa_16s_quad_max_star_aligned16.cc \
+ qa_32fc_dot_prod_aligned16.cc \
+ qa_32fc_square_dist_aligned16.cc \
+ qa_32fc_square_dist_scalar_mult_aligned16.cc \
+ qa_32f_sum_of_poly_aligned16.cc \
+ qa_32fc_index_max_aligned16.cc \
+ qa_32f_index_max_aligned16.cc \
+ qa_32fc_conjugate_dot_prod_aligned16.cc \
+ qa_16s_permute_and_scalar_add_aligned16.cc \
+ qa_16s_branch_4_state_8_aligned16.cc \
+ qa_16s_max_star_horizontal_aligned16.cc \
+ qa_16s_max_star_aligned16.cc \
+ qa_16s_add_quad_aligned16.cc \
+ qa_32f_add_aligned16.cc \
+ qa_32f_subtract_aligned16.cc \
+ qa_32f_max_aligned16.cc \
+ qa_32f_min_aligned16.cc \
+ qa_64f_max_aligned16.cc \
+ qa_64f_min_aligned16.cc \
+ qa_32s_and_aligned16.cc \
+ qa_32s_or_aligned16.cc \
+ qa_32f_dot_prod_aligned16.cc \
+ qa_32f_dot_prod_unaligned16.cc \
+ qa_32f_fm_detect_aligned16.cc \
+ qa_32fc_32f_multiply_aligned16.cc \
+ qa_32fc_multiply_aligned16.cc \
+ qa_32f_divide_aligned16.cc \
+ qa_32f_multiply_aligned16.cc \
+ qa_32f_sqrt_aligned16.cc \
+ qa_8sc_multiply_conjugate_16sc_aligned16.cc \
+ qa_8sc_multiply_conjugate_32fc_aligned16.cc \
+ qa_32u_popcnt_aligned16.cc \
+ qa_64u_popcnt_aligned16.cc \
+ qa_64u_byteswap_aligned16.cc \
+ qa_8sc_deinterleave_32f_aligned16.cc \
+ qa_16sc_deinterleave_32f_aligned16.cc \
+ qa_8sc_deinterleave_16s_aligned16.cc \
+ qa_32f_interleave_32fc_aligned16.cc \
+ qa_16u_byteswap_aligned16.cc \
+ qa_16sc_deinterleave_16s_aligned16.cc \
+ qa_32fc_deinterleave_real_32f_aligned16.cc \
+ qa_32fc_magnitude_32f_aligned16.cc \
+ qa_32fc_deinterleave_real_64f_aligned16.cc \
+ qa_32fc_deinterleave_real_16s_aligned16.cc \
+ qa_32fc_magnitude_16s_aligned16.cc \
+ qa_32fc_deinterleave_32f_aligned16.cc \
+ qa_8sc_deinterleave_real_8s_aligned16.cc \
+ qa_32fc_deinterleave_64f_aligned16.cc \
+ qa_32f_interleave_16sc_aligned16.cc \
+ qa_16sc_deinterleave_real_8s_aligned16.cc \
+ qa_16sc_deinterleave_real_32f_aligned16.cc \
+ qa_16sc_magnitude_32f_aligned16.cc \
+ qa_32u_byteswap_aligned16.cc \
+ qa_16sc_deinterleave_real_16s_aligned16.cc \
+ qa_8sc_deinterleave_real_32f_aligned16.cc \
+ qa_16sc_magnitude_16s_aligned16.cc \
+ qa_32f_normalize_aligned16.cc \
+ qa_8sc_deinterleave_real_16s_aligned16.cc \
+ qa_16s_convert_32f_aligned16.cc \
+ qa_16s_convert_32f_unaligned16.cc \
+ qa_16s_convert_8s_aligned16.cc \
+ qa_16s_convert_8s_unaligned16.cc \
+ qa_32f_convert_16s_aligned16.cc \
+ qa_32f_convert_16s_unaligned16.cc \
+ qa_32f_convert_32s_aligned16.cc \
+ qa_32f_convert_32s_unaligned16.cc \
+ qa_32f_convert_64f_aligned16.cc \
+ qa_32f_convert_64f_unaligned16.cc \
+ qa_32f_convert_8s_aligned16.cc \
+ qa_32f_convert_8s_unaligned16.cc \
+ qa_32s_convert_32f_aligned16.cc \
+ qa_32s_convert_32f_unaligned16.cc \
+ qa_64f_convert_32f_aligned16.cc \
+ qa_64f_convert_32f_unaligned16.cc \
+ qa_8s_convert_16s_aligned16.cc \
+ qa_8s_convert_16s_unaligned16.cc \
+ qa_8s_convert_32f_aligned16.cc \
+ qa_8s_convert_32f_unaligned16.cc \
+ qa_32fc_32f_power_32fc_aligned16.cc \
+ qa_32f_power_aligned16.cc \
+ qa_32fc_atan2_32f_aligned16.cc \
+ qa_32fc_power_spectral_density_32f_aligned16.cc \
+ qa_32fc_power_spectrum_32f_aligned16.cc \
+ qa_32f_calc_spectral_noise_floor_aligned16.cc \
+ qa_32f_accumulator_aligned16.cc \
+ qa_32f_stddev_aligned16.cc \
+ qa_32f_stddev_and_mean_aligned16.cc
+
+libvolk_qa_la_LDFLAGS = $(NO_UNDEFINED) -version-info 0:0:0
+
+libvolk_qa_la_LIBADD = \
+ libvolk.la \
+ libvolk_runtime.la \
+ $(CPPUNIT_LIBS)
+
+# ----------------------------------------------------------------
+# headers that don't get installed
+# ----------------------------------------------------------------
+noinst_HEADERS = \
+ volk_init.h \
+ qa_volk.h \
+ assembly.h \
+ qa_16s_quad_max_star_aligned16.h \
+ qa_32fc_dot_prod_aligned16.h \
+ qa_32fc_square_dist_aligned16.h \
+ qa_32fc_square_dist_scalar_mult_aligned16.h \
+ qa_32f_sum_of_poly_aligned16.h \
+ qa_32fc_index_max_aligned16.h \
+ qa_32f_index_max_aligned16.h \
+ qa_32fc_conjugate_dot_prod_aligned16.h \
+ qa_16s_permute_and_scalar_add_aligned16.h \
+ qa_16s_branch_4_state_8_aligned16.h \
+ qa_16s_max_star_horizontal_aligned16.h \
+ qa_16s_max_star_aligned16.h \
+ qa_16s_add_quad_aligned16.h \
+ qa_32f_add_aligned16.h \
+ qa_32f_subtract_aligned16.h \
+ qa_32f_max_aligned16.h \
+ qa_32f_min_aligned16.h \
+ qa_64f_max_aligned16.h \
+ qa_64f_min_aligned16.h \
+ qa_32s_and_aligned16.h \
+ qa_32s_or_aligned16.h \
+ qa_32f_dot_prod_aligned16.h \
+ qa_32f_dot_prod_unaligned16.h \
+ qa_32f_fm_detect_aligned16.h \
+ qa_32fc_32f_multiply_aligned16.h \
+ qa_32fc_multiply_aligned16.h \
+ qa_32f_divide_aligned16.h \
+ qa_32f_multiply_aligned16.h \
+ qa_32f_sqrt_aligned16.h \
+ qa_8sc_multiply_conjugate_16sc_aligned16.h \
+ qa_8sc_multiply_conjugate_32fc_aligned16.h \
+ qa_32u_popcnt_aligned16.h \
+ qa_64u_popcnt_aligned16.h \
+ qa_64u_byteswap_aligned16.h \
+ qa_8sc_deinterleave_32f_aligned16.h \
+ qa_16sc_deinterleave_32f_aligned16.h \
+ qa_8sc_deinterleave_16s_aligned16.h \
+ qa_32f_interleave_32fc_aligned16.h \
+ qa_16u_byteswap_aligned16.h \
+ qa_16sc_deinterleave_16s_aligned16.h \
+ qa_32fc_deinterleave_real_32f_aligned16.h \
+ qa_32fc_magnitude_32f_aligned16.h \
+ qa_32fc_deinterleave_real_64f_aligned16.h \
+ qa_32fc_deinterleave_real_16s_aligned16.h \
+ qa_32fc_magnitude_16s_aligned16.h \
+ qa_32fc_deinterleave_32f_aligned16.h \
+ qa_8sc_deinterleave_real_8s_aligned16.h \
+ qa_32fc_deinterleave_64f_aligned16.h \
+ qa_32f_interleave_16sc_aligned16.h \
+ qa_16sc_deinterleave_real_8s_aligned16.h \
+ qa_16sc_deinterleave_real_32f_aligned16.h \
+ qa_16sc_magnitude_32f_aligned16.h \
+ qa_32u_byteswap_aligned16.h \
+ qa_16sc_deinterleave_real_16s_aligned16.h \
+ qa_8sc_deinterleave_real_32f_aligned16.h \
+ qa_16sc_magnitude_16s_aligned16.h \
+ qa_32f_normalize_aligned16.h \
+ qa_8sc_deinterleave_real_16s_aligned16.h \
+ qa_16s_convert_32f_aligned16.h \
+ qa_16s_convert_32f_unaligned16.h \
+ qa_16s_convert_8s_aligned16.h \
+ qa_16s_convert_8s_unaligned16.h \
+ qa_32f_convert_16s_aligned16.h \
+ qa_32f_convert_16s_unaligned16.h \
+ qa_32f_convert_32s_aligned16.h \
+ qa_32f_convert_32s_unaligned16.h \
+ qa_32f_convert_64f_aligned16.h \
+ qa_32f_convert_64f_unaligned16.h \
+ qa_32f_convert_8s_aligned16.h \
+ qa_32f_convert_8s_unaligned16.h \
+ qa_32s_convert_32f_aligned16.h \
+ qa_32s_convert_32f_unaligned16.h \
+ qa_64f_convert_32f_aligned16.h \
+ qa_64f_convert_32f_unaligned16.h \
+ qa_8s_convert_16s_aligned16.h \
+ qa_8s_convert_16s_unaligned16.h \
+ qa_8s_convert_32f_aligned16.h \
+ qa_8s_convert_32f_unaligned16.h \
+ qa_32fc_32f_power_32fc_aligned16.h \
+ qa_32f_power_aligned16.h \
+ qa_32fc_atan2_32f_aligned16.h \
+ qa_32fc_power_spectral_density_32f_aligned16.h \
+ qa_32fc_power_spectrum_32f_aligned16.h \
+ qa_32f_calc_spectral_noise_floor_aligned16.h \
+ qa_32f_accumulator_aligned16.h \
+ qa_32f_stddev_aligned16.h \
+ qa_32f_stddev_and_mean_aligned16.h
+
+
+# ----------------------------------------------------------------
+# Our test program
+# ----------------------------------------------------------------
+noinst_PROGRAMS = \
+ test_all
+
+test_all_SOURCES = test_all.cc
+test_all_LDADD = libvolk_qa.la
+
+
+distclean-local:
+ rm -f volk.c
+ rm -f volk_cpu_generic.c
+ rm -f volk_cpu_powerpc.c
+ rm -f volk_cpu_x86.c
+ rm -f volk_init.c
+ rm -f volk_init.h
+ rm -f volk_mktables.c
+ rm -f volk_proccpu_sim.c
+ rm -f volk_runtime.c
+ rm -f volk_tables.h
+ rm -f volk_environment_init.c
+#SUBDIRS =
+
+#ifdef BUILD_SSE
+#SUBDIRS += sse
+#elif BUILD_SPU
+#SUBDIRS += spu
+#else
+#SUBDIRS += port
+#endif
+
+