Modify it to adjust Tizen IVI enviroment
[platform/upstream/kmscon.git] / Makefile.am
index 47c286f..8f97c06 100644 (file)
@@ -1,29 +1,43 @@
 #
 # Kmscon - Global Makefile
-# Copyright (c) 2012 David Herrmann <dh.herrmann@googlemail.com>
+# Copyright (c) 2012-2013 David Herrmann <dh.herrmann@googlemail.com>
 #
 
-ACLOCAL_AMFLAGS = -I m4
-SUBDIRS = \
-       .
+#
+# Global Configurations and Initializations
+#
+
+ACLOCAL_AMFLAGS = -I m4 ${ACLOCAL_FLAGS}
+AM_MAKEFLAGS = --no-print-directory
+AUTOMAKE_OPTIONS = color-tests
+AM_DISTCHECK_CONFIGURE_FLAGS = --enable-all
+
+SUBDIRS = .
+
+.DELETE_ON_ERROR:
+
 include_HEADERS =
 EXTRA_DIST = \
        README \
        COPYING \
-       NEWS
+       NEWS \
+       docs/kmscon.service \
+       docs/kmsconvt@.service
 CLEANFILES =
 pkgconfigdir = $(libdir)/pkgconfig
 pkgconfig_DATA =
 MANPAGES =
 MANPAGES_ALIASES =
+TPHONY =
 
 bin_PROGRAMS =
 check_PROGRAMS =
-noinst_PROGRAMS = \
-       genshader \
-       genunifont
-noinst_LTLIBRARIES =
+noinst_PROGRAMS =
 lib_LTLIBRARIES =
+noinst_LTLIBRARIES =
+
+moduledir = $(libdir)/kmscon
+module_LTLIBRARIES =
 
 #
 # Default CFlags
@@ -38,12 +52,25 @@ lib_LTLIBRARIES =
 #
 
 AM_CFLAGS = \
-       -Wall
+       -Wall \
+       -pipe \
+       -fno-common \
+       -ffast-math \
+       -fdiagnostics-show-option \
+       -fno-strict-aliasing \
+       -fvisibility=hidden \
+       -ffunction-sections \
+       -fdata-sections \
+       -fstack-protector
 AM_CPPFLAGS = \
+       -DBUILD_MODULE_DIR='"$(moduledir)"' \
        -include $(top_builddir)/config.h \
        -I $(srcdir)/src
 AM_LDFLAGS = \
-       -Wl,--as-needed
+       -Wl,--as-needed \
+       -Wl,--gc-sections \
+       -Wl,-z,relro \
+       -Wl,-z,now
 
 if BUILD_ENABLE_DEBUG
 AM_CFLAGS += -g
@@ -56,33 +83,154 @@ AM_CFLAGS += -O0
 endif
 
 #
