From nobody Mon Feb 9 20:10:04 2026 Delivered-To: importer@patchew.org Received-SPF: pass (zoho.com: domain of gnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Authentication-Results: mx.zohomail.com; dkim=fail; spf=pass (zoho.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=fail(p=none dis=none) header.from=redhat.com ARC-Seal: i=1; a=rsa-sha256; t=1565188583; cv=none; d=zoho.com; s=zohoarc; b=biOiqL00VBkG/HlroIc6gtLkX3TXyVxwwfCFbWWCwNEIcykF0quvtzozI/F50fR9QsdlLRA1Teg/fFkxhxhzWmo7HuNDog8jNlNm7gd3VQyk10HzkN+0VJJKT+mG+1NM6UPJ2Cbgf8QdsQ6tOfXZtg547S97IrqTnjlqqLcIsGE= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zoho.com; s=zohoarc; t=1565188583; h=Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To:ARC-Authentication-Results; bh=L17nmp4EtB/bX6EdCmG6uVDw61DjK5O/rGkvV267caI=; b=ElR3DvGyZP72bheyafQCMYZXG17hcc1AQazWMzymF5mYrIpPaQlzKUWdqXKhYb/ex9fR0pcE95XrTtT4ZyvexyjUzTb68kPVzhU+R2FhIwJaioGJVcsuACj8MdoO0oc1IK6VPf89f10OgLUIYdB66fBcJEcXxe7mDBTFbkI0Dbo= ARC-Authentication-Results: i=1; mx.zoho.com; dkim=fail; spf=pass (zoho.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=fail header.from= (p=none dis=none) header.from= Return-Path: Received: from lists.gnu.org (lists.gnu.org [209.51.188.17]) by mx.zohomail.com with SMTPS id 1565188583014477.7636867013822; Wed, 7 Aug 2019 07:36:23 -0700 (PDT) Received: from localhost ([::1]:41922 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.86_2) (envelope-from ) id 1hvN35-0004wJ-Lk for importer@patchew.org; Wed, 07 Aug 2019 10:36:19 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:41764) by lists.gnu.org with esmtp (Exim 4.86_2) (envelope-from ) id 1hvN2K-0003Yu-Kj for qemu-devel@nongnu.org; Wed, 07 Aug 2019 10:35:34 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1hvN2H-0006bi-Ky for qemu-devel@nongnu.org; Wed, 07 Aug 2019 10:35:32 -0400 Received: from mail-wr1-x441.google.com ([2a00:1450:4864:20::441]:40097) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1hvN2H-0006b8-Cq for qemu-devel@nongnu.org; Wed, 07 Aug 2019 10:35:29 -0400 Received: by mail-wr1-x441.google.com with SMTP id r1so91590333wrl.7 for ; Wed, 07 Aug 2019 07:35:29 -0700 (PDT) Received: from donizetti.lan ([2001:b07:6468:f312:dc26:ed70:9e4c:3810]) by smtp.gmail.com with ESMTPSA id o4sm86004wmh.35.2019.08.07.07.35.26 (version=TLS1_3 cipher=AEAD-AES256-GCM-SHA384 bits=256/256); Wed, 07 Aug 2019 07:35:27 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=sender:from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=L17nmp4EtB/bX6EdCmG6uVDw61DjK5O/rGkvV267caI=; b=batk8qBJkgSx9TpiC/I+ojP7pBL5bjfqkdoQnEkgcHYhPxhAXdvCC24JFHmbiSfOWi BsIGRy3OlfpnXmJEAymCj+GWf9uq+O4W1PbLJe1HwjKsFS6PE9vdYZUpCDxwUIGbyThU cdppr80uRUQx33NZn5h0hmcwK3UTKulELZlxeQUnWsSj9GoIq4/na3ysQfKW9SxnPwYZ 1jDd0w6QdalvQSOjMja9upMJVz72nEPLTh9MZA0g3WmUeSOGac4VhecxdSw5lvZwBLlx 08i6N5cmRcK0L6PkB83IjC38sKx93De4yKD7SoI7i49GbIZaanWtK57lD3rx+wOtM/fu 4jYg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:from:to:cc:subject:date:message-id :in-reply-to:references:mime-version:content-transfer-encoding; bh=L17nmp4EtB/bX6EdCmG6uVDw61DjK5O/rGkvV267caI=; b=T3o7suqJsuiRTMLwhUiEtG0Q4xADZZxD7U9Rh1BpXlELOlRlHpBTJwisr3RWokOrV9 62ADZi4l5m82+uUeuFzn7obt7GSTGIE7Xw8kC9w0oJ8oWyO2HGi7/xLEFjR3INNCpQ9N 5G/lSpHI57i2014UegjDgo45fYeQSFbgZ+vqnZfe8wsf2LHC3lr9I9svcPOmH8SbHrvX W81PzGgseaNRN/13csGqvJ5DzR51b9aIqJ6GEuNMZmyTZEk181sXl3xneg+wkUCGKCkv 15NbEm3aTmXEm7JgynJtoiwRWsfo94Qp2tgBcIuYD2mLqpb6gWY629xylgWIopbnDa26 XYNg== X-Gm-Message-State: APjAAAVfZBJ7DdgpUh/6rY+MZR+ie5J8J8A9UoOVO5HTcD+QPIy4YFWH Y8Dbyhbcg0RTHKkorXUN3aSdCyHn X-Google-Smtp-Source: APXvYqyJYKei4bqZtO6DKUjs6sEqHRdDF21Fs0qQSa1jLrjOAq57v7IziBh6dop4fxAqY60rcmWsJA== X-Received: by 2002:a5d:438e:: with SMTP id i14mr11283698wrq.122.1565188527954; Wed, 07 Aug 2019 07:35:27 -0700 (PDT) From: Paolo Bonzini To: qemu-devel@nongnu.org Date: Wed, 7 Aug 2019 16:35:22 +0200 Message-Id: <20190807143523.15917-3-pbonzini@redhat.com> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190807143523.15917-1-pbonzini@redhat.com> References: <20190807143523.15917-1-pbonzini@redhat.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-detected-operating-system: by eggs.gnu.org: Genre and OS details not recognized. X-Received-From: 2a00:1450:4864:20::441 Subject: [Qemu-devel] [PATCH v2 2/3] tests/tcg: cleanup Makefile inclusions X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: alex.bennee@linaro.org Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" X-ZohoMail-DKIM: fail (Header signature does not verify) Content-Type: text/plain; charset="utf-8" Rename Makefile.probe to Makefile.prereqs and make it actually define rules for the tests. Rename Makefile to Makefile.target, since it is not a toplevel makefile. Rename Makefile.include to Makefile.qemu and disentangle it from the QEMU Makefile.target, so that it is invoked recursively by tests/Makefile.include. Tests are now placed in tests/tcg/$(TARGET). Drop the usage of TARGET_BASE_ARCH, which is ignored by everything except x86_64 and aarch64. Fix x86 tests by using -cpu max and, while at it, standardize on QEMU_OPTS for aarch64 tests too. Signed-off-by: Paolo Bonzini --- Makefile.target | 3 -- tests/Makefile.include | 23 +++++---- .../tcg/{Makefile.probe =3D> Makefile.prereqs} | 5 +- tests/tcg/{Makefile.include =3D> Makefile.qemu} | 48 +++++++++++-------- tests/tcg/{Makefile =3D> Makefile.target} | 13 ++--- tests/tcg/aarch64/Makefile.target | 12 +++-- tests/tcg/arm/Makefile.softmmu-target | 4 -- tests/tcg/i386/Makefile.softmmu-target | 8 ---- tests/tcg/i386/Makefile.target | 13 ++--- tests/tcg/x86_64/Makefile.softmmu-target | 36 ++++++++++++++ tests/tcg/x86_64/Makefile.target | 7 +-- 11 files changed, 100 insertions(+), 72 deletions(-) rename tests/tcg/{Makefile.probe =3D> Makefile.prereqs} (92%) rename tests/tcg/{Makefile.include =3D> Makefile.qemu} (52%) rename tests/tcg/{Makefile =3D> Makefile.target} (92%) create mode 100644 tests/tcg/x86_64/Makefile.softmmu-target diff --git a/Makefile.target b/Makefile.target index 933b27453a..5e916230c4 100644 --- a/Makefile.target +++ b/Makefile.target @@ -39,9 +39,6 @@ endif PROGS=3D$(QEMU_PROG) $(QEMU_PROGW) STPFILES=3D =20 -# Makefile Tests -include $(SRC_PATH)/tests/tcg/Makefile.include - config-target.h: config-target.h-timestamp config-target.h-timestamp: config-target.mak =20 diff --git a/tests/Makefile.include b/tests/Makefile.include index fd7fdb8658..8bb5c97b7a 100644 --- a/tests/Makefile.include +++ b/tests/Makefile.include @@ -1061,23 +1061,28 @@ RUN_TCG_TARGET_RULES=3D$(patsubst %,run-tcg-tests-%= , $(TARGET_DIRS)) ifeq ($(HAVE_USER_DOCKER),y) # Probe for the Docker Builds needed for each build $(foreach PROBE_TARGET,$(TARGET_DIRS), \ - $(eval -include $(SRC_PATH)/tests/tcg/Makefile.probe) \ - $(if $(DOCKER_PREREQ), \ - $(eval build-tcg-tests-$(PROBE_TARGET): $(DOCKER_PREREQ)))) + $(eval -include $(SRC_PATH)/tests/tcg/Makefile.prereqs)) endif =20 build-tcg-tests-%: - $(call quiet-command,$(MAKE) $(SUBDIR_MAKEFLAGS) -C $* V=3D"$(V)" \ - SKIP_DOCKER_BUILD=3D1 TARGET_DIR=3D"$*/" guest-tests, \ + $(call quiet-command,$(MAKE) $(SUBDIR_MAKEFLAGS) \ + -f $(SRC_PATH)/tests/tcg/Makefile.qemu \ + SRC_PATH=3D$(SRC_PATH) \ + V=3D"$(V)" TARGET_DIR=3D"$*/" guest-tests, \ "BUILD", "TCG tests for $*") =20 -run-tcg-tests-%: % build-tcg-tests-% - $(call quiet-command,$(MAKE) $(SUBDIR_MAKEFLAGS) -C $* V=3D"$(V)" \ - SKIP_DOCKER_BUILD=3D1 TARGET_DIR=3D"$*/" run-guest-tests, \ +run-tcg-tests-%: build-tcg-tests-% %/all + $(call quiet-command,$(MAKE) $(SUBDIR_MAKEFLAGS) \ + -f $(SRC_PATH)/tests/tcg/Makefile.qemu \ + SRC_PATH=3D$(SRC_PATH) SPEED=3D"$(SPEED)" \ + V=3D"$(V)" TARGET_DIR=3D"$*/" run-guest-tests, \ "RUN", "TCG tests for $*") =20 clean-tcg-tests-%: - $(call quiet-command,$(MAKE) $(SUBDIR_MAKEFLAGS) -C $* V=3D"$(V)" TARGET_= DIR=3D"$*/" clean-guest-tests,) + $(call quiet-command,$(MAKE) $(SUBDIR_MAKEFLAGS) \ + -f $(SRC_PATH)/tests/tcg/Makefile.qemu \ + SRC_PATH=3D$(SRC_PATH) TARGET_DIR=3D"$*/" clean-guest-tests, \ + "RUN", "TCG tests for $*") =20 .PHONY: build-tcg build-tcg: $(BUILD_TCG_TARGET_RULES) diff --git a/tests/tcg/Makefile.probe b/tests/tcg/Makefile.prereqs similarity index 92% rename from tests/tcg/Makefile.probe rename to tests/tcg/Makefile.prereqs index 9dc654663d..53b01962e1 100644 --- a/tests/tcg/Makefile.probe +++ b/tests/tcg/Makefile.prereqs @@ -8,20 +8,19 @@ # each target. =20 # First we need the target makefile which tells us the target architecture +CROSS_CC_GUEST:=3D -include $(BUILD_DIR)/$(PROBE_TARGET)/config-target.mak =20 # Then we load up the target architecture makefiles which tell us # about the compilers -CROSS_CC_GUEST:=3D DOCKER_IMAGE:=3D -DOCKER_PREREQ:=3D =20 -include $(SRC_PATH)/tests/tcg/$(TARGET_BASE_ARCH)/Makefile.include -include $(SRC_PATH)/tests/tcg/$(TARGET_NAME)/Makefile.include =20 ifndef CROSS_CC_GUEST ifneq ($(DOCKER_IMAGE),) -DOCKER_PREREQ:=3Ddocker-image-$(DOCKER_IMAGE) +build-tcg-tests-$(PROBE_TARGET): docker-image-$(DOCKER_IMAGE) endif endif =20 diff --git a/tests/tcg/Makefile.include b/tests/tcg/Makefile.qemu similarity index 52% rename from tests/tcg/Makefile.include rename to tests/tcg/Makefile.qemu index 73b5626fc5..d3f34372de 100644 --- a/tests/tcg/Makefile.include +++ b/tests/tcg/Makefile.qemu @@ -2,20 +2,23 @@ # # TCG tests (per-target rules) # -# This Makefile fragment is included from the per-target -# Makefile.target so will be invoked for each linux-user program we -# build. We have two options for compiling, either using a configured -# guest compiler or calling one of our docker images to do it for us. +# This Makefile fragment is included from the build-tcg target, once +# for each target we build. We have two options for compiling, either +# using a configured guest compiler or calling one of our docker images +# to do it for us. # =20 # The per ARCH makefile, if it exists, holds extra information about # useful docker images or alternative compiler flags. =20 --include $(SRC_PATH)/tests/tcg/$(TARGET_BASE_ARCH)/Makefile.include --include $(SRC_PATH)/tests/tcg/$(TARGET_NAME)/Makefile.include +include $(TARGET_DIR)config-target.mak +include $(SRC_PATH)/rules.mak +include $(wildcard \ + $(SRC_PATH)/tests/tcg/$(TARGET_BASE_ARCH)/Makefile.include \ + $(SRC_PATH)/tests/tcg/$(TARGET_NAME)/Makefile.include) =20 GUEST_BUILD=3D -TCG_MAKE=3D$(SRC_PATH)/tests/tcg/Makefile +TCG_MAKE=3D../Makefile.target # Support installed Cross Compilers =20 ifdef CROSS_CC_GUEST @@ -23,9 +26,9 @@ ifdef CROSS_CC_GUEST .PHONY: cross-build-guest-tests cross-build-guest-tests: $(call quiet-command, \ - (mkdir -p tests && cd tests && \ - $(MAKE) -f $(TCG_MAKE) CC=3D$(CROSS_CC_GUEST) \ - BUILD_STATIC=3D$(CROSS_CC_GUEST_STATIC) \ + (mkdir -p tests/tcg/$(TARGET_DIR) && cd tests/tcg/$(TARGET_DIR) && \ + $(MAKE) -f $(TCG_MAKE) TARGET_DIR=3D"$(TARGET_DIR)" CC=3D"$(CROSS_CC_= GUEST)" \ + SRC_PATH=3D"$(SRC_PATH)" BUILD_STATIC=3D$(CROSS_CC_GUEST_STATIC) \ EXTRA_CFLAGS=3D$(CROSS_CC_GUEST_CFLAGS)), \ "BUILD","$(TARGET_NAME) guest-tests with $(CROSS_CC_GUEST)") =20 @@ -39,20 +42,20 @@ ifeq ($(HAVE_USER_DOCKER)$(GUEST_BUILD),y) ifneq ($(DOCKER_IMAGE),) =20 # We also need the Docker make rules to depend on +SKIP_DOCKER_BUILD=3D1 include $(SRC_PATH)/tests/docker/Makefile.include =20 DOCKER_COMPILE_CMD=3D"$(DOCKER_SCRIPT) cc --user $(shell id -u) \ --cc $(DOCKER_CROSS_COMPILER) \ -i qemu:$(DOCKER_IMAGE) \ -s $(SRC_PATH) -- " -DOCKER_PREREQ=3Ddocker-image-$(DOCKER_IMAGE) =20 .PHONY: docker-build-guest-tests -docker-build-guest-tests: $(DOCKER_PREREQ) +docker-build-guest-tests: docker-image-$(DOCKER_IMAGE) $(call quiet-command, \ - (mkdir -p tests && cd tests && \ - $(MAKE) -f $(TCG_MAKE) CC=3D$(DOCKER_COMPILE_CMD) \ - BUILD_STATIC=3Dy \ + (mkdir -p tests/tcg/$(TARGET_DIR) && cd tests/tcg/$(TARGET_DIR) && \ + $(MAKE) -f $(TCG_MAKE) TARGET_DIR=3D"$(TARGET_DIR)" CC=3D$(DOCKER_COMP= ILE_CMD) \ + SRC_PATH=3D"$(SRC_PATH)" BUILD_STATIC=3Dy \ EXTRA_CFLAGS=3D$(DOCKER_CROSS_COMPILER_CFLAGS)), \ "BUILD","$(TARGET_NAME) guest-tests with docker qemu:$(DOCKER_IMAGE)") =20 @@ -62,27 +65,32 @@ endif endif =20 # Final targets +all: + @echo "Do not invoke this Makefile directly"; exit 1 + .PHONY: guest-tests =20 ifneq ($(GUEST_BUILD),) guest-tests: $(GUEST_BUILD) =20 -run-guest-tests: guest-tests qemu-$(subst y,system-,$(CONFIG_SOFTMMU))$(TA= RGET_NAME) +run-guest-tests: guest-tests $(call quiet-command, \ - (cd tests && $(MAKE) -f $(TCG_MAKE) SPEED=3D$(SPEED) run), \ + (cd tests/tcg/$(TARGET_DIR) && \ + $(MAKE) -f $(TCG_MAKE) TARGET_DIR=3D"$(TARGET_DIR)" \ + SRC_PATH=3D"$(SRC_PATH)" SPEED=3D$(SPEED) run), \ "RUN", "tests for $(TARGET_NAME)") =20 else guest-tests: $(call quiet-command, /bin/true, "BUILD", \ - "$(TARGET_NAME) guest-tests SKIPPED") + "$(TARGET_DIR) guest-tests SKIPPED") =20 run-guest-tests: $(call quiet-command, /bin/true, "RUN", \ - "tests for $(TARGET_NAME) SKIPPED") + "tests for $(TARGET_DIR) SKIPPED") endif =20 # It doesn't matter if these don't exits .PHONY: clean-guest-tests clean-guest-tests: - rm -rf tests || echo "no $(TARGET_NAME) tests to remove" + rm -rf tests/tcg/$(TARGET_DIR) diff --git a/tests/tcg/Makefile b/tests/tcg/Makefile.target similarity index 92% rename from tests/tcg/Makefile rename to tests/tcg/Makefile.target index 9f56768624..8dbcba4474 100644 --- a/tests/tcg/Makefile +++ b/tests/tcg/Makefile.target @@ -29,8 +29,9 @@ # We also expect to be in the tests build dir for the FOO-(linux-user|soft= mmu). # =20 +all: -include ../../config-host.mak --include ../config-target.mak +-include ../../../$(TARGET_DIR)/config-target.mak =20 # for including , in command strings COMMA :=3D , @@ -64,9 +65,9 @@ LDFLAGS=3D =20 # The QEMU for this TARGET ifdef CONFIG_USER_ONLY -QEMU=3D../qemu-$(TARGET_NAME) +QEMU=3D../../../$(TARGET_DIR)/qemu-$(TARGET_NAME) else -QEMU=3D../qemu-system-$(TARGET_NAME) +QEMU=3D../../../$(TARGET_DIR)/qemu-system-$(TARGET_NAME) endif QEMU_OPTS=3D =20 @@ -82,10 +83,7 @@ ifdef CONFIG_USER_ONLY # The order we include is important. We include multiarch, base arch # and finally arch if it's not the same as base arch. -include $(SRC_PATH)/tests/tcg/multiarch/Makefile.target --include $(SRC_PATH)/tests/tcg/$(TARGET_BASE_ARCH)/Makefile.target -ifneq ($(TARGET_BASE_ARCH),$(TARGET_NAME)) -include $(SRC_PATH)/tests/tcg/$(TARGET_NAME)/Makefile.target -endif =20 # Add the common build options CFLAGS+=3D-Wall -O0 -g -fno-strict-aliasing @@ -101,10 +99,7 @@ else # are expected to provide their own build recipes. -include $(SRC_PATH)/tests/tcg/minilib/Makefile.target -include $(SRC_PATH)/tests/tcg/multiarch/system/Makefile.softmmu-target --include $(SRC_PATH)/tests/tcg/$(TARGET_BASE_ARCH)/Makefile.softmmu-target -ifneq ($(TARGET_BASE_ARCH),$(TARGET_NAME)) -include $(SRC_PATH)/tests/tcg/$(TARGET_NAME)/Makefile.softmmu-target -endif =20 endif =20 diff --git a/tests/tcg/aarch64/Makefile.target b/tests/tcg/aarch64/Makefile= .target index 31ba9cfcaa..e763dd9da3 100644 --- a/tests/tcg/aarch64/Makefile.target +++ b/tests/tcg/aarch64/Makefile.target @@ -2,12 +2,14 @@ # # AArch64 specific tweaks =20 +ARM_SRC=3D$(SRC_PATH)/tests/tcg/arm +VPATH +=3D $(ARM_SRC) + AARCH64_SRC=3D$(SRC_PATH)/tests/tcg/aarch64 VPATH +=3D $(AARCH64_SRC) =20 -# we don't build any of the ARM tests -AARCH64_TESTS=3D$(filter-out $(ARM_TESTS), $(TESTS)) -AARCH64_TESTS+=3Dfcvt +# we don't build any other ARM test +AARCH64_TESTS=3Dfcvt =20 fcvt: LDFLAGS+=3D-lm =20 @@ -16,6 +18,6 @@ run-fcvt: fcvt $(call diff-out,$<,$(AARCH64_SRC)/fcvt.ref) =20 AARCH64_TESTS +=3D pauth-1 pauth-2 -run-pauth-%: QEMU +=3D -cpu max +run-pauth-%: QEMU_OPTS +=3D -cpu max =20 -TESTS:=3D$(AARCH64_TESTS) +TESTS +=3D $(AARCH64_TESTS) diff --git a/tests/tcg/arm/Makefile.softmmu-target b/tests/tcg/arm/Makefile= .softmmu-target index 2deb06e6e4..231e9a57b4 100644 --- a/tests/tcg/arm/Makefile.softmmu-target +++ b/tests/tcg/arm/Makefile.softmmu-target @@ -3,8 +3,6 @@ # ARM SoftMMU tests - included from tests/tcg/Makefile # =20 -ifeq ($(TARGET_ABI_DIR),arm) - ARM_SRC=3D$(SRC_PATH)/tests/tcg/arm =20 # Set search path for all sources @@ -25,5 +23,3 @@ LDFLAGS+=3D-nostdlib -N -static test-armv6m-undef: EXTRA_CFLAGS+=3D-mcpu=3Dcortex-m0 =20 run-test-armv6m-undef: QEMU_OPTS+=3D-semihosting -M microbit -kernel - -endif diff --git a/tests/tcg/i386/Makefile.softmmu-target b/tests/tcg/i386/Makefi= le.softmmu-target index cee342017e..1c8790eecd 100644 --- a/tests/tcg/i386/Makefile.softmmu-target +++ b/tests/tcg/i386/Makefile.softmmu-target @@ -12,17 +12,9 @@ X64_SYSTEM_SRC=3D$(SRC_PATH)/tests/tcg/x86_64/system # These objects provide the basic boot code and helper functions for all t= ests CRT_OBJS=3Dboot.o =20 -ifeq ($(TARGET_X86_64), y) -CRT_PATH=3D$(X64_SYSTEM_SRC) -CFLAGS=3D-march=3Dx86-64 -LINK_SCRIPT=3D$(X64_SYSTEM_SRC)/kernel.ld -LDFLAGS=3D-Wl,-T$(LINK_SCRIPT) -Wl,-melf_x86_64 -else CRT_PATH=3D$(I386_SYSTEM_SRC) -CFLAGS+=3D-m32 LINK_SCRIPT=3D$(I386_SYSTEM_SRC)/kernel.ld LDFLAGS=3D-Wl,-T$(LINK_SCRIPT) -Wl,-melf_i386 -endif CFLAGS+=3D-nostdlib -ggdb -O0 $(MINILIB_INC) LDFLAGS+=3D-static -nostdlib $(CRT_OBJS) $(MINILIB_OBJS) -lgcc =20 diff --git a/tests/tcg/i386/Makefile.target b/tests/tcg/i386/Makefile.target index d0eb7023e5..08c5736a4d 100644 --- a/tests/tcg/i386/Makefile.target +++ b/tests/tcg/i386/Makefile.target @@ -6,14 +6,11 @@ I386_SRC=3D$(SRC_PATH)/tests/tcg/i386 VPATH +=3D $(I386_SRC) =20 I386_SRCS=3D$(notdir $(wildcard $(I386_SRC)/*.c)) -I386_TESTS=3D$(I386_SRCS:.c=3D) -I386_ONLY_TESTS=3D$(filter-out test-i386-ssse3, $(I386_TESTS)) +ALL_X86_TESTS=3D$(I386_SRCS:.c=3D) +I386_TESTS:=3D$(filter-out test-i386-ssse3, $(ALL_X86_TESTS)) +X86_64_TESTS:=3D$(filter test-i386-ssse3, $(ALL_X86_TESTS)) # Update TESTS -TESTS+=3D$(I386_ONLY_TESTS) - -ifneq ($(TARGET_NAME),x86_64) -CFLAGS+=3D-m32 -endif +TESTS=3D$(MULTIARCH_TESTS) $(I386_TESTS) =20 # # hello-i386 is a barebones app @@ -26,7 +23,7 @@ hello-i386: LDFLAGS+=3D-nostdlib # =20 test-i386: test-i386.c test-i386-code16.S test-i386-vm86.S test-i386.h tes= t-i386-shift.h test-i386-muldiv.h - $(CC) $(CFLAGS) $(LDFLAGS) -o $@ \ + $(CC) $(CFLAGS) $(LDFLAGS) $(EXTRA_CFLAGS) -o $@ \ $(