build-sys: link with slirp as an external project
Use the "system" libslirp if its present or requested. Else build with a static libslirp.a if slirp/ is checked out ("internal") or a submodule ("git"). Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com> Message-Id: <20190212162524.31504-7-marcandre.lureau@redhat.com> Signed-off-by: Samuel Thibault <samuel.thibault@ens-lyon.org>
This commit is contained in:
parent
12f8beeb9f
commit
675b9b5368
8
Makefile
8
Makefile
@ -383,8 +383,7 @@ dummy := $(call unnest-vars,, \
|
|||||||
ui-obj-m \
|
ui-obj-m \
|
||||||
audio-obj-y \
|
audio-obj-y \
|
||||||
audio-obj-m \
|
audio-obj-m \
|
||||||
trace-obj-y \
|
trace-obj-y)
|
||||||
slirp-obj-y)
|
|
||||||
|
|
||||||
include $(SRC_PATH)/tests/Makefile.include
|
include $(SRC_PATH)/tests/Makefile.include
|
||||||
|
|
||||||
@ -458,7 +457,10 @@ CAP_CFLAGS += -DCAPSTONE_HAS_X86
|
|||||||
subdir-capstone: .git-submodule-status
|
subdir-capstone: .git-submodule-status
|
||||||
$(call quiet-command,$(MAKE) -C $(SRC_PATH)/capstone CAPSTONE_SHARED=no BUILDDIR="$(BUILD_DIR)/capstone" CC="$(CC)" AR="$(AR)" LD="$(LD)" RANLIB="$(RANLIB)" CFLAGS="$(CAP_CFLAGS)" $(SUBDIR_MAKEFLAGS) $(BUILD_DIR)/capstone/$(LIBCAPSTONE))
|
$(call quiet-command,$(MAKE) -C $(SRC_PATH)/capstone CAPSTONE_SHARED=no BUILDDIR="$(BUILD_DIR)/capstone" CC="$(CC)" AR="$(AR)" LD="$(LD)" RANLIB="$(RANLIB)" CFLAGS="$(CAP_CFLAGS)" $(SUBDIR_MAKEFLAGS) $(BUILD_DIR)/capstone/$(LIBCAPSTONE))
|
||||||
|
|
||||||
$(SUBDIR_RULES): libqemuutil.a $(common-obj-y) $(chardev-obj-y) $(slirp-obj-y) \
|
subdir-slirp: .git-submodule-status
|
||||||
|
$(call quiet-command,$(MAKE) -C $(SRC_PATH)/slirp BUILD_DIR="$(BUILD_DIR)/slirp" CC="$(CC)" AR="$(AR)" LD="$(LD)" RANLIB="$(RANLIB)" CFLAGS="$(QEMU_CFLAGS)")
|
||||||
|
|
||||||
|
$(SUBDIR_RULES): libqemuutil.a $(common-obj-y) $(chardev-obj-y) \
|
||||||
$(qom-obj-y) $(crypto-aes-obj-$(CONFIG_USER_ONLY))
|
$(qom-obj-y) $(crypto-aes-obj-$(CONFIG_USER_ONLY))
|
||||||
|
|
||||||
ROMSUBDIR_RULES=$(patsubst %,romsubdir-%, $(ROMS))
|
ROMSUBDIR_RULES=$(patsubst %,romsubdir-%, $(ROMS))
|
||||||
|
@ -4,7 +4,6 @@ stub-obj-y = stubs/ util/ crypto/
|
|||||||
util-obj-y = util/ qobject/ qapi/
|
util-obj-y = util/ qobject/ qapi/
|
||||||
|
|
||||||
chardev-obj-y = chardev/
|
chardev-obj-y = chardev/
|
||||||
slirp-obj-$(CONFIG_SLIRP) = slirp/
|
|
||||||
|
|
||||||
#######################################################################
|
#######################################################################
|
||||||
# authz-obj-y is code used by both qemu system emulation and qemu-img
|
# authz-obj-y is code used by both qemu system emulation and qemu-img
|
||||||
|
@ -174,7 +174,6 @@ target-obj-y :=
|
|||||||
block-obj-y :=
|
block-obj-y :=
|
||||||
common-obj-y :=
|
common-obj-y :=
|
||||||
chardev-obj-y :=
|
chardev-obj-y :=
|
||||||
slirp-obj-y :=
|
|
||||||
include $(SRC_PATH)/Makefile.objs
|
include $(SRC_PATH)/Makefile.objs
|
||||||
dummy := $(call unnest-vars,,target-obj-y)
|
dummy := $(call unnest-vars,,target-obj-y)
|
||||||
target-obj-y-save := $(target-obj-y)
|
target-obj-y-save := $(target-obj-y)
|
||||||
@ -188,8 +187,7 @@ dummy := $(call unnest-vars,.., \
|
|||||||
qom-obj-y \
|
qom-obj-y \
|
||||||
io-obj-y \
|
io-obj-y \
|
||||||
common-obj-y \
|
common-obj-y \
|
||||||
common-obj-m \
|
common-obj-m)
|
||||||
slirp-obj-y)
|
|
||||||
target-obj-y := $(target-obj-y-save)
|
target-obj-y := $(target-obj-y-save)
|
||||||
all-obj-y += $(common-obj-y)
|
all-obj-y += $(common-obj-y)
|
||||||
all-obj-y += $(target-obj-y)
|
all-obj-y += $(target-obj-y)
|
||||||
@ -199,7 +197,6 @@ all-obj-$(CONFIG_SOFTMMU) += $(block-obj-y) $(chardev-obj-y)
|
|||||||
all-obj-$(CONFIG_USER_ONLY) += $(crypto-aes-obj-y)
|
all-obj-$(CONFIG_USER_ONLY) += $(crypto-aes-obj-y)
|
||||||
all-obj-$(CONFIG_SOFTMMU) += $(crypto-obj-y)
|
all-obj-$(CONFIG_SOFTMMU) += $(crypto-obj-y)
|
||||||
all-obj-$(CONFIG_SOFTMMU) += $(io-obj-y)
|
all-obj-$(CONFIG_SOFTMMU) += $(io-obj-y)
|
||||||
all-obj-$(CONFIG_SOFTMMU) += $(slirp-obj-y)
|
|
||||||
|
|
||||||
$(QEMU_PROG_BUILD): config-devices.mak
|
$(QEMU_PROG_BUILD): config-devices.mak
|
||||||
|
|
||||||
|
65
configure
vendored
65
configure
vendored
@ -406,7 +406,7 @@ includedir="\${prefix}/include"
|
|||||||
sysconfdir="\${prefix}/etc"
|
sysconfdir="\${prefix}/etc"
|
||||||
local_statedir="\${prefix}/var"
|
local_statedir="\${prefix}/var"
|
||||||
confsuffix="/qemu"
|
confsuffix="/qemu"
|
||||||
slirp="yes"
|
slirp=""
|
||||||
oss_lib=""
|
oss_lib=""
|
||||||
bsd="no"
|
bsd="no"
|
||||||
linux="no"
|
linux="no"
|
||||||
@ -1105,6 +1105,10 @@ for opt do
|
|||||||
;;
|
;;
|
||||||
--disable-slirp) slirp="no"
|
--disable-slirp) slirp="no"
|
||||||
;;
|
;;
|
||||||
|
--enable-slirp=git) slirp="git"
|
||||||
|
;;
|
||||||
|
--enable-slirp=system) slirp="system"
|
||||||
|
;;
|
||||||
--disable-vde) vde="no"
|
--disable-vde) vde="no"
|
||||||
;;
|
;;
|
||||||
--enable-vde) vde="yes"
|
--enable-vde) vde="yes"
|
||||||
@ -5754,6 +5758,55 @@ if test "$libpmem" != "no"; then
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
##########################################
|
||||||
|
# check for slirp
|
||||||
|
|
||||||
|
case "$slirp" in
|
||||||
|
"" | yes)
|
||||||
|
if $pkg_config slirp; then
|
||||||
|
slirp=system
|
||||||
|
elif test -e "${source_path}/.git" && test $git_update = 'yes' ; then
|
||||||
|
slirp=git
|
||||||
|
elif test -e "${source_path}/slirp/Makefile" ; then
|
||||||
|
slirp=internal
|
||||||
|
elif test -z "$slirp" ; then
|
||||||
|
slirp=no
|
||||||
|
else
|
||||||
|
feature_not_found "slirp" "Install slirp devel or git submodule"
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
|
||||||
|
system)
|
||||||
|
if ! $pkg_config slirp; then
|
||||||
|
feature_not_found "slirp" "Install slirp devel"
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
case "$slirp" in
|
||||||
|
git | internal)
|
||||||
|
if test "$slirp" = git; then
|
||||||
|
git_submodules="${git_submodules} slirp"
|
||||||
|
fi
|
||||||
|
mkdir -p slirp
|
||||||
|
slirp_cflags="-I\$(SRC_PATH)/slirp/src -I\$(BUILD_DIR)/slirp/src"
|
||||||
|
slirp_libs="-L\$(BUILD_DIR)/slirp -lslirp"
|
||||||
|
;;
|
||||||
|
|
||||||
|
system)
|
||||||
|
slirp_version=$($pkg_config --modversion slirp 2>/dev/null)
|
||||||
|
slirp_cflags=$($pkg_config --cflags slirp 2>/dev/null)
|
||||||
|
slirp_libs=$($pkg_config --libs slirp 2>/dev/null)
|
||||||
|
;;
|
||||||
|
|
||||||
|
no)
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
error_exit "Unknown state for slirp: $slirp"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
|
||||||
##########################################
|
##########################################
|
||||||
# End of CC checks
|
# End of CC checks
|
||||||
# After here, no more $cc or $ld runs
|
# After here, no more $cc or $ld runs
|
||||||
@ -6111,7 +6164,8 @@ echo "QEMU_LDFLAGS $QEMU_LDFLAGS"
|
|||||||
echo "make $make"
|
echo "make $make"
|
||||||
echo "install $install"
|
echo "install $install"
|
||||||
echo "python $python ($python_version)"
|
echo "python $python ($python_version)"
|
||||||
if test "$slirp" = "yes" ; then
|
echo "slirp support $slirp $(echo_version $slirp $slirp_version)"
|
||||||
|
if test "$slirp" != "no" ; then
|
||||||
echo "smbd $smbd"
|
echo "smbd $smbd"
|
||||||
fi
|
fi
|
||||||
echo "module support $modules"
|
echo "module support $modules"
|
||||||
@ -6372,9 +6426,14 @@ fi
|
|||||||
if test "$profiler" = "yes" ; then
|
if test "$profiler" = "yes" ; then
|
||||||
echo "CONFIG_PROFILER=y" >> $config_host_mak
|
echo "CONFIG_PROFILER=y" >> $config_host_mak
|
||||||
fi
|
fi
|
||||||
if test "$slirp" = "yes" ; then
|
if test "$slirp" != "no"; then
|
||||||
echo "CONFIG_SLIRP=y" >> $config_host_mak
|
echo "CONFIG_SLIRP=y" >> $config_host_mak
|
||||||
echo "CONFIG_SMBD_COMMAND=\"$smbd\"" >> $config_host_mak
|
echo "CONFIG_SMBD_COMMAND=\"$smbd\"" >> $config_host_mak
|
||||||
|
echo "SLIRP_CFLAGS=$slirp_cflags" >> $config_host_mak
|
||||||
|
echo "SLIRP_LIBS=$slirp_libs" >> $config_host_mak
|
||||||
|
fi
|
||||||
|
if [ "$slirp" = "git" -o "$slirp" = "internal" ]; then
|
||||||
|
echo "config-host.h: subdir-slirp" >> $config_host_mak
|
||||||
fi
|
fi
|
||||||
if test "$vde" = "yes" ; then
|
if test "$vde" = "yes" ; then
|
||||||
echo "CONFIG_VDE=y" >> $config_host_mak
|
echo "CONFIG_VDE=y" >> $config_host_mak
|
||||||
|
@ -8,6 +8,8 @@ common-obj-$(call land,$(CONFIG_VIRTIO_NET),$(CONFIG_VHOST_NET_USER)) += vhost-u
|
|||||||
common-obj-$(call land,$(call lnot,$(CONFIG_VIRTIO_NET)),$(CONFIG_VHOST_NET_USER)) += vhost-user-stub.o
|
common-obj-$(call land,$(call lnot,$(CONFIG_VIRTIO_NET)),$(CONFIG_VHOST_NET_USER)) += vhost-user-stub.o
|
||||||
common-obj-$(CONFIG_ALL) += vhost-user-stub.o
|
common-obj-$(CONFIG_ALL) += vhost-user-stub.o
|
||||||
common-obj-$(CONFIG_SLIRP) += slirp.o
|
common-obj-$(CONFIG_SLIRP) += slirp.o
|
||||||
|
slirp.o-cflags := $(SLIRP_CFLAGS)
|
||||||
|
slirp.o-libs := $(SLIRP_LIBS)
|
||||||
common-obj-$(CONFIG_VDE) += vde.o
|
common-obj-$(CONFIG_VDE) += vde.o
|
||||||
common-obj-$(CONFIG_NETMAP) += netmap.o
|
common-obj-$(CONFIG_NETMAP) += netmap.o
|
||||||
common-obj-y += filter.o
|
common-obj-y += filter.o
|
||||||
|
@ -37,7 +37,7 @@
|
|||||||
#include "monitor/monitor.h"
|
#include "monitor/monitor.h"
|
||||||
#include "qemu/error-report.h"
|
#include "qemu/error-report.h"
|
||||||
#include "qemu/sockets.h"
|
#include "qemu/sockets.h"
|
||||||
#include "slirp/src/libslirp.h"
|
#include <libslirp.h>
|
||||||
#include "chardev/char-fe.h"
|
#include "chardev/char-fe.h"
|
||||||
#include "sysemu/sysemu.h"
|
#include "sysemu/sysemu.h"
|
||||||
#include "qemu/cutils.h"
|
#include "qemu/cutils.h"
|
||||||
|
@ -3,6 +3,7 @@ util-obj-y += bufferiszero.o
|
|||||||
util-obj-y += lockcnt.o
|
util-obj-y += lockcnt.o
|
||||||
util-obj-y += aiocb.o async.o aio-wait.o thread-pool.o qemu-timer.o
|
util-obj-y += aiocb.o async.o aio-wait.o thread-pool.o qemu-timer.o
|
||||||
util-obj-y += main-loop.o iohandler.o
|
util-obj-y += main-loop.o iohandler.o
|
||||||
|
main-loop.o-cflags := $(SLIRP_CFLAGS)
|
||||||
util-obj-$(call lnot,$(CONFIG_ATOMIC64)) += atomic64.o
|
util-obj-$(call lnot,$(CONFIG_ATOMIC64)) += atomic64.o
|
||||||
util-obj-$(CONFIG_POSIX) += aio-posix.o
|
util-obj-$(CONFIG_POSIX) += aio-posix.o
|
||||||
util-obj-$(CONFIG_POSIX) += compatfd.o
|
util-obj-$(CONFIG_POSIX) += compatfd.o
|
||||||
|
Loading…
Reference in New Issue
Block a user