+# GIT-HEAD helper
+# The file ./src/shl_githead.c contains a constant "shl_git_head" which is
+# defined to the string returned by "git describe". We need to adjust this
+# string for every build and correctly rebuild any sources that depend on it.
+# Therefore, you should use this file rarely as it causes rebuilds on every
+# git-commit.
+#
+# We have a helper-script ./src/genversion.sh that takes as argument the source
+# file and creates it if necessary. It updates it only if the new git-describe
+# string is different to the old one. So the file is only modified on changes.
+# Hence, we can use it as normal dependency in this Makefile.
+# However, we need to run this script on _every_ "make" invocation before any
+# recipy is executed. To achieve this, we use $(shell ...) and assign it to a
+# "simply expanded" variable (:=) so the shell command is executed on
+# variable-declaration and not during expansion.
+#
+# Note that we must not clean ./src/shl_githead.c ever! If we would, a
+# distribution tarball might delete that file and have no way to recreate it.
+# We could delete it on something like "make maintainerclean", but then again,
+# it seems unnecessary so lets simply not clean it at all.
+#
+# If the helper-script is executed in a directory that is not a git-repository
+# (like a distribution tarball) and shl_githead.c exists, then it does nothing
+# as it expects shl_githead.c to be correctly written by "make dist".
+# However, if shl_githead.c does not exist, it will print a warning and write
+# an unknown random git-revision.
+# This guarantees, that shl_githead.c is always present and has the most correct
+# value that we can get under any conditions.
+#
+# The $(emptyvariable) expansion below is used for broken $(shell ...)
+# syntax-highlighting algorithms in many existing editors.
+#
+
+EXTRA_DIST += src/genversion.sh
+GITHEAD:=$(shell $(emptyvariable)"$(srcdir)/src/genversion.sh" "$(srcdir)/src/shl_githead.c")
+
+#
+# Binary File Compiler
+# This target gets as input a binary file *.bin and produces an ELF/etc. output
+# object file *.bin.o and the corresponding libtool file *.bin.lo.
+# Note that we fake the libtool object files as there is no way to make libtool
+# create it. The comments in the .lo file are mandatory so don't remove them!
+#
+
+CLEANFILES += src/*.bin.lo src/*.bin.o
+
+src/%.bin.lo: src/%.bin
+       $(AM_V_GEN)$(LD) -r -o "src/$*.bin.o" -z noexecstack --format=binary "$<"
+       $(AM_V_at)$(OBJCOPY) --rename-section .data=.rodata,alloc,load,readonly,data,contents "src/$*.bin.o"
+       $(AM_V_at)echo "# $@ - a libtool object file" >"$@"
+       $(AM_V_at)echo "# Generated by $(shell $(LIBTOOL) --version | head -n 1)" >>"$@"
+       $(AM_V_at)echo "#" >>"$@"
+       $(AM_V_at)echo "# Please DO NOT delete this file!" >>"$@"
+       $(AM_V_at)echo "# It is necessary for linking the library." >>"$@"
+       $(AM_V_at)echo >>"$@"
+       $(AM_V_at)echo "# Name of the PIC object." >>"$@"
+       $(AM_V_at)echo "pic_object='$*.bin.o'" >>"$@"
+       $(AM_V_at)echo >>"$@"
+       $(AM_V_at)echo "# Name of the non-PIC object" >>"$@"
+       $(AM_V_at)echo "non_pic_object='$*.bin.o'" >>"$@"
+       $(AM_V_at)echo >>"$@"
+
+#
+# Shader Converter
+# We use a few built-in shader files. To reduce memory-consumption, this helper
+# removes useless lines from the shaders before they are compiled into an object
+# file.
+#
+# Following regexp are used to remove characters/lines:
+#  ^/*.*$     Start of multi-line comment
+#  ^ *.*$     Multi-line comment body
+#  ^[ \t]*    Indentation whitespace
+#  [\r\n]     Newlines
+#
+
+CLEANFILES += src/*.vert.bin src/*.frag.bin
+SHADER_SED = -e 's/^\/\*.*$$//' -e 's/^ \*.*$$//' -e 's/^[ \t]*//'
+SHADER_TR = -d "\r\n"
+
+src/%.vert.bin: $(top_srcdir)/src/%.vert
+       $(AM_V_at)$(SED) $(SHADER_SED) "$<" | tr $(SHADER_TR) >"$@"
+
+src/%.frag.bin: $(top_srcdir)/src/%.frag
+       $(AM_V_at)$(SED) $(SHADER_SED) "$<" | tr $(SHADER_TR) >"$@"
+
+#
+# XKB Fallback Converter
+# We use a static built-in XKB fallback keymap. To avoid huge memory consumption
+# we remove useless lines/characters first.
+# We also append an ASCII 0 character so it can be used as regular C-string.
+#
+# Following regexp are used to remove characters/lines:
+#   *= *           Whitespace around assignments
+#   *, *           Whitespace around commatas
+#   *[][{}()] *    Whitespace around braces
+#  ^[ \t]*         Indentation whitespace
+#  [\r\n]          Newlines
+#
+
+CLEANFILES += src/*.xkb.bin
+XKB_SED = -e 's/^[ \t]*//' -e 's/ *\([,=]\) */\1/g' -e 's/ *\([][{}()]\) */\1/g'
+XKB_TR = -d "\r\n"
+
+src/%.xkb.bin: $(top_srcdir)/src/%.xkb
+       $(AM_V_at)$(SED) $(XKB_SED) "$<" | tr $(XKB_TR) >"$@"
+       $(AM_V_at)echo -ne "\x00" >>"$@"
+
+#
 # SHL - Static Helper Library
 # The SHL subsystem contains several small code pieces used all over kmscon and
 # other applications.
 #
-# Simply include $(SHL_*) in your source-file list. Except for SHL_MISC none of
-# these have external dependencies. SHL_MISC needs xkbcommon.
-#
 
-SHL_DLIST = \
-       src/shl_dlist.h
-SHL_ARRAY = \
-       src/shl_array.h
-SHL_HASHTABLE = \
+noinst_LTLIBRARIES += libshl.la
+
+libshl_la_SOURCES = \
+       src/shl_githead.h \
+       src/shl_githead.c \
+       src/shl_dlist.h \
+       src/shl_array.h \
        src/shl_hashtable.h \
        external/htable.h \
