]> sigrok.org Git - libsigrok.git/blobdiff - Makefile.am
output/csv: use intermediate time_t var, silence compiler warning
[libsigrok.git] / Makefile.am
index 731726355ad4b63bcd04e494d4eac4190f39e532..62aca8ac95ad0830b9b35971fab21b28c8c6e546 100644 (file)
@@ -25,9 +25,11 @@ GNUMAKEFLAGS = --no-print-directory
 # distutils/setuptools cause trouble on distcheck. Disable for now.
 DISTCHECK_CONFIGURE_FLAGS = --disable-python
 
+CLEAN_EXTRA =
+
 FIRMWARE_DIR = $(datadir)/sigrok-firmware
 
-local_includes = -Iinclude -I$(srcdir)/include -I$(srcdir)/src -I.
+local_includes = -Iinclude -I$(srcdir)/include -I$(srcdir)/src -I. @RPC_CFLAGS@
 if BINDINGS_CXX
 local_includes += -Ibindings/cxx/include -I$(srcdir)/bindings/cxx/include -Ibindings/cxx
 endif
@@ -42,7 +44,8 @@ AM_CPPFLAGS = $(local_includes) $(global_defs)
 
 # The tests CFLAGS are a superset of the libsigrok CFLAGS, and the
 # python bindings CFLAGS are a superset of the C++ bindings CFLAGS.
-AM_CFLAGS = $(SR_EXTRA_CFLAGS) $(SR_WFLAGS) $(TESTS_CFLAGS)
+SR_MINILZO_CFLAGS = -DMINILZO_HAVE_CONFIG_H
+AM_CFLAGS = $(SR_EXTRA_CFLAGS) $(SR_WFLAGS) $(SR_MINILZO_CFLAGS) $(TESTS_CFLAGS)
 AM_CXXFLAGS = $(SR_WXXFLAGS) $(LIBSIGROKCXX_CFLAGS)
 
 lib_LTLIBRARIES = libsigrok.la
@@ -50,6 +53,9 @@ lib_LTLIBRARIES = libsigrok.la
 # Backend files
 libsigrok_la_SOURCES = \
        src/backend.c \
+       src/binary_helpers.c \
+       src/conversion.c \
+       src/crc.c \
        src/device.c \
        src/session.c \
        src/session_file.c \
@@ -65,18 +71,35 @@ libsigrok_la_SOURCES = \
        src/version.c \
        src/error.c \
        src/std.c \
-       src/sw_limits.c
+       src/sw_limits.c \
+       src/tcp.c
+
+# Support code, shared among input and driver modules
+libsigrok_la_SOURCES += \
+       src/minilzo/minilzo.c \
+       src/minilzo/minilzo.h \
+       src/minilzo/lzoconf.h \
+       src/minilzo/lzodefs.h
 
 # Input modules
 libsigrok_la_SOURCES += \
        src/input/input.c \
+       src/input/feed_queue.c \
        src/input/binary.c \
        src/input/chronovu_la8.c \
        src/input/csv.c \
+       src/input/logicport.c \
+       src/input/protocoldata.c \
        src/input/raw_analog.c \
+       src/input/saleae.c \
        src/input/trace32_ad.c \
        src/input/vcd.c \
-       src/input/wav.c
+       src/input/wav.c \
+       src/input/null.c
+if HAVE_INPUT_STF
+libsigrok_la_SOURCES += \
+       src/input/stf.c
+endif
 
 # Output modules
 libsigrok_la_SOURCES += \
@@ -91,7 +114,9 @@ libsigrok_la_SOURCES += \
        src/output/hex.c \
        src/output/ols.c \
        src/output/srzip.c \
-       src/output/vcd.c
+       src/output/vcd.c \
+       src/output/wavedrom.c \
+       src/output/null.c
 
 # Transform modules
 libsigrok_la_SOURCES += \
@@ -104,7 +129,6 @@ libsigrok_la_SOURCES += \
 libsigrok_la_SOURCES += \
        src/scpi.h \
        src/scpi/scpi.c \
-       src/scpi/helpers.c \
        src/scpi/scpi_tcp.c
 if NEED_RPC
 libsigrok_la_SOURCES += \
@@ -113,10 +137,26 @@ libsigrok_la_SOURCES += \
        src/scpi/vxi_xdr.c \
        src/scpi/vxi.h
 endif
+# if HAVE_BLUETOOTH
+libsigrok_la_SOURCES += \
+       src/bt/bt_bluez.c
+# endif
 if NEED_SERIAL
 libsigrok_la_SOURCES += \
        src/serial.c \
+       src/serial_bt.c \
+       src/serial_hid.c \
+       src/serial_hid.h \
+       src/serial_hid_bu86x.c \
+       src/serial_hid_ch9325.c \
+       src/serial_hid_cp2110.c \
+       src/serial_hid_victor.c \
+       src/serial_libsp.c \
+       src/serial_tcpraw.c \
        src/scpi/scpi_serial.c
+else
+libsigrok_la_SOURCES += \
+       src/serial.c
 endif
 if NEED_USB
 libsigrok_la_SOURCES += \
@@ -143,23 +183,32 @@ endif
 
 # Hardware (DMM chip parsers)
 libsigrok_la_SOURCES += \
+       src/dmm/asycii.c \
+       src/dmm/bm25x.c \
+       src/dmm/bm52x.c \
+       src/dmm/bm85x.c \
+       src/dmm/bm86x.c \
+       src/dmm/dtm0660.c \
+       src/dmm/eev121gw.c \
        src/dmm/es519xx.c \
        src/dmm/fs9721.c \
        src/dmm/fs9922.c \
        src/dmm/m2110.c \
        src/dmm/metex14.c \
-       src/dmm/asycii.c \
+       src/dmm/mm38xr.c \
+       src/dmm/ms2115b.c \
+       src/dmm/ms8250d.c \
        src/dmm/rs9lcd.c \
-       src/dmm/bm25x.c \
-       src/dmm/ut71x.c \
        src/dmm/ut372.c \
+       src/dmm/ut71x.c \
        src/dmm/vc870.c \
-       src/dmm/dtm0660.c
+       src/dmm/vc96.c
 
 # Hardware (LCR chip parsers)
 if NEED_SERIAL
 libsigrok_la_SOURCES += \
-       src/lcr/es51919.c
+       src/lcr/es51919.c \
+       src/lcr/vc4080.c
 endif
 
 # Hardware (Scale protocol parsers)
@@ -167,15 +216,22 @@ libsigrok_la_SOURCES += \
        src/scale/kern.c
 
 # Hardware drivers
-noinst_LTLIBRARIES = src/libdrivers.la
+noinst_LTLIBRARIES = src/libdrivers.la \
+       src/libdrivers_head.la src/libdrivers_tail.la
 
-src/libdrivers.o: src/libdrivers.la
-       $(AM_V_CCLD)$(LINK) src/libdrivers.la
+src/libdrivers.o: src/libdrivers.la \
+               src/libdrivers_head.la src/libdrivers_tail.la
+       $(AM_V_CCLD)$(LINK) src/libdrivers_head.la src/libdrivers.la \
+               src/libdrivers_tail.la
 src/libdrivers.lo: src/libdrivers.o
        $(AM_V_GEN)echo "# Generated by libtool" > $@
        $(AM_V_at)echo "pic_object='libdrivers.o'" >> $@
        $(AM_V_at)echo "non_pic_object='libdrivers.o'" >> $@
 
+src_libdrivers_head_la_SOURCES = src/driver_list_start.c
+
+src_libdrivers_tail_la_SOURCES = src/driver_list_stop.c
+
 src_libdrivers_la_SOURCES = src/drivers.c
 
 if HW_AGILENT_DMM
@@ -196,12 +252,24 @@ src_libdrivers_la_SOURCES += \
        src/hardware/arachnid-labs-re-load-pro/protocol.c \
        src/hardware/arachnid-labs-re-load-pro/api.c
 endif
+if HW_ASIX_OMEGA_RTM_CLI
+src_libdrivers_la_SOURCES += \
+       src/hardware/asix-omega-rtm-cli/protocol.h \
+       src/hardware/asix-omega-rtm-cli/protocol.c \
+       src/hardware/asix-omega-rtm-cli/api.c
+endif
 if HW_ASIX_SIGMA
 src_libdrivers_la_SOURCES += \
        src/hardware/asix-sigma/protocol.h \
        src/hardware/asix-sigma/protocol.c \
        src/hardware/asix-sigma/api.c
 endif
+if HW_ATORCH
+src_libdrivers_la_SOURCES += \
+       src/hardware/atorch/protocol.h \
+       src/hardware/atorch/protocol.c \
+       src/hardware/atorch/api.c
+endif
 if HW_ATTEN_PPS3XXX
 src_libdrivers_la_SOURCES += \
        src/hardware/atten-pps3xxx/protocol.h \
@@ -221,20 +289,9 @@ src_libdrivers_la_SOURCES += \
        src/hardware/beaglelogic/beaglelogic.h \
        src/hardware/beaglelogic/protocol.h \
        src/hardware/beaglelogic/protocol.c \
-       src/hardware/beaglelogic/api.c
-endif
-if HW_BRYMEN_BM86X
-src_libdrivers_la_SOURCES += \
-       src/hardware/brymen-bm86x/protocol.h \
-       src/hardware/brymen-bm86x/protocol.c \
-       src/hardware/brymen-bm86x/api.c
-endif
-if HW_BRYMEN_DMM
-src_libdrivers_la_SOURCES += \
-       src/hardware/brymen-dmm/parser.c \
-       src/hardware/brymen-dmm/protocol.h \
-       src/hardware/brymen-dmm/protocol.c \
-       src/hardware/brymen-dmm/api.c
+       src/hardware/beaglelogic/api.c \
+       src/hardware/beaglelogic/beaglelogic_native.c \
+       src/hardware/beaglelogic/beaglelogic_tcp.c
 endif
 if HW_CEM_DT_885X
 src_libdrivers_la_SOURCES += \
@@ -266,12 +323,36 @@ src_libdrivers_la_SOURCES += \
        src/hardware/conrad-digi-35-cpu/protocol.c \
        src/hardware/conrad-digi-35-cpu/api.c
 endif
+if HW_DCTTECH_USBRELAY
+src_libdrivers_la_SOURCES += \
+       src/hardware/dcttech-usbrelay/protocol.h \
+       src/hardware/dcttech-usbrelay/protocol.c \
+       src/hardware/dcttech-usbrelay/api.c
+endif
 if HW_DEMO
 src_libdrivers_la_SOURCES += \
        src/hardware/demo/protocol.h \
        src/hardware/demo/protocol.c \
        src/hardware/demo/api.c
 endif
+if HW_DEVANTECH_ETH008
+src_libdrivers_la_SOURCES += \
+       src/hardware/devantech-eth008/protocol.h \
+       src/hardware/devantech-eth008/protocol.c \
+       src/hardware/devantech-eth008/api.c
+endif
+if HW_DREAMSOURCELAB_DSLOGIC
+src_libdrivers_la_SOURCES += \
+       src/hardware/dreamsourcelab-dslogic/protocol.h \
+       src/hardware/dreamsourcelab-dslogic/protocol.c \
+       src/hardware/dreamsourcelab-dslogic/api.c
+endif
+if HW_FLUKE_45
+src_libdrivers_la_SOURCES += \
+       src/hardware/fluke-45/protocol.h \
+       src/hardware/fluke-45/protocol.c \
+       src/hardware/fluke-45/api.c
+endif
 if HW_FLUKE_DMM
 src_libdrivers_la_SOURCES += \
        src/hardware/fluke-dmm/protocol.h \
@@ -288,9 +369,7 @@ if HW_FX2LAFW
 src_libdrivers_la_SOURCES += \
        src/hardware/fx2lafw/protocol.h \
        src/hardware/fx2lafw/protocol.c \
-       src/hardware/fx2lafw/api.c \
-       src/hardware/fx2lafw/dslogic.c \
-       src/hardware/fx2lafw/dslogic.h
+       src/hardware/fx2lafw/api.c
 endif
 if HW_GMC_MH_1X_2X
 src_libdrivers_la_SOURCES += \
@@ -298,18 +377,36 @@ src_libdrivers_la_SOURCES += \
        src/hardware/gmc-mh-1x-2x/protocol.c \
        src/hardware/gmc-mh-1x-2x/api.c
 endif
+if HW_GREATFET
+src_libdrivers_la_SOURCES += \
+       src/hardware/greatfet/protocol.h \
+       src/hardware/greatfet/protocol.c \
+       src/hardware/greatfet/api.c
+endif
 if HW_GWINSTEK_GDS_800
 src_libdrivers_la_SOURCES += \
        src/hardware/gwinstek-gds-800/protocol.h \
        src/hardware/gwinstek-gds-800/protocol.c \
        src/hardware/gwinstek-gds-800/api.c
 endif
+if HW_GWINSTEK_GPD
+src_libdrivers_la_SOURCES += \
+       src/hardware/gwinstek-gpd/protocol.h \
+       src/hardware/gwinstek-gpd/protocol.c \
+       src/hardware/gwinstek-gpd/api.c
+endif
 if HW_HAMEG_HMO
 src_libdrivers_la_SOURCES += \
        src/hardware/hameg-hmo/protocol.h \
        src/hardware/hameg-hmo/protocol.c \
        src/hardware/hameg-hmo/api.c
 endif
+if HW_HANTEK_4032L
+src_libdrivers_la_SOURCES += \
+       src/hardware/hantek-4032l/protocol.h \
+       src/hardware/hantek-4032l/protocol.c \
+       src/hardware/hantek-4032l/api.c
+endif
 if HW_HANTEK_6XXX
 src_libdrivers_la_SOURCES += \
        src/hardware/hantek-6xxx/protocol.h \
@@ -328,12 +425,30 @@ src_libdrivers_la_SOURCES += \
        src/hardware/hp-3457a/protocol.c \
        src/hardware/hp-3457a/api.c
 endif
+if HW_HP_3478A
+src_libdrivers_la_SOURCES += \
+       src/hardware/hp-3478a/protocol.h \
+       src/hardware/hp-3478a/protocol.c \
+       src/hardware/hp-3478a/api.c
+endif
+if HW_HP_59306A
+src_libdrivers_la_SOURCES += \
+       src/hardware/hp-59306a/protocol.h \
+       src/hardware/hp-59306a/protocol.c \
+       src/hardware/hp-59306a/api.c
+endif
 if HW_HUNG_CHANG_DSO_2100
 src_libdrivers_la_SOURCES += \
        src/hardware/hung-chang-dso-2100/protocol.h \
        src/hardware/hung-chang-dso-2100/protocol.c \
        src/hardware/hung-chang-dso-2100/api.c
 endif
+if HW_ICSTATION_USBRELAY
+src_libdrivers_la_SOURCES += \
+       src/hardware/icstation-usbrelay/protocol.h \
+       src/hardware/icstation-usbrelay/protocol.c \
+       src/hardware/icstation-usbrelay/api.c
+endif
 if HW_IKALOGIC_SCANALOGIC2
 src_libdrivers_la_SOURCES += \
        src/hardware/ikalogic-scanalogic2/protocol.h \
@@ -346,6 +461,24 @@ src_libdrivers_la_SOURCES += \
        src/hardware/ikalogic-scanaplus/protocol.c \
        src/hardware/ikalogic-scanaplus/api.c
 endif
+if HW_IPDBG_LA
+src_libdrivers_la_SOURCES += \
+       src/hardware/ipdbg-la/protocol.h \
+       src/hardware/ipdbg-la/protocol.c \
+       src/hardware/ipdbg-la/api.c
+endif
+if HW_ITECH_IT8500
+src_libdrivers_la_SOURCES += \
+       src/hardware/itech-it8500/protocol.h \
+       src/hardware/itech-it8500/protocol.c \
+       src/hardware/itech-it8500/api.c
+endif
+if HW_JUNTEK_JDS6600
+src_libdrivers_la_SOURCES += \
+       src/hardware/juntek-jds6600/protocol.h \
+       src/hardware/juntek-jds6600/protocol.c \
+       src/hardware/juntek-jds6600/api.c
+endif
 if HW_KECHENG_KC_330B
 src_libdrivers_la_SOURCES += \
        src/hardware/kecheng-kc-330b/protocol.h \
@@ -358,6 +491,12 @@ src_libdrivers_la_SOURCES += \
        src/hardware/kern-scale/protocol.c \
        src/hardware/kern-scale/api.c
 endif
+if HW_KINGST_LA2016
+src_libdrivers_la_SOURCES += \
+       src/hardware/kingst-la2016/protocol.h \
+       src/hardware/kingst-la2016/protocol.c \
+       src/hardware/kingst-la2016/api.c
+endif
 if HW_KORAD_KAXXXXP
 src_libdrivers_la_SOURCES += \
        src/hardware/korad-kaxxxxp/protocol.h \
@@ -388,18 +527,36 @@ src_libdrivers_la_SOURCES += \
        src/hardware/manson-hcs-3xxx/protocol.c \
        src/hardware/manson-hcs-3xxx/api.c
 endif
+if HW_MASTECH_MS6514
+src_libdrivers_la_SOURCES += \
+       src/hardware/mastech-ms6514/protocol.h \
+       src/hardware/mastech-ms6514/protocol.c \
+       src/hardware/mastech-ms6514/api.c
+endif
 if HW_MAYNUO_M97
 src_libdrivers_la_SOURCES += \
        src/hardware/maynuo-m97/protocol.h \
        src/hardware/maynuo-m97/protocol.c \
        src/hardware/maynuo-m97/api.c
 endif
+if HW_MICROCHIP_PICKIT2
+src_libdrivers_la_SOURCES += \
+       src/hardware/microchip-pickit2/protocol.h \
+       src/hardware/microchip-pickit2/protocol.c \
+       src/hardware/microchip-pickit2/api.c
+endif
 if HW_MIC_985XX
 src_libdrivers_la_SOURCES += \
        src/hardware/mic-985xx/protocol.h \
        src/hardware/mic-985xx/protocol.c \
        src/hardware/mic-985xx/api.c
 endif
+if HW_MOOSHIMETER_DMM
+src_libdrivers_la_SOURCES += \
+       src/hardware/mooshimeter-dmm/protocol.h \
+       src/hardware/mooshimeter-dmm/protocol.c \
+       src/hardware/mooshimeter-dmm/api.c
+endif
 if HW_MOTECH_LPS_30X
 src_libdrivers_la_SOURCES += \
        src/hardware/motech-lps-30x/protocol.h \
@@ -430,6 +587,36 @@ src_libdrivers_la_SOURCES += \
        src/hardware/pipistrello-ols/protocol.c \
        src/hardware/pipistrello-ols/api.c
 endif
+if HW_RASPBERRYPI_PICO
+src_libdrivers_la_SOURCES += \
+       src/hardware/raspberrypi-pico/protocol.h \
+       src/hardware/raspberrypi-pico/protocol.c \
+       src/hardware/raspberrypi-pico/api.c
+endif
+if HW_RDTECH_DPS
+src_libdrivers_la_SOURCES += \
+       src/hardware/rdtech-dps/protocol.h \
+       src/hardware/rdtech-dps/protocol.c \
+       src/hardware/rdtech-dps/api.c
+endif
+if HW_RDTECH_UM
+src_libdrivers_la_SOURCES += \
+       src/hardware/rdtech-um/protocol.h \
+       src/hardware/rdtech-um/protocol.c \
+       src/hardware/rdtech-um/api.c
+endif
+if HW_RDTECH_TC
+src_libdrivers_la_SOURCES += \
+       src/hardware/rdtech-tc/protocol.h \
+       src/hardware/rdtech-tc/protocol.c \
+       src/hardware/rdtech-tc/api.c
+endif
+if HW_RIGOL_DG
+src_libdrivers_la_SOURCES += \
+       src/hardware/rigol-dg/protocol.h \
+       src/hardware/rigol-dg/protocol.c \
+       src/hardware/rigol-dg/api.c
+endif
 if HW_RIGOL_DS
 src_libdrivers_la_SOURCES += \
        src/hardware/rigol-ds/protocol.h \
@@ -448,6 +635,18 @@ src_libdrivers_la_SOURCES += \
        src/hardware/saleae-logic16/protocol.c \
        src/hardware/saleae-logic16/api.c
 endif
+if HW_SALEAE_LOGIC_PRO
+src_libdrivers_la_SOURCES += \
+       src/hardware/saleae-logic-pro/protocol.h \
+       src/hardware/saleae-logic-pro/protocol.c \
+       src/hardware/saleae-logic-pro/api.c
+endif
+if HW_SCPI_DMM
+src_libdrivers_la_SOURCES += \
+       src/hardware/scpi-dmm/protocol.h \
+       src/hardware/scpi-dmm/protocol.c \
+       src/hardware/scpi-dmm/api.c
+endif
 if HW_SCPI_PPS
 src_libdrivers_la_SOURCES += \
        src/hardware/scpi-pps/protocol.h \
@@ -463,8 +662,16 @@ src_libdrivers_la_SOURCES += \
 endif
 if HW_SERIAL_LCR
 src_libdrivers_la_SOURCES += \
+       src/hardware/serial-lcr/protocol.h \
+       src/hardware/serial-lcr/protocol.c \
        src/hardware/serial-lcr/api.c
 endif
+if HW_SIGLENT_SDS
+src_libdrivers_la_SOURCES += \
+       src/hardware/siglent-sds/protocol.h \
+       src/hardware/siglent-sds/protocol.c \
+       src/hardware/siglent-sds/api.c
+endif
 if HW_SYSCLK_LWLA
 src_libdrivers_la_SOURCES += \
        src/hardware/sysclk-lwla/lwla.h \
@@ -475,6 +682,12 @@ src_libdrivers_la_SOURCES += \
        src/hardware/sysclk-lwla/protocol.c \
        src/hardware/sysclk-lwla/api.c
 endif
+if HW_SYSCLK_SLA5032
+src_libdrivers_la_SOURCES += \
+       src/hardware/sysclk-sla5032/protocol.h \
+       src/hardware/sysclk-sla5032/protocol.c \
+       src/hardware/sysclk-sla5032/api.c
+endif
 if HW_TELEINFO
 src_libdrivers_la_SOURCES += \
        src/hardware/teleinfo/protocol.h \
@@ -499,18 +712,18 @@ src_libdrivers_la_SOURCES += \
        src/hardware/uni-t-dmm/protocol.c \
        src/hardware/uni-t-dmm/api.c
 endif
+if HW_UNI_T_UT181A
+src_libdrivers_la_SOURCES += \
+       src/hardware/uni-t-ut181a/protocol.h \
+       src/hardware/uni-t-ut181a/protocol.c \
+       src/hardware/uni-t-ut181a/api.c
+endif
 if HW_UNI_T_UT32X
 src_libdrivers_la_SOURCES += \
        src/hardware/uni-t-ut32x/protocol.h \
        src/hardware/uni-t-ut32x/protocol.c \
        src/hardware/uni-t-ut32x/api.c
 endif
-if HW_VICTOR_DMM
-src_libdrivers_la_SOURCES += \
-       src/hardware/victor-dmm/protocol.h \
-       src/hardware/victor-dmm/protocol.c \
-       src/hardware/victor-dmm/api.c
-endif
 if HW_YOKOGAWA_DLM
 src_libdrivers_la_SOURCES += \
        src/hardware/yokogawa-dlm/protocol.h \
@@ -529,6 +742,12 @@ src_libdrivers_la_SOURCES += \
        src/hardware/zeroplus-logic-cube/protocol.c \
        src/hardware/zeroplus-logic-cube/api.c
 endif
+if HW_ZKETECH_EBD_USB
+src_libdrivers_la_SOURCES += \
+       src/hardware/zketech-ebd-usb/protocol.h \
+       src/hardware/zketech-ebd-usb/protocol.c \
+       src/hardware/zketech-ebd-usb/api.c
+endif
 
 libsigrok_la_LIBADD = src/libdrivers.lo $(SR_EXTRA_LIBS) $(LIBSIGROK_LIBS)
 libsigrok_la_LDFLAGS = -version-info $(SR_LIB_VERSION) -no-undefined
@@ -541,9 +760,47 @@ nodist_library_include_HEADERS = \
        include/libsigrok/version.h
 noinst_HEADERS = src/libsigrok-internal.h
 
+$(builddir)/src/version.lo: $(builddir)/include/libsigrok/git-version.h
+
+# Create the git-version.h file even for non-versioned source trees,
+# to reduce complexity in the library code. Re-create the header file
+# when branches change, when revisions change, or upon re-configuration.
+# Use the verbatim tagged version number when applicable, or append the
+# "-git-<hash>[-dirty]" suffix for non-tagged source trees.
+if VCS_IS_GIT
+
+$(builddir)/include/libsigrok/git-version.h: Makefile $(VERSION_GITVERSION_DEPS)
+       $(AM_V_GEN) \
+               HASH=`git -C "$(srcdir)" describe --match "@VERSION_TAG_MATCH@" --always --dirty` && \
+               HASH=`echo "$${HASH}" | sed 's/@VERSION_TAG_MATCH@-//'` && \
+               SUFFIX=`git -C "$(srcdir)" describe --match "@VERSION_TAG_MATCH@" --exact-match > /dev/null 2> /dev/null || echo "-$${HASH}"` && \
+               echo "#undef SR_PACKAGE_VERSION_STRING_SUFFIX" > $@ && \
+               echo "#define SR_PACKAGE_VERSION_STRING_SUFFIX \"$${SUFFIX}\"" >> $@
+
+else
+
+$(builddir)/include/libsigrok/git-version.h:
+       $(AM_V_GEN)echo '#define SR_PACKAGE_VERSION_STRING_SUFFIX ""' > $@
+
+endif
+
+version-clean:
+       rm -f $(builddir)/include/libsigrok/git-version.h
+
+CLEAN_EXTRA += version-clean
+
 pkgconfigdir = $(libdir)/pkgconfig
 pkgconfig_DATA = libsigrok.pc
 
+mimeappdir = $(datadir)/mime/packages
+mimeapp_DATA = contrib/vnd.sigrok.session.xml
+
+mimeicondir = $(datadir)/icons/hicolor/48x48/mimetypes
+mimeicon_DATA = contrib/libsigrok.png
+
+mimeiconscalabledir = $(datadir)/icons/hicolor/scalable/mimetypes
+mimeiconscalable_DATA = contrib/libsigrok.svg
+
 EXTRA_DIST = \
        Doxyfile \
        HACKING \
@@ -568,8 +825,17 @@ EXTRA_DIST = \
        bindings/swig/classes.i \
        bindings/swig/doc.py \
        bindings/swig/templates.i \
-       contrib/sigrok-logo-notext.png \
-       contrib/z60_libsigrok.rules
+       contrib/libsigrok_112x112.png \
+       contrib/libsigrok.png \
+       contrib/libsigrok.svg \
+       contrib/vnd.sigrok.session.xml \
+       contrib/60-libsigrok.rules \
+       contrib/61-libsigrok-plugdev.rules \
+       contrib/61-libsigrok-uaccess.rules \
+       src/minilzo/COPYING \
+       src/minilzo/Makefile \
+       src/minilzo/README.LZO \
+       src/minilzo/testmini.c
 
 if HAVE_CHECK
 TESTS = tests/main
@@ -592,14 +858,19 @@ tests_main_SOURCES = \
        tests/driver_all.c \
        tests/device.c \
        tests/trigger.c \
-       tests/analog.c
+       tests/analog.c \
+       tests/conv.c
 
 tests_main_LDADD = libsigrok.la $(SR_EXTRA_LIBS) $(TESTS_LIBS)
 
 BUILD_EXTRA =
 INSTALL_EXTRA =
 UNINSTALL_EXTRA =
-CLEAN_EXTRA =
+
+libsigrok-uninstall:
+       -rmdir $(DESTDIR)$(includedir)/libsigrok
+
+UNINSTALL_EXTRA += libsigrok-uninstall
 
 if BINDINGS_CXX
 
@@ -619,7 +890,7 @@ nodist_bindings_cxx_libsigrokcxx_la_include_HEADERS = \
 pkgconfig_DATA += bindings/cxx/libsigrokcxx.pc
 
 doxy/xml/index.xml: include/libsigrok/libsigrok.h
-       $(AM_V_GEN)cd $(srcdir) && BUILDDIR=$(abs_builddir)/ doxygen Doxyfile 2>/dev/null
+       $(AM_V_GEN)cd $(srcdir) && SRCDIR=$(abs_srcdir)/ BUILDDIR=$(abs_builddir)/ doxygen Doxyfile 2>/dev/null
 
 bindings/swig/enums.i: bindings/cxx/enums.timestamp
 bindings/cxx/enums.cpp: bindings/cxx/enums.timestamp
@@ -643,13 +914,18 @@ cxx-clean:
 
 CLEAN_EXTRA += cxx-clean
 
+cxx-uninstall:
+       -rmdir $(DESTDIR)$(includedir)/libsigrokcxx
+
+UNINSTALL_EXTRA += cxx-uninstall
+
 endif
 
 CPPXMLDOC = bindings/cxx/doxy/xml/index.xml
 
 $(CPPXMLDOC): bindings/cxx/include/libsigrokcxx/libsigrokcxx.hpp \
                bindings/cxx/enums.timestamp
-       $(AM_V_GEN)cd $(srcdir)/bindings/cxx && BUILDDIR=$(abs_builddir)/bindings/cxx/ doxygen Doxyfile 2>/dev/null
+       $(AM_V_GEN)cd $(srcdir)/bindings/cxx && SRCDIR=$(abs_srcdir)/bindings/cxx/ BUILDDIR=$(abs_builddir)/bindings/cxx/ doxygen Doxyfile 2>/dev/null
 
 # Macro definitions to be used by the SWIG parser.
 swig_defs = -Dnoexcept= -Dprivate=protected -DG_GNUC_BEGIN_IGNORE_DEPRECATIONS= -DG_GNUC_END_IGNORE_DEPRECATIONS=
@@ -697,7 +973,7 @@ python-clean:
        -$(AM_V_at)$(setup_py) clean --all 2>/dev/null
 
 python-doc:
-       $(AM_V_at)cd $(srcdir)/$(PDIR) && BUILDDIR="$(abs_builddir)/$(PDIR)/" doxygen Doxyfile 2>/dev/null
+       $(AM_V_at)cd $(srcdir)/$(PDIR) && SRCDIR="$(abs_srcdir)/$(PDIR)/" BUILDDIR="$(abs_builddir)/$(PDIR)/" doxygen Doxyfile 2>/dev/null
 
 BUILD_EXTRA += python-build
 INSTALL_EXTRA += python-install
@@ -814,7 +1090,7 @@ java-clean:
        -$(AM_V_at)rm -fr $(JDIR)/doxy
 
 java-doc:
-       $(AM_V_at)cd $(srcdir)/$(JDIR) && BUILDDIR="$(abs_builddir)/$(JDIR)/" doxygen Doxyfile
+       $(AM_V_at)cd $(srcdir)/$(JDIR) && SRCDIR="$(abs_srcdir)/$(JDIR)/" BUILDDIR="$(abs_builddir)/$(JDIR)/" doxygen Doxyfile
 
 BUILD_EXTRA += java-build
 INSTALL_EXTRA += java-install
@@ -825,7 +1101,7 @@ endif
 
 all-local: $(BUILD_EXTRA)
 install-exec-local: $(INSTALL_EXTRA)
-uninstall-local: $(UNINSTALL_EXTRA)
+uninstall-hook: $(UNINSTALL_EXTRA)
 clean-local: $(CLEAN_EXTRA)
 
 .PHONY: dist-changelog