-       external/htable.c
-SHL_RING = \
-       src/shl_ring.h
-SHL_TIMER = \
-       src/shl_timer.h
-SHL_LLOG = \
-       src/shl_llog.h
-SHL_HOOK = \
+       external/htable.c \
+       src/shl_ring.h \
+       src/shl_timer.h \
+       src/shl_llog.h \
+       src/shl_log.h \
+       src/shl_log.c \
        src/shl_hook.h \
-       $(SHL_DLIST)
-SHL_MISC = \
-       src/shl_misc.h
+       src/shl_misc.h \
+       src/shl_register.h \
+       src/shl_flagset.h
+libshl_la_CPPFLAGS = \
+       $(AM_CPPFLAGS) \
+       $(XKBCOMMON_CFLAGS) \
+       -pthread
+libshl_la_LDFLAGS = \
+       $(AM_LDFLAGS) \
+       -pthread
+libshl_la_LIBADD = \
+       $(AM_LIBADD) \
+       $(XKBCOMMON_LIBS)
+
+if BUILD_HAVE_GLES2
+libshl_la_SOURCES += src/shl_gl.h src/shl_gl_shader.c src/shl_gl_math.c
+libshl_la_CPPFLAGS += $(GLES2_CFLAGS)
+libshl_la_LIBADD += $(GLES2_LIBS)
+endif
 
 #
 # libeloop
@@ -90,74 +238,15 @@ SHL_MISC = \
 # compiled into a separate object to allow using it in several other programs.
 #
 
-if BUILD_ENABLE_ELOOP
-lib_LTLIBRARIES += libeloop.la
-include_HEADERS += src/eloop.h
-pkgconfig_DATA += docs/pc/libeloop.pc
-endif
+noinst_LTLIBRARIES += libeloop.la
 
 libeloop_la_SOURCES = \
-       $(SHL_DLIST) \
-       $(SHL_LLOG) \
-       $(SHL_HOOK) \
        src/eloop.h \
        src/eloop.c
 
-libeloop_la_CPPFLAGS = \
-       $(AM_CPPFLAGS)
-libeloop_la_LIBADD =
-libeloop_la_LDFLAGS = \
-       -version-info 1:0:0
-
-
-if BUILD_ENABLE_ELOOP_DBUS
-libeloop_la_SOURCES += \
-       external/dbus-common.h \
-       external/dbus-loop.h \
-       external/dbus-loop.c
-libeloop_la_CPPFLAGS += \
-       $(DBUS_CFLAGS)
-libeloop_la_LIBADD += \
-       $(DBUS_LIBS)
-endif
-
-#
-# libtsm
-# The Terminal-emulator State Machine is a library that implements the whole VTE
-# layer and everything related to it. It has no external dependencies so it can
-# be used to implement any kind of terminal emulator or debugger.
-#
-
-if BUILD_ENABLE_TSM
-lib_LTLIBRARIES += \
-       libtsm.la
-include_HEADERS += \
-       src/tsm_screen.h \
-       src/tsm_unicode.h \
-       src/tsm_vte.h
-pkgconfig_DATA += \
-       docs/pc/libtsm.pc
-endif
-
-libtsm_la_SOURCES = \
-       $(SHL_LLOG) \
-       $(SHL_TIMER) \
-       $(SHL_ARRAY) \
-       $(SHL_HASHTABLE) \
-       src/tsm_screen.h \
-       src/tsm_screen.c \
-       src/tsm_unicode.h \
-       src/tsm_unicode.c \
-       src/tsm_vte.h \
-       src/tsm_vte.c \
-       src/tsm_vte_charsets.c
-
-libtsm_la_CPPFLAGS = \
-       $(AM_CPPFLAGS) \
-       $(XKBCOMMON_CFLAGS)
-libtsm_la_LDFLAGS = \
-       $(XKBCOMMON_LIBS) \
-       -version-info 1:0:0
+libeloop_la_LIBADD = libshl.la
+libeloop_la_CPPFLAGS = $(AM_CPPFLAGS)
+libeloop_la_LDFLAGS = $(AM_LDFLAGS)
 
 #
 # libuterm
@@ -167,21 +256,16 @@ libtsm_la_LDFLAGS = \
 # abstractions and an input layer
 #
 
-if BUILD_ENABLE_UTERM
-lib_LTLIBRARIES += libuterm.la
-include_HEADERS += src/uterm.h
-pkgconfig_DATA += docs/pc/libuterm.pc
-endif
+noinst_LTLIBRARIES += libuterm.la
 
 libuterm_la_SOURCES = \
-       $(SHL_DLIST) \
-       $(SHL_HOOK) \
-       $(SHL_MISC) \
-       src/uterm.h \
        src/uterm_input.h \
+       src/uterm_monitor.h \
        src/uterm_video.h \
-       src/uterm_pci.h \
-       src/uterm_systemd.h \
+       src/uterm_vt.h \
+       src/uterm_input_internal.h \
+       src/uterm_video_internal.h \
+       src/uterm_systemd_internal.h \
        src/uterm_video.c \
        src/uterm_monitor.c \
        src/uterm_vt.c \
@@ -192,12 +276,16 @@ nodist_libuterm_la_SOURCES =
 
 libuterm_la_CPPFLAGS = \
        $(AM_CPPFLAGS) \
+       $(UDEV_CFLAGS) \
        $(XKBCOMMON_CFLAGS)
-libuterm_la_LIBADD =
+libuterm_la_LIBADD = \
+       $(UDEV_LIBS) \
        $(XKBCOMMON_LIBS) \
-       libeloop.la
+       libeloop.la \
+       libshl.la \
+       src/uterm_input_fallback.xkb.bin.lo
 libuterm_la_LDFLAGS = \
-       -version-info 1:0:0
+       $(AM_LDFLAGS)
 
 if BUILD_ENABLE_MULTI_SEAT
 libuterm_la_SOURCES += src/uterm_systemd.c
@@ -205,35 +293,27 @@ libuterm_la_CPPFLAGS += $(SYSTEMD_CFLAGS)
 libuterm_la_LIBADD += $(SYSTEMD_LIBS)
 endif
 
-if BUILD_ENABLE_HOTPLUG
-libuterm_la_CPPFLAGS += $(UDEV_CFLAGS)
-libuterm_la_LIBADD += $(UDEV_LIBS)
-endif
-
-if BUILD_ENABLE_PCIACCESS
-libuterm_la_CPPFLAGS += $(PCIACCESS_CFLAGS)
-libuterm_la_LIBADD += $(PCIACCESS_LIBS)
-libuterm_la_SOURCES += src/uterm_pci.c
-endif
-
 if BUILD_ENABLE_VIDEO_FBDEV
-libuterm_la_SOURCES += src/uterm_video_fbdev.c
+libuterm_la_SOURCES += \
+       src/uterm_fbdev_internal.h \
+       src/uterm_fbdev_video.c \
+       src/uterm_fbdev_render.c
 endif
 
-if BUILD_ENABLE_VIDEO_DUMB
-libuterm_la_SOURCES += src/uterm_video_dumb.c
+if BUILD_ENABLE_VIDEO_DRM2D
+libuterm_la_SOURCES += \
+       src/uterm_drm2d_internal.h \
+       src/uterm_drm2d_video.c \
+       src/uterm_drm2d_render.c
 libuterm_la_CPPFLAGS += $(DRM_CFLAGS)
 libuterm_la_LIBADD += $(DRM_LIBS)
 endif
 
-if BUILD_ENABLE_VIDEO_DRM
+if BUILD_ENABLE_VIDEO_DRM3D
 libuterm_la_SOURCES += \
-       src/uterm_video_drm.c \
-       src/static_gl.h \
-       src/static_gl_math.c \
-       src/static_gl_shader.c
-nodist_libuterm_la_SOURCES += \
-       src/static_shaders.c
+       src/uterm_drm3d_internal.h \
+       src/uterm_drm3d_video.c \
+       src/uterm_drm3d_render.c
 libuterm_la_CPPFLAGS += \
        $(DRM_CFLAGS) \
        $(EGL_CFLAGS) \
@@ -243,99 +323,151 @@ libuterm_la_LIBADD += \
        $(DRM_LIBS) \
        $(EGL_LIBS) \
        $(GBM_LIBS) \
-       $(GLES2_LIBS)
+       $(GLES2_LIBS) \
+       src/uterm_drm3d_blend.vert.bin.lo \
+       src/uterm_drm3d_blend.frag.bin.lo \
+       src/uterm_drm3d_blit.vert.bin.lo \
+       src/uterm_drm3d_blit.frag.bin.lo \
+       src/uterm_drm3d_fill.vert.bin.lo \
+       src/uterm_drm3d_fill.frag.bin.lo
 endif
 
-#
-# Shaders
-# As there is no need to modify shaders at run-time, we statically compile them
-# into object files. As autotools would ignore them, we need to add them to
-# EXTRA_DIST.
-# The program that converts the shaders into C-source files is "genshader". It's
-# pretty simple and just creates a string with the shader source as content.
-#
-
-SHADERS = \
-       $(srcdir)/src/static_fill.vert \
-       $(srcdir)/src/static_fill.frag \
-       $(srcdir)/src/static_blend.vert \
-       $(srcdir)/src/static_blend.frag \
-       $(srcdir)/src/static_blit.vert \
-       $(srcdir)/src/static_blit.frag \
-       $(srcdir)/src/static_gltex.vert \
-       $(srcdir)/src/static_gltex.frag
-
-EXTRA_DIST += $(SHADERS)
-CLEANFILES += src/static_shaders.c
-genshader_SOURCES = src/genshader.c
-
-src/static_shaders.c: $(SHADERS) genshader$(EXEEXT)
-       $(AM_V_GEN)./genshader$(EXEEXT) src/static_shaders.c $(SHADERS)
+# add shared sources only once
+UTERM_DRM_SHARED_SRC = \
+       src/uterm_drm_shared_internal.h \
+       src/uterm_drm_shared.c
+if BUILD_ENABLE_VIDEO_DRM2D
+libuterm_la_SOURCES += $(UTERM_DRM_SHARED_SRC)
+else
+if BUILD_ENABLE_VIDEO_DRM3D
+libuterm_la_SOURCES += $(UTERM_DRM_SHARED_SRC)
+endif
+endif
 
 #
 # Unifont Generator
 # This generates the unifont sources from raw hex-encoded font data.
 #
 
-UNIFONT = src/text_font_unifont_data.hex
+UNIFONT = $(top_srcdir)/src/font_unifont_data.hex
+UNIFONT_BIN = src/font_unifont_data.bin
+UNIFONT_LT = src/font_unifont_data.bin.lo
 
 EXTRA_DIST += $(UNIFONT)
-CLEANFILES += src/text_font_unifont_data.c
+CLEANFILES += $(UNIFONT_BIN)
 genunifont_SOURCES = src/genunifont.c
 
-src/text_font_unifont_data.c: $(UNIFONT) genunifont$(EXEEXT)
-       $(AM_V_GEN)./genunifont$(EXEEXT) src/text_font_unifont_data.c $(UNIFONT)
+genunifont$(BUILD_EXEEXT) $(genunifont_OBJECTS): CC = $(CC_FOR_BUILD)
+genunifont$(BUILD_EXEEXT) $(genunifont_OBJECTS): CFLAGS = $(CFLAGS_FOR_BUILD)
+genunifont$(BUILD_EXEEXT): LDFLAGS = $(LDFLAGS_FOR_BUILD)
+
+$(UNIFONT_BIN): $(UNIFONT) genunifont$(BUILD_EXEEXT)
+       $(AM_V_GEN)./genunifont$(BUILD_EXEEXT) $(UNIFONT_BIN) $(UNIFONT)
 
 #
-# Text-font library
-# The text-font library is used by kmscon _and_ wlterm but is currently linked
-# statically as it hasn't been cleaned up entirely.
-# It has a build-time dependency to UTERM and runtime dependencies to TSM.
+# Kmscon Modules
 #
 
-if BUILD_ENABLE_KMSCON
-noinst_LTLIBRARIES += libtext-font.la
-else
-if BUILD_ENABLE_WLTERM
-noinst_LTLIBRARIES += libtext-font.la
-endif
+if BUILD_ENABLE_FONT_UNIFONT
+module_LTLIBRARIES += mod-unifont.la
+noinst_PROGRAMS += genunifont
 endif
 
-libtext_font_la_SOURCES = \
-       $(SHL_DLIST) \
-       $(SHL_HASHTABLE) \
-       $(SHL_HOOK) \
-       src/text.h \
-       src/text_font.c
-nodist_libtext_font_la_SOURCES =
+mod_unifont_la_SOURCES = \
+       src/kmscon_module_interface.h \
+       src/font_unifont.c \
+       src/kmscon_mod_unifont.c
+mod_unifont_la_LIBADD = \
+       $(UNIFONT_LT) \
+       libshl.la
+mod_unifont_la_LDFLAGS = \
+       $(AM_LDFLAGS) \
+       -module \
+       -avoid-version
+
+if BUILD_ENABLE_FONT_PANGO
+module_LTLIBRARIES += mod-pango.la
+endif
 
-libtext_font_la_CPPFLAGS = \
-       $(AM_CPPFLAGS)
-libtext_font_la_LIBADD = \
+mod_pango_la_SOURCES = \
+       src/kmscon_module_interface.h \
+       src/font_pango.c \
+       src/kmscon_mod_pango.c
+mod_pango_la_CPPFLAGS = \
+       $(AM_CPPFLAGS) \
+       $(PANGO_CFLAGS) \
+       $(TSM_CFLAGS)
+mod_pango_la_LIBADD = \
+       $(PANGO_LIBS) \
+       $(TSM_LIBS) \
        -lpthread \
-       libtsm.la
+       libshl.la
+mod_pango_la_LDFLAGS = \
+       $(AM_LDFLAGS) \
+       -module \
+       -avoid-version
 
-if BUILD_ENABLE_FONT_8X16
-libtext_font_la_SOURCES += src/text_font_8x16.c
+if BUILD_ENABLE_RENDERER_BBULK
+module_LTLIBRARIES += mod-bbulk.la
 endif
 
-if BUILD_ENABLE_FONT_UNIFONT
-libtext_font_la_SOURCES += src/text_font_unifont.c
-nodist_libtext_font_la_SOURCES += src/text_font_unifont_data.c
-endif
+mod_bbulk_la_SOURCES = \
+       src/kmscon_module_interface.h \
+       src/text_bbulk.c \
+       src/kmscon_mod_bbulk.c
+mod_bbulk_la_CPPFLAGS = \
+       $(AM_CPPFLAGS) \
+       $(TSM_CFLAGS)
+mod_bbulk_la_LIBADD = \
+       $(TSM_LIBS) \
+       libshl.la
+mod_bbulk_la_LDFLAGS = \
+       $(AM_LDFLAGS) \
+       -module \
+       -avoid-version
 
-if BUILD_ENABLE_FONT_FREETYPE2
-libtext_font_la_SOURCES += src/text_font_freetype2.c
-libtext_font_la_CPPFLAGS += $(FREETYPE2_CFLAGS)
-libtext_font_la_LIBADD += $(FREETYPE2_LIBS)
+if BUILD_ENABLE_RENDERER_GLTEX
+module_LTLIBRARIES += mod-gltex.la
 endif
 
-if BUILD_ENABLE_FONT_PANGO
-libtext_font_la_SOURCES += src/text_font_pango.c
-libtext_font_la_CPPFLAGS += $(PANGO_CFLAGS)
-libtext_font_la_LIBADD += $(PANGO_LIBS)
+mod_gltex_la_SOURCES = \
+       src/kmscon_module_interface.h \
+       src/text_gltex.c \
+       src/kmscon_mod_gltex.c
+mod_gltex_la_CPPFLAGS = \
+       $(AM_CPPFLAGS) \
+       $(TSM_CFLAGS) \
+       $(GLES2_CFLAGS)
+mod_gltex_la_LIBADD = \
+       $(GLES2_LIBS) \
+       $(TSM_LIBS) \
+       libshl.la \
+       src/text_gltex_atlas.vert.bin.lo \
+       src/text_gltex_atlas.frag.bin.lo
+mod_gltex_la_LDFLAGS = \
+       $(AM_LDFLAGS) \
+       -module \
+       -avoid-version
+
+if BUILD_ENABLE_RENDERER_PIXMAN
+module_LTLIBRARIES += mod-pixman.la
 endif
 
+mod_pixman_la_SOURCES = \
+       src/kmscon_module_interface.h \
+       src/text_pixman.c \
+       src/kmscon_mod_pixman.c
+mod_pixman_la_CPPFLAGS = \
+       $(AM_CPPFLAGS) \
+       $(PIXMAN_CFLAGS)
+mod_pixman_la_LIBADD = \
+       $(PIXMAN_LIBS) \
+       libshl.la
+mod_pixman_la_LDFLAGS = \
+       $(AM_LDFLAGS) \
+       -module \
+       -avoid-version
+
 #
 # Binaries
 # These are the sources for the main binaries and test programs. They mostly
@@ -343,34 +475,30 @@ endif
 # built as part of kmscon.
 #
 
-if BUILD_ENABLE_KMSCON
 bin_PROGRAMS += kmscon
 check_PROGRAMS += \
        test_output \
        test_vt \
        test_input \
        test_key
-endif
+MANPAGES += docs/man/kmscon.1
 
 kmscon_SOURCES = \
-       $(SHL_DLIST) \
-       $(SHL_MISC) \
-       $(SHL_ARRAY) \
-       $(SHL_HASHTABLE) \
-       $(SHL_RING) \
-       $(SHL_TIMER) \
-       $(SHL_HOOK) \
        src/conf.h \
        src/conf.c \
-       src/log.h \
-       src/log.c \
        src/pty.h \
        src/pty.c \
+       src/font.h \
+       src/font.c \
+       src/font_8x16.c \
        src/text.h \
        src/text.c \
+       src/text_bblit.c \
+       src/kmscon_module_interface.h \
+       src/kmscon_module.h \
+       src/kmscon_module.c \
        src/kmscon_terminal.h \
        src/kmscon_dummy.h \
-       src/kmscon_cdev.h \
        src/kmscon_seat.h \
        src/kmscon_seat.c \
        src/kmscon_conf.h \
@@ -380,13 +508,19 @@ nodist_kmscon_SOURCES =
 
 kmscon_CPPFLAGS = \
        $(AM_CPPFLAGS) \
-       $(XKBCOMMON_CFLAGS)
+       $(XKBCOMMON_CFLAGS) \
+       $(TSM_CFLAGS)
 kmscon_LDADD = \
        $(XKBCOMMON_LIBS) \
+       $(TSM_LIBS) \
        libeloop.la \
        libuterm.la \
-       libtext-font.la \
-       -lpthread
+       libshl.la \
+       -lpthread \
+       -ldl
+kmscon_LDFLAGS = \
+       $(AM_LDFLAGS) \
+       -rdynamic
 
 if BUILD_ENABLE_SESSION_DUMMY
 kmscon_SOURCES += src/kmscon_dummy.c
@@ -394,96 +528,28 @@ endif
 
 if BUILD_ENABLE_SESSION_TERMINAL
 kmscon_SOURCES += src/kmscon_terminal.c
-kmscon_LDADD += libtsm.la
-endif
-
-if BUILD_ENABLE_SESSION_CDEV
-kmscon_SOURCES += src/kmscon_cdev.c
-kmscon_CPPFLAGS += $(FUSE_CFLAGS)
-kmscon_LDADD += $(FUSE_LIBS)
-endif
-
-if BUILD_ENABLE_RENDERER_BBLIT
-kmscon_SOURCES += src/text_bblit.c
-endif
-
-if BUILD_ENABLE_RENDERER_BBULK
-kmscon_SOURCES += src/text_bbulk.c
-endif
-
-if BUILD_ENABLE_RENDERER_GLTEX
-kmscon_SOURCES += \
-       src/text_gltex.c \
-       src/static_gl.h \
-       src/static_gl_math.c \
-       src/static_gl_shader.c
-nodist_kmscon_SOURCES += src/static_shaders.c
-kmscon_CPPFLAGS += $(GLES2_CFLAGS)
-kmscon_LDADD += $(GLES2_LIBS)
-MANPAGES += docs/man/kmscon.1
-endif
-
-#
-# Wayland Terminal
-#
-
-if BUILD_ENABLE_WLTERM
-bin_PROGRAMS += wlterm
 endif
 
-wlterm_SOURCES = \
-       $(SHL_MISC) \
-       $(SHL_ARRAY) \
-       $(SHL_DLIST) \
-       $(SHL_HOOK) \
-       src/wlt_main.h \
-       src/wlt_main.c \
-       src/wlt_toolkit.h \
-       src/wlt_toolkit.c \
-       src/wlt_theme.h \
-       src/wlt_theme.c \
-       src/wlt_terminal.h \
-       src/wlt_terminal.c \
-       src/log.h \
-       src/log.c \
-       src/conf.h \
-       src/conf.c \
-       src/pty.h \
-       src/pty.c
-wlterm_CPPFLAGS = \
-       $(AM_CPPFLAGS) \
-       $(WAYLAND_CFLAGS) \
-       $(XKBCOMMON_CFLAGS)
-wlterm_LDADD = \
-       $(WAYLAND_LIBS) \
-       $(XKBCOMMON_LIBS) \
-       libeloop.la \
-       libtsm.la \
-       libtext-font.la \
-       -lpthread
-
 #
 # Tests
 #
 
 test_sources = \
-       src/log.h \
-       src/log.c \
        src/conf.h \
        src/conf.c \
        tests/test_include.h
 test_cflags = \
+       $(AM_CPPFLAGS) \
        $(XKBCOMMON_CFLAGS)
 test_libs = \
        $(XKBCOMMON_LIBS) \
-       libeloop.la
+       libeloop.la \
+       libshl.la
 
 test_output_SOURCES = \
        $(test_sources) \
        tests/test_output.c
-test_output_CPPFLAGS = \
-       $(AM_CPPFLAGS) \
-       $(test_cflags)
+test_output_CPPFLAGS = $(test_cflags)
 test_output_LDADD = \
        $(test_libs) \
        libuterm.la
@@ -491,9 +557,7 @@ test_output_LDADD = \
 test_vt_SOURCES = \
        $(test_sources) \
        tests/test_vt.c
-test_vt_CPPFLAGS = \
-       $(AM_CPPFLAGS) \
-       $(test_cflags)
+test_vt_CPPFLAGS = $(test_cflags)
 test_vt_LDADD = \
        $(test_libs) \
        libuterm.la
@@ -501,9 +565,7 @@ test_vt_LDADD = \
 test_input_SOURCES = \
        $(test_sources) \
        tests/test_input.c
-test_input_CPPFLAGS = \
-       $(AM_CPPFLAGS) \
-       $(test_cflags)
+test_input_CPPFLAGS = $(test_cflags)
 test_input_LDADD = \
        $(test_libs) \
        libuterm.la
@@ -511,25 +573,21 @@ test_input_LDADD = \
 test_key_SOURCES = \
        $(test_sources) \
        tests/test_key.c
-test_key_CPPFLAGS = \
-       $(AM_CPPFLAGS) \
-       $(test_cflags)
-test_key_LDADD = \
-       $(test_libs)
+test_key_CPPFLAGS = $(test_cflags)
+test_key_LDADD = $(test_libs)
 
 #
 # Manpages
 #
 
-MAN_XML_FILES = ${patsubst %.1,%.xml,${patsubst %.3,%.xml,${patsubst %.5,%.xml,${patsubst %.7,%.xml,$(MANPAGES)}}}}
 man_MANS =
+EXTRA_DIST += ${patsubst %.1,%.xml,${patsubst %.3,%.xml,${patsubst %.5,%.xml,${patsubst %.7,%.xml,$(MANPAGES)}}}}
+CLEANFILES += $(MANPAGES) $(MANPAGES_ALIASES) .man_fixup
 
 if BUILD_HAVE_XSLTPROC
 if BUILD_HAVE_MANPAGES_STYLESHEET
 
-CLEANFILES += $(MANPAGES) $(MANPAGES_ALIASES)
-EXTRA_DIST += $(MANPAGES) $(MANPAGES_ALIASES) $(XML_FILES)
-man_MANS += $(MANPAGES) $(MANPAGES_ALIASES) man_fixup_aliases
+man_MANS += $(MANPAGES) $(MANPAGES_ALIASES)
 
 XSLTPROC_FLAGS = \
        --stringparam man.authors.section.enabled 0 \
@@ -540,10 +598,15 @@ XSLTPROC_FLAGS = \
 
 XSLTPROC_PROCESS_MAN = \
        $(AM_V_GEN)$(MKDIR_P) $(dir $@) && \
-       $(XSLTPROC) -o $@ $(XSLTPROC_FLAGS) $(BUILD_MANPAGES_STYLESHEET) $<
+       $(XSLTPROC) -o "$@" $(XSLTPROC_FLAGS) $(BUILD_MANPAGES_STYLESHEET) "$<" && \
+       touch .man_fixup
+
+# Force .man_fixup if $(MANPAGES) are not built
+.man_fixup: | $(MANPAGES)
+       @touch .man_fixup
 
-man_fixup_aliases: $(MANPAGES) $(MANPAGES_ALIASES)
-       $(AM_V_GEN)if test -n "$(MANPAGES_ALIASES)" ; then $(SED) -i -e 's/^\.so \([a-z_]\+\)\.\([0-9]\)$$/\.so man\2\/\1\.\2/' $(MANPAGES_ALIASES) ; fi
+$(MANPAGES_ALIASES): $(MANPAGES) .man_fixup
+       $(AM_V_GEN)if test -n "$@" ; then $(SED) -i -e 's/^\.so \([a-z_]\+\)\.\([0-9]\)$$/\.so man\2\/\1\.\2/' "$@" ; fi
 
 docs/man/%.1: docs/man/%.xml
        $(XSLTPROC_PROCESS_MAN)
@@ -559,3 +622,16 @@ docs/man/%.7: docs/man/%.xml
 
 endif # BUILD_HAVE_MANPAGES_STYLESHEET
 endif # BUILD_HAVE_XSLTPROC
+
+#
+# Phony targets
+#
+
+.PHONY: $(TPHONY)
+
+#
+# Empty .SECONDARY target causes alle intermediate files to be treated as
+# secondary files. That is, they don't get deleted after make finished.
+#
+
+.SECONDARY: