From nobody Fri May 3 11:34:29 2024 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=1564490347; cv=none; d=zoho.com; s=zohoarc; b=ALxdVilyS290cFh46aU97d/Q0nIDQpT3Zu2CuvtDoHq6jR5duiJnGPnhiOOukWER2ntXuXlcnx0XKgyyixypI7jxy2wBh6pGYQoIpLNcYGLuC+99WyDMhVewc9q5G/Fr0f25USITBjInAE/UNj4YMvO+XsK6b36k12GglvbWHnw= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zoho.com; s=zohoarc; t=1564490347; 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=+0lmLbpK31lpr1scwil4wDPUGBPfI3X3nakGAquegRQ=; b=IutrALkRYl26nRTjeQVDxqDDSxXmAMm5A2zCXRFDzm7bXc6BvAqm54PpMmuJV7wbN9xwnRTsgoWV8H49jaRzC7b45kbDswEth98o5mc2pOz+YlxX/yQrNebtxJocQcD1lbx/OCmCwA9zGOwPO4klJGfXkfuyZM1QYHIRem1s9pI= 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 1564490347023372.2592087065452; Tue, 30 Jul 2019 05:39:07 -0700 (PDT) Received: from localhost ([::1]:60664 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.86_2) (envelope-from ) id 1hsRPG-0006G7-2Y for importer@patchew.org; Tue, 30 Jul 2019 08:39:06 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:37246) by lists.gnu.org with esmtp (Exim 4.86_2) (envelope-from ) id 1hsROH-0004uH-Nj for qemu-devel@nongnu.org; Tue, 30 Jul 2019 08:38:06 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1hsROG-0006fx-Af for qemu-devel@nongnu.org; Tue, 30 Jul 2019 08:38:05 -0400 Received: from mail-wr1-x434.google.com ([2a00:1450:4864:20::434]:42554) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1hsROG-0006fF-4P for qemu-devel@nongnu.org; Tue, 30 Jul 2019 08:38:04 -0400 Received: by mail-wr1-x434.google.com with SMTP id x1so15695257wrr.9 for ; Tue, 30 Jul 2019 05:38:03 -0700 (PDT) Received: from donizetti.redhat.com ([2001:b07:6468:f312:29d3:6123:6d5f:2c04]) by smtp.gmail.com with ESMTPSA id j6sm90847995wrx.46.2019.07.30.05.38.01 (version=TLS1_3 cipher=AEAD-AES256-GCM-SHA384 bits=256/256); Tue, 30 Jul 2019 05:38:02 -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=+0lmLbpK31lpr1scwil4wDPUGBPfI3X3nakGAquegRQ=; b=KxbC8y+WdU2D5v13TlP4vcC2TQyjL9YI2v06Xv2jfVy0IYwRaIo2x1NltJCnwtIW+5 F6yqlK0DYYrFeHzd/cYR5n2VKe24Ep4oqcX+2jn8ynl8bG5cTgCQbYVepaO4v7lCgN+o 77s69afHsBhKU8QMwp6talYyAX6PY9DJpKsVTPcYcimJmk7Jr6QP5F569vQTwHIXw5rS QxR7mX3H+uZ8iU3Wh7gUsV/4O87I9qYlZpWLBHkaJ7nJBG+FGkGWS3gela4fqLUXjK6q RlfbxbhVYKo4h4ySvIcruM+pDoBWDZfkQ1xn0jTJby3RG6JL2d7ZEq+y3xGT4y7jk0IQ i8dg== 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=+0lmLbpK31lpr1scwil4wDPUGBPfI3X3nakGAquegRQ=; b=TbosmHY49cY70TNcEnQvA+BZsqUFrWO7G2p1JJPdwPkeUM/Z4+WI0bfGacTVba4ZDs K0vioR5DauOwXlFm9w17DHaM8VfzLnNGN1juFG/Ghily+YJCzoVi/71ZJwqg580+Ej5W w4zdfP9jYlOA4grFvVTnED9TSeE+QQVcUdHNH17l02qP4Yx9OgZmTHe4FZu1rbd0RfrJ d8jjCHgPLdQ0mBrHnmO40O752PYtEEE9zT0VXA8cQfYCF47uDjIvYnSEeWc9vh6v3V5+ D1sfaTf7fby8NuoctlTrT9lwh3dj3wsRZNCIlzgNRVr2IfUbPGluLtqb70/5Wv6Qlx5+ +yKw== X-Gm-Message-State: APjAAAU8d+HIotv48YzWHHPUUbkDD49iuDNWrtLF2z0YWX9oaEwz9g9c 2NPvJloXGpC2OOvcHz8AXdGsEhrT/5c= X-Google-Smtp-Source: APXvYqxdw9pZ5Imy0Z/aYrgGPRscndouqFLf+vRj7EPtVl/+DjBEIGXmTb5fT1MgfMGqVUddPGQy6Q== X-Received: by 2002:a05:6000:1186:: with SMTP id g6mr9869775wrx.17.1564490282649; Tue, 30 Jul 2019 05:38:02 -0700 (PDT) From: Paolo Bonzini To: qemu-devel@nongnu.org Date: Tue, 30 Jul 2019 14:37:57 +0200 Message-Id: <20190730123759.21723-2-pbonzini@redhat.com> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190730123759.21723-1-pbonzini@redhat.com> References: <20190730123759.21723-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::434 Subject: [Qemu-devel] [PATCH 1/3] tests/tcg: use EXTRA_CFLAGS everywhere 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" For i386 specifically, this allows using the host GCC to compile the i386 tests. But, it should really be done for all targets, unless we want to pass $(EXTRA_CFLAGS) directly as part of $(CC). Signed-off-by: Paolo Bonzini --- tests/tcg/aarch64/Makefile.softmmu-target | 4 ++-- tests/tcg/alpha/Makefile.softmmu-target | 4 ++-- tests/tcg/arm/Makefile.softmmu-target | 2 +- tests/tcg/i386/Makefile.softmmu-target | 4 ++-- tests/tcg/minilib/Makefile.target | 2 +- tests/tcg/xtensa/Makefile.softmmu-target | 4 ++-- 6 files changed, 10 insertions(+), 10 deletions(-) diff --git a/tests/tcg/aarch64/Makefile.softmmu-target b/tests/tcg/aarch64/= Makefile.softmmu-target index 2e560e4..4c4aaf6 100644 --- a/tests/tcg/aarch64/Makefile.softmmu-target +++ b/tests/tcg/aarch64/Makefile.softmmu-target @@ -22,11 +22,11 @@ LDFLAGS+=3D-static -nostdlib $(CRT_OBJS) $(MINILIB_OBJS= ) -lgcc .PRECIOUS: $(CRT_OBJS) =20 %.o: $(CRT_PATH)/%.S - $(CC) $(CFLAGS) -x assembler-with-cpp -c $< -o $@ + $(CC) $(CFLAGS) $(EXTRA_CFLAGS) -x assembler-with-cpp -c $< -o $@ =20 # Build and link the tests %: %.c $(LINK_SCRIPT) $(CRT_OBJS) $(MINILIB_OBJS) - $(CC) $(CFLAGS) $< -o $@ $(LDFLAGS) + $(CC) $(CFLAGS) $(EXTRA_CFLAGS) $< -o $@ $(LDFLAGS) =20 memory: CFLAGS+=3D-DCHECK_UNALIGNED=3D1 =20 diff --git a/tests/tcg/alpha/Makefile.softmmu-target b/tests/tcg/alpha/Make= file.softmmu-target index 3c0f34c..09193a6 100644 --- a/tests/tcg/alpha/Makefile.softmmu-target +++ b/tests/tcg/alpha/Makefile.softmmu-target @@ -22,11 +22,11 @@ LDFLAGS+=3D-static -nostdlib $(CRT_OBJS) $(MINILIB_OBJS= ) -lgcc .PRECIOUS: $(CRT_OBJS) =20 %.o: $(CRT_PATH)/%.S - $(CC) $(CFLAGS) -x assembler-with-cpp -c $< -o $@ + $(CC) $(CFLAGS) $(EXTRA_CFLAGS) -x assembler-with-cpp -c $< -o $@ =20 # Build and link the tests %: %.c $(LINK_SCRIPT) $(CRT_OBJS) $(MINILIB_OBJS) - $(CC) $(CFLAGS) $< -o $@ $(LDFLAGS) + $(CC) $(CFLAGS) $(EXTRA_CFLAGS) $< -o $@ $(LDFLAGS) =20 memory: CFLAGS+=3D-DCHECK_UNALIGNED=3D0 =20 diff --git a/tests/tcg/arm/Makefile.softmmu-target b/tests/tcg/arm/Makefile= .softmmu-target index 49d48d8..2deb06e 100644 --- a/tests/tcg/arm/Makefile.softmmu-target +++ b/tests/tcg/arm/Makefile.softmmu-target @@ -18,7 +18,7 @@ CFLAGS+=3D-Wl,--build-id=3Dnone -x assembler-with-cpp LDFLAGS+=3D-nostdlib -N -static =20 %: %.S %.ld - $(CC) $(CFLAGS) $(ASFLAGS) $< -o $@ $(LDFLAGS) -T $(ARM_SRC)/$@.ld + $(CC) $(CFLAGS) $(ASFLAGS) $(EXTRA_CFLAGS) $< -o $@ $(LDFLAGS) -T $(ARM_S= RC)/$@.ld =20 # Specific Test Rules =20 diff --git a/tests/tcg/i386/Makefile.softmmu-target b/tests/tcg/i386/Makefi= le.softmmu-target index 0a43648..cee3420 100644 --- a/tests/tcg/i386/Makefile.softmmu-target +++ b/tests/tcg/i386/Makefile.softmmu-target @@ -32,11 +32,11 @@ TESTS+=3D$(MULTIARCH_TESTS) .PRECIOUS: $(CRT_OBJS) =20 %.o: $(CRT_PATH)/%.S - $(CC) $(CFLAGS) -c $< -o $@ + $(CC) $(CFLAGS) $(EXTRA_CFLAGS) -c $< -o $@ =20 # Build and link the tests %: %.c $(LINK_SCRIPT) $(CRT_OBJS) $(MINILIB_OBJS) - $(CC) $(CFLAGS) $< -o $@ $(LDFLAGS) + $(CC) $(CFLAGS) $(EXTRA_CFLAGS) $< -o $@ $(LDFLAGS) =20 memory: CFLAGS+=3D-DCHECK_UNALIGNED=3D1 =20 diff --git a/tests/tcg/minilib/Makefile.target b/tests/tcg/minilib/Makefile= .target index 3ed8077..c821d28 100644 --- a/tests/tcg/minilib/Makefile.target +++ b/tests/tcg/minilib/Makefile.target @@ -18,4 +18,4 @@ MINILIB_INC=3D-isystem $(SYSTEM_MINILIB_SRC) .PRECIOUS: $(MINILIB_OBJS) =20 %.o: $(SYSTEM_MINILIB_SRC)/%.c - $(CC) $(CFLAGS) -c $< -o $@ + $(CC) $(CFLAGS) $(EXTRA_CFLAGS) -c $< -o $@ diff --git a/tests/tcg/xtensa/Makefile.softmmu-target b/tests/tcg/xtensa/Ma= kefile.softmmu-target index 8212d96..9530cac 100644 --- a/tests/tcg/xtensa/Makefile.softmmu-target +++ b/tests/tcg/xtensa/Makefile.softmmu-target @@ -34,9 +34,9 @@ $(XTENSA_USABLE_TESTS): linker.ld macros.inc $(CRT) Makef= ile.softmmu-target =20 # special rule for common blobs %.o: %.S - $(CC) $(XTENSA_INC) $($*_ASFLAGS) $(ASFLAGS) -c $< -o $@ + $(CC) $(XTENSA_INC) $($*_ASFLAGS) $(ASFLAGS) $(EXTRA_CFLAGS) -c $< -o $@ =20 %: %.S - $(CC) $(XTENSA_INC) $(ASFLAGS) $< -o $@ $(LDFLAGS) $(NOSTDFLAGS) $(CRT) + $(CC) $(XTENSA_INC) $(ASFLAGS) $(EXTRA_CFLAGS) $< -o $@ $(LDFLAGS) $(NOST= DFLAGS) $(CRT) =20 endif --=20 1.8.3.1 From nobody Fri May 3 11:34:29 2024 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=1564490351; cv=none; d=zoho.com; s=zohoarc; b=Cj6ap76nkTvtXJji/bJo1q8rzD9vlQKOPeg6PAoBPi41RFH9Nn+NC2RXnV/1MLo0Z4dNVibK28+BVLzcK6vQUqG8qoMH9nKbXnuRgu5dS7ItX25Kh7g5DrMjNugmsybbs2fyt4GVJVeZ+0PcVuMgrqeSA76azr5mFOqv+1eQSE0= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zoho.com; s=zohoarc; t=1564490351; 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=2x0tHqG+AkM9kjKf6n79T6Y/ORQjn6Hjc+1auCdGDh4=; b=RxyUzUrPbkaE++zt9GEmGfU3CmzxQ1U7zScA34ixngrLLq7OYKyC8THTJm8MmEI3AQ1T5td7aSxrMiHkA5Ax5fA1wcCrOCi+lzM1wsPNuq4cnzKxMOH5jKZQYgjWut35oYR/qZG/d7LfOhHWQng0UK/EGWSdOsr6RYSLob/vOWo= 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 1564490351238262.8031115327617; Tue, 30 Jul 2019 05:39:11 -0700 (PDT) Received: from localhost ([::1]:60666 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.86_2) (envelope-from ) id 1hsRPK-0006PB-84 for importer@patchew.org; Tue, 30 Jul 2019 08:39:10 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:37265) by lists.gnu.org with esmtp (Exim 4.86_2) (envelope-from ) id 1hsROJ-0004xv-Ky for qemu-devel@nongnu.org; Tue, 30 Jul 2019 08:38:09 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1hsROH-0006gZ-Ge for qemu-devel@nongnu.org; Tue, 30 Jul 2019 08:38:07 -0400 Received: from mail-wr1-x434.google.com ([2a00:1450:4864:20::434]:36504) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1hsROH-0006g2-8R for qemu-devel@nongnu.org; Tue, 30 Jul 2019 08:38:05 -0400 Received: by mail-wr1-x434.google.com with SMTP id n4so65676609wrs.3 for ; Tue, 30 Jul 2019 05:38:04 -0700 (PDT) Received: from donizetti.redhat.com ([2001:b07:6468:f312:29d3:6123:6d5f:2c04]) by smtp.gmail.com with ESMTPSA id j6sm90847995wrx.46.2019.07.30.05.38.02 (version=TLS1_3 cipher=AEAD-AES256-GCM-SHA384 bits=256/256); Tue, 30 Jul 2019 05:38:03 -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=2x0tHqG+AkM9kjKf6n79T6Y/ORQjn6Hjc+1auCdGDh4=; b=SuZvFTFBXRBii4rofL7Y7XsP3WDiSsouUipOzgKv7pQ17/C3BkLmXUXExvQt/41R3a EWro4ZYp9unfqVqyBZScZZ/ys/Fy5ubwhRpBJ/STWNjP9CKdjZFvmzVwUyMpj9+9C41i lD9bDN/Gb2NzbYYZ9Q8LNbtoFx8Tglch/78dEpI5ibJUI5co2jAgwIVBWPQRKLaXZ9c8 qp+t9EsFkgQ/19KaKS4jWuOW0anys/BQyV/jczvPoI5fGi0XUl6kl3FMMgjY4V2ZlVN1 K2+TVGvOQKtpE7hoEcgje1Dnef6sbE3b4B717PNBJjmx/0Q+M+kEe3bz8QS/lppFK3Oe T8pA== 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=2x0tHqG+AkM9kjKf6n79T6Y/ORQjn6Hjc+1auCdGDh4=; b=Gam9VUBAYrxCXhRNCImQl7etLHdRCOUKFy1F02QmDlnsVo5DiM99n4tlTKtQUs6yN8 1oasGJp9iULVEGoz+fwkoUb8nXYajGg5V7bOMPrlQfL0hui2lpYfxZNMmK5a4/24YS2K BWF4ezbvzJTpQuSf28NpZM1pw5UMjr891la+aNsKgglHa7bkaTnwLPJ1IBlTL7x2JPsH xIVFTd1MNhyTa4vUnU2cEofl5dZd29UmKccAqIa0QkfTErAvr2MUVjGLJ653qeqcxWv0 Z0uJtJNBbbpFHVNcI4P3nc9XmO3BsvU+X7v3dnIqxDivy3lvfv615+bPRpWgh48X8MEE tMYw== X-Gm-Message-State: APjAAAWlVYl/BoKBIUuYr50WjPET+SGzb1/yP90v05Tk1bHA/mNY4W86 j1MBj5HjIWmlCoJrVcrNyO+AeYuRQZM= X-Google-Smtp-Source: APXvYqx079IlTELYRupb9wAlS1hCMnxNn5F0dnJYIg7Fjy5C5Muf6Am0Ff2Q4/CgMzX33xe93JhUJQ== X-Received: by 2002:a5d:4a02:: with SMTP id m2mr126054630wrq.78.1564490283661; Tue, 30 Jul 2019 05:38:03 -0700 (PDT) From: Paolo Bonzini To: qemu-devel@nongnu.org Date: Tue, 30 Jul 2019 14:37:58 +0200 Message-Id: <20190730123759.21723-3-pbonzini@redhat.com> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190730123759.21723-1-pbonzini@redhat.com> References: <20190730123759.21723-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::434 Subject: [Qemu-devel] [PATCH 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 +++++++----- tests/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 933b274..5e91623 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 fd7fdb8..8bb5c97 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 9dc6546..53b0196 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 73b5626..d3f3437 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 9f56768..8dbcba4 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 31ba9cf..e763dd9 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 2deb06e..231e9a5 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 cee3420..1c8790e 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 d0eb702..08c5736 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 $@ \ $( (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 1564490425638628.3812407980706; Tue, 30 Jul 2019 05:40:25 -0700 (PDT) Received: from localhost ([::1]:60682 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.86_2) (envelope-from ) id 1hsRQW-0008J5-JK for importer@patchew.org; Tue, 30 Jul 2019 08:40:24 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:37291) by lists.gnu.org with esmtp (Exim 4.86_2) (envelope-from ) id 1hsROM-00052G-FR for qemu-devel@nongnu.org; Tue, 30 Jul 2019 08:38:14 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1hsROI-0006hX-SW for qemu-devel@nongnu.org; Tue, 30 Jul 2019 08:38:10 -0400 Received: from mail-wm1-x342.google.com ([2a00:1450:4864:20::342]:54666) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1hsROI-0006gw-Hr for qemu-devel@nongnu.org; Tue, 30 Jul 2019 08:38:06 -0400 Received: by mail-wm1-x342.google.com with SMTP id p74so56974072wme.4 for ; Tue, 30 Jul 2019 05:38:06 -0700 (PDT) Received: from donizetti.redhat.com ([2001:b07:6468:f312:29d3:6123:6d5f:2c04]) by smtp.gmail.com with ESMTPSA id j6sm90847995wrx.46.2019.07.30.05.38.03 (version=TLS1_3 cipher=AEAD-AES256-GCM-SHA384 bits=256/256); Tue, 30 Jul 2019 05:38:04 -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=vISeher4eST5pQ8x9FfJ2JLtq30j4leNOmnkMaZNfmA=; b=iAVdojKyRwV1qMKw0RA0fWkIHYHjkqjMrGMSZs/X5Ohf9I+F1ppU8UUzWzbGOpl9u7 +jzK15QMIs7E2/50P89x86ESbjMpSq7VcgirNrGQ9qyqNHvbbipYFp9wdfVyPX4PnFlO PlRi6GfljkHLWF3D2Ih/QxtCPpzvKITC/f0Nz16/Zf3JFYLvfYhhMeybBtFxAXSgujRz KlllwV4MzN4to+lfveyghBrsEpMKbFiXYDg0AFmGOR9ZM830+ulKQwsRCNxaINOZCcd7 fiQUMtrYNR44QXq0tut1/eBSLea8nTrSjEreZ5gK91LyWHnMP98/3DQ1+mQ+JlqWDFTX 10nQ== 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=vISeher4eST5pQ8x9FfJ2JLtq30j4leNOmnkMaZNfmA=; b=aJi1Kl94GvHQZnpqyAiKa+qWAZz4YxGtixvdLMMtZd7FhtNkXeYv39i1lciviOM5n4 uRUz+4NzM2R8XhCfke8iVsHsmgn+5I26hALw9jecFwHKgmcb1VGT8h2fH+oGjInSlZ1J 5qDb0MccAMZZjdtpD+/PalEqLxWqweZJefUBxrlSyE1FtRP6TK14X33Lw+02iXsCjvIf nVTu+ES3aQRgGGGWWjPRGiZscNmxqFUuH3OsiLsW9R5h+FuTkAkk505ADP87fA+JdYAv 4339qLE7/Br5wXlDOtkn95PH+rg/2XYxrQqcRI424WostWss/C9+3QRsWQSdhQE3+bNR vkMQ== X-Gm-Message-State: APjAAAUP9YB7lrWGfMIlFgdS01+MwT++DPllhVr5uN83xr3ouhkAr5hd 3aCKMw8OjvyRwKSq4OhQdU+JafbWugA= X-Google-Smtp-Source: APXvYqxDRvAbaDmHxZdhtBYC8V5r8M3ppe91VXS+b5pROaPQpA19OD1rLrzEDGXoR+CXR7UPIqtYIg== X-Received: by 2002:a1c:a848:: with SMTP id r69mr102374216wme.12.1564490284664; Tue, 30 Jul 2019 05:38:04 -0700 (PDT) From: Paolo Bonzini To: qemu-devel@nongnu.org Date: Tue, 30 Jul 2019 14:37:59 +0200 Message-Id: <20190730123759.21723-4-pbonzini@redhat.com> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190730123759.21723-1-pbonzini@redhat.com> References: <20190730123759.21723-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::342 Subject: [Qemu-devel] [PATCH 3/3] tests/tcg: move configuration to a sub-shell script 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" Avoid the repeated inclusions of config-target.mak, which have risks of namespace pollution, and instead build minimal configuration files in a configuration script. The same configuration files can also be included in Makefile and Makefile.qemu Signed-off-by: Paolo Bonzini --- Makefile | 1 + configure | 155 +++---------------------- tests/Makefile.include | 8 +- tests/tcg/Makefile.prereqs | 18 +-- tests/tcg/Makefile.qemu | 51 ++++----- tests/tcg/Makefile.target | 8 +- tests/tcg/aarch64/Makefile.include | 8 -- tests/tcg/alpha/Makefile.include | 2 - tests/tcg/arm/Makefile.include | 8 -- tests/tcg/configure.sh | 228 +++++++++++++++++++++++++++++++++= ++++ tests/tcg/cris/Makefile.include | 6 - tests/tcg/hppa/Makefile.include | 2 - tests/tcg/i386/Makefile.include | 9 -- tests/tcg/m68k/Makefile.include | 2 - tests/tcg/mips/Makefile.include | 20 ---- tests/tcg/ppc/Makefile.include | 10 -- tests/tcg/riscv/Makefile.include | 10 -- tests/tcg/s390x/Makefile.include | 2 - tests/tcg/sh4/Makefile.include | 4 - tests/tcg/sparc64/Makefile.include | 2 - tests/tcg/xtensa/Makefile.include | 11 -- 21 files changed, 276 insertions(+), 289 deletions(-) delete mode 100644 tests/tcg/aarch64/Makefile.include delete mode 100644 tests/tcg/alpha/Makefile.include delete mode 100644 tests/tcg/arm/Makefile.include create mode 100644 tests/tcg/configure.sh delete mode 100644 tests/tcg/cris/Makefile.include delete mode 100644 tests/tcg/hppa/Makefile.include delete mode 100644 tests/tcg/i386/Makefile.include delete mode 100644 tests/tcg/m68k/Makefile.include delete mode 100644 tests/tcg/mips/Makefile.include delete mode 100644 tests/tcg/ppc/Makefile.include delete mode 100644 tests/tcg/riscv/Makefile.include delete mode 100644 tests/tcg/s390x/Makefile.include delete mode 100644 tests/tcg/sh4/Makefile.include delete mode 100644 tests/tcg/sparc64/Makefile.include delete mode 100644 tests/tcg/xtensa/Makefile.include diff --git a/Makefile b/Makefile index ecb788b..e76288a 100644 --- a/Makefile +++ b/Makefile @@ -718,6 +718,7 @@ endef =20 distclean: clean rm -f config-host.mak config-host.h* config-host.ld $(DOCS) qemu-options.= texi qemu-img-cmds.texi qemu-monitor.texi qemu-monitor-info.texi + rm -f tests/tcg/config-*.mak rm -f config-all-devices.mak config-all-disas.mak config.status rm -f $(SUBDIR_DEVICES_MAK) rm -f po/*.mo tests/qemu-iotests/common.env diff --git a/configure b/configure index 714e7fb..b0bd308 100755 --- a/configure +++ b/configure @@ -500,22 +500,6 @@ debug_mutex=3D"no" libpmem=3D"" default_devices=3D"yes" =20 -# cross compilers defaults, can be overridden with --cross-cc-ARCH -cross_cc_aarch64=3D"aarch64-linux-gnu-gcc" -cross_cc_aarch64_be=3D"$cross_cc_aarch64" -cross_cc_cflags_aarch64_be=3D"-mbig-endian" -cross_cc_arm=3D"arm-linux-gnueabihf-gcc" -cross_cc_cflags_armeb=3D"-mbig-endian" -cross_cc_i386=3D"i386-pc-linux-gnu-gcc" -cross_cc_cflags_i386=3D"" -cross_cc_ppc=3D"powerpc-linux-gnu-gcc" -cross_cc_cflags_ppc=3D"-m32" -cross_cc_ppc64=3D"powerpc-linux-gnu-gcc" -cross_cc_cflags_ppc64=3D"-m64" -cross_cc_ppc64le=3D"powerpc64le-linux-gnu-gcc" - -enabled_cross_compilers=3D"" - supported_cpu=3D"no" supported_os=3D"no" bogus_os=3D"no" @@ -548,9 +532,12 @@ for opt do ;; --cross-cc-cflags-*) cc_arch=3D${opt#--cross-cc-flags-}; cc_arch=3D${cc_= arch%%=3D*} eval "cross_cc_cflags_${cc_arch}=3D\$optarg" + cross_cc_vars=3D"$cross_cc_vars cross_cc_cflags_${cc= _arch}" ;; --cross-cc-*) cc_arch=3D${opt#--cross-cc-}; cc_arch=3D${cc_arch%%=3D*} + cc_archs=3D"$cc_archs $cc_arch" eval "cross_cc_${cc_arch}=3D\$optarg" + cross_cc_vars=3D"$cross_cc_vars cross_cc_${cc_arch}" ;; esac done @@ -745,42 +732,34 @@ ARCH=3D case "$cpu" in ppc|ppc64|s390|s390x|sparc64|x32|riscv32|riscv64) supported_cpu=3D"yes" - eval "cross_cc_${cpu}=3D\$host_cc" ;; ppc64le) ARCH=3D"ppc64" supported_cpu=3D"yes" - cross_cc_ppc64le=3D$host_cc ;; i386|i486|i586|i686|i86pc|BePC) cpu=3D"i386" supported_cpu=3D"yes" - cross_cc_i386=3D$host_cc ;; x86_64|amd64) cpu=3D"x86_64" supported_cpu=3D"yes" - cross_cc_x86_64=3D$host_cc ;; armv*b|armv*l|arm) cpu=3D"arm" supported_cpu=3D"yes" - cross_cc_arm=3D$host_cc ;; aarch64) cpu=3D"aarch64" supported_cpu=3D"yes" - cross_cc_aarch64=3D$host_cc ;; mips*) cpu=3D"mips" supported_cpu=3D"yes" - cross_cc_mips=3D$host_cc ;; sparc|sun4[cdmuv]) cpu=3D"sparc" supported_cpu=3D"yes" - cross_cc_sparc=3D$host_cc ;; *) # This will result in either an error or falling back to TCI later @@ -1555,44 +1534,30 @@ case "$cpu" in ppc) CPU_CFLAGS=3D"-m32" LDFLAGS=3D"-m32 $LDFLAGS" - cross_cc_ppc=3D$cc - cross_cc_cflags_ppc=3D"$CPU_CFLAGS" ;; ppc64) CPU_CFLAGS=3D"-m64" LDFLAGS=3D"-m64 $LDFLAGS" - cross_cc_ppc64=3D$cc - cross_cc_cflags_ppc64=3D"$CPU_CFLAGS" ;; sparc) CPU_CFLAGS=3D"-m32 -mv8plus -mcpu=3Dultrasparc" LDFLAGS=3D"-m32 -mv8plus $LDFLAGS" - cross_cc_sparc=3D$cc - cross_cc_cflags_sparc=3D"$CPU_CFLAGS" ;; sparc64) CPU_CFLAGS=3D"-m64 -mcpu=3Dultrasparc" LDFLAGS=3D"-m64 $LDFLAGS" - cross_cc_sparc64=3D$cc - cross_cc_cflags_sparc64=3D"$CPU_CFLAGS" ;; s390) CPU_CFLAGS=3D"-m31" LDFLAGS=3D"-m31 $LDFLAGS" - cross_cc_s390=3D$cc - cross_cc_cflags_s390=3D"$CPU_CFLAGS" ;; s390x) CPU_CFLAGS=3D"-m64" LDFLAGS=3D"-m64 $LDFLAGS" - cross_cc_s390x=3D$cc - cross_cc_cflags_s390x=3D"$CPU_CFLAGS" ;; i386) CPU_CFLAGS=3D"-m32" LDFLAGS=3D"-m32 $LDFLAGS" - cross_cc_i386=3D$cc - cross_cc_cflags_i386=3D"$CPU_CFLAGS" ;; x86_64) # ??? Only extremely old AMD cpus do not have cmpxchg16b. @@ -1600,18 +1565,16 @@ case "$cpu" in # runtime and generate the fallback to serial emulation. CPU_CFLAGS=3D"-m64 -mcx16" LDFLAGS=3D"-m64 $LDFLAGS" - cross_cc_x86_64=3D$cc - cross_cc_cflags_x86_64=3D"$CPU_CFLAGS" ;; x32) CPU_CFLAGS=3D"-mx32" LDFLAGS=3D"-mx32 $LDFLAGS" - cross_cc_i386=3D$cc - cross_cc_cflags_i386=3D"$CPU_CFLAGS" ;; # No special flags required for other host CPUs esac =20 +eval "cross_cc_${cpu}=3D\$host_cc" +cross_cc_vars=3D"$cross_cc_vars cross_cc_${cpu}" QEMU_CFLAGS=3D"$CPU_CFLAGS $QEMU_CFLAGS" =20 # For user-mode emulation the host arch has to be one we explicitly @@ -5894,17 +5857,6 @@ EOF fi =20 ########################################## -# Docker and cross-compiler support -# -# This is specifically for building test -# cases for foreign architectures, not -# cross-compiling QEMU itself. - -if has "docker"; then - docker=3D$($python $source_path/tests/docker/docker.py probe) -fi - -########################################## # check for libpmem =20 if test "$libpmem" !=3D "no"; then @@ -6516,6 +6468,12 @@ if ! $python -c 'import sys; sys.exit(sys.version_in= fo < (3,0))'; then echo "warning: Python 3 will be required for building future versions of= QEMU" >&2 fi =20 +(for i in $cross_cc_vars; do + export $i +done +export target_list source_path +${SHELL-/bin/sh} $source_path/tests/tcg/configure.sh) + config_host_mak=3D"config-host.mak" =20 echo "# Automatically generated by configure - do not modify" >config-all-= disas.mak @@ -7388,10 +7346,6 @@ if test "$gcov" =3D "yes" ; then echo "GCOV=3D$gcov_tool" >> $config_host_mak fi =20 -if test "$docker" !=3D "no"; then - echo "HAVE_USER_DOCKER=3Dy" >> $config_host_mak -fi - if test "$libudev" !=3D "no"; then echo "CONFIG_LIBUDEV=3Dy" >> $config_host_mak echo "LIBUDEV_LIBS=3D$libudev_libs" >> $config_host_mak @@ -7460,10 +7414,6 @@ case "$target" in ;; esac =20 -target_compiler=3D"" -target_compiler_static=3D"" -target_compiler_cflags=3D"" - mkdir -p $target_dir echo "# Automatically generated by configure - do not modify" > $config_ta= rget_mak =20 @@ -7480,26 +7430,20 @@ case "$target_name" in i386) mttcg=3D"yes" gdb_xml_files=3D"i386-32bit.xml" - target_compiler=3D$cross_cc_i386 - target_compiler_cflags=3D$cross_cc_ccflags_i386 ;; x86_64) TARGET_BASE_ARCH=3Di386 mttcg=3D"yes" gdb_xml_files=3D"i386-64bit.xml" - target_compiler=3D$cross_cc_x86_64 ;; alpha) mttcg=3D"yes" - target_compiler=3D$cross_cc_alpha ;; arm|armeb) TARGET_ARCH=3Darm bflt=3D"yes" mttcg=3D"yes" gdb_xml_files=3D"arm-core.xml arm-vfp.xml arm-vfp3.xml arm-neon.xml" - target_compiler=3D$cross_cc_arm - eval "target_compiler_cflags=3D\$cross_cc_cflags_${target_name}" ;; aarch64|aarch64_be) TARGET_ARCH=3Daarch64 @@ -7507,41 +7451,32 @@ case "$target_name" in bflt=3D"yes" mttcg=3D"yes" gdb_xml_files=3D"aarch64-core.xml aarch64-fpu.xml arm-core.xml arm-vfp= .xml arm-vfp3.xml arm-neon.xml" - target_compiler=3D$cross_cc_aarch64 - eval "target_compiler_cflags=3D\$cross_cc_cflags_${target_name}" ;; cris) - target_compiler=3D$cross_cc_cris ;; hppa) mttcg=3D"yes" - target_compiler=3D$cross_cc_hppa ;; lm32) - target_compiler=3D$cross_cc_lm32 ;; m68k) bflt=3D"yes" gdb_xml_files=3D"cf-core.xml cf-fp.xml m68k-fp.xml" - target_compiler=3D$cross_cc_m68k ;; microblaze|microblazeel) TARGET_ARCH=3Dmicroblaze bflt=3D"yes" echo "TARGET_ABI32=3Dy" >> $config_target_mak - target_compiler=3D$cross_cc_microblaze ;; mips|mipsel) mttcg=3D"yes" TARGET_ARCH=3Dmips - target_compiler=3D$cross_cc_mips echo "TARGET_ABI_MIPSO32=3Dy" >> $config_target_mak ;; mipsn32|mipsn32el) mttcg=3D"yes" TARGET_ARCH=3Dmips64 TARGET_BASE_ARCH=3Dmips - target_compiler=3D$cross_cc_mipsn32 echo "TARGET_ABI_MIPSN32=3Dy" >> $config_target_mak echo "TARGET_ABI32=3Dy" >> $config_target_mak ;; @@ -7549,32 +7484,24 @@ case "$target_name" in mttcg=3D"yes" TARGET_ARCH=3Dmips64 TARGET_BASE_ARCH=3Dmips - target_compiler=3D$cross_cc_mips64 echo "TARGET_ABI_MIPSN64=3Dy" >> $config_target_mak ;; moxie) - target_compiler=3D$cross_cc_moxie ;; nios2) - target_compiler=3D$cross_cc_nios2 ;; or1k) - target_compiler=3D$cross_cc_or1k TARGET_ARCH=3Dopenrisc TARGET_BASE_ARCH=3Dopenrisc ;; ppc) gdb_xml_files=3D"power-core.xml power-fpu.xml power-altivec.xml power-= spe.xml" - target_compiler=3D$cross_cc_ppc - target_compiler_cflags=3D"$cross_cc_cflags_ppc" ;; ppc64) TARGET_BASE_ARCH=3Dppc TARGET_ABI_DIR=3Dppc mttcg=3Dyes gdb_xml_files=3D"power64-core.xml power-fpu.xml power-altivec.xml powe= r-spe.xml power-vsx.xml" - target_compiler=3D$cross_cc_ppc64 - target_compiler_cflags=3D"$cross_cc_cflags_ppc64" ;; ppc64le) TARGET_ARCH=3Dppc64 @@ -7582,7 +7509,6 @@ case "$target_name" in TARGET_ABI_DIR=3Dppc mttcg=3Dyes gdb_xml_files=3D"power64-core.xml power-fpu.xml power-altivec.xml powe= r-spe.xml power-vsx.xml" - target_compiler=3D$cross_cc_ppc64le ;; ppc64abi32) TARGET_ARCH=3Dppc64 @@ -7590,60 +7516,48 @@ case "$target_name" in TARGET_ABI_DIR=3Dppc echo "TARGET_ABI32=3Dy" >> $config_target_mak gdb_xml_files=3D"power64-core.xml power-fpu.xml power-altivec.xml powe= r-spe.xml power-vsx.xml" - target_compiler=3D$cross_cc_ppc64abi32 ;; riscv32) TARGET_BASE_ARCH=3Driscv TARGET_ABI_DIR=3Driscv mttcg=3Dyes gdb_xml_files=3D"riscv-32bit-cpu.xml riscv-32bit-fpu.xml riscv-32bit-c= sr.xml" - target_compiler=3D$cross_cc_riscv32 ;; riscv64) TARGET_BASE_ARCH=3Driscv TARGET_ABI_DIR=3Driscv mttcg=3Dyes gdb_xml_files=3D"riscv-64bit-cpu.xml riscv-64bit-fpu.xml riscv-64bit-c= sr.xml" - target_compiler=3D$cross_cc_riscv64 ;; sh4|sh4eb) TARGET_ARCH=3Dsh4 bflt=3D"yes" - target_compiler=3D$cross_cc_sh4 ;; sparc) - target_compiler=3D$cross_cc_sparc ;; sparc64) TARGET_BASE_ARCH=3Dsparc - target_compiler=3D$cross_cc_sparc64 ;; sparc32plus) TARGET_ARCH=3Dsparc64 TARGET_BASE_ARCH=3Dsparc TARGET_ABI_DIR=3Dsparc - target_compiler=3D$cross_cc_sparc32plus echo "TARGET_ABI32=3Dy" >> $config_target_mak ;; s390x) mttcg=3Dyes gdb_xml_files=3D"s390x-core64.xml s390-acr.xml s390-fpr.xml s390-vx.xm= l s390-cr.xml s390-virt.xml s390-gs.xml" - target_compiler=3D$cross_cc_s390x ;; tilegx) - target_compiler=3D$cross_cc_tilegx ;; tricore) - target_compiler=3D$cross_cc_tricore ;; unicore32) - target_compiler=3D$cross_cc_unicore32 ;; xtensa|xtensaeb) TARGET_ARCH=3Dxtensa bflt=3D"yes" mttcg=3D"yes" - target_compiler=3D$cross_cc_xtensa ;; *) error_exit "Unsupported target CPU" @@ -7654,27 +7568,6 @@ if [ "$TARGET_BASE_ARCH" =3D "" ]; then TARGET_BASE_ARCH=3D$TARGET_ARCH fi =20 -# Do we have a cross compiler for this target? -if has $target_compiler; then - - write_c_skeleton - - if ! do_compiler "$target_compiler" $target_compiler_cflags -o $TMPE $= TMPC -static ; then - # For host systems we might get away with building without -static - if ! do_compiler "$target_compiler" $target_compiler_cflags -o $TM= PE $TMPC ; then - target_compiler=3D"" - else - enabled_cross_compilers=3D"${enabled_cross_compilers} '${targe= t_compiler}'" - target_compiler_static=3D"n" - fi - else - enabled_cross_compilers=3D"${enabled_cross_compilers} '${target_co= mpiler}'" - target_compiler_static=3D"y" - fi -else - target_compiler=3D"" -fi - symlink "$source_path/Makefile.target" "$target_dir/Makefile" =20 upper() { @@ -7748,18 +7641,6 @@ if test "$target_bsd_user" =3D "yes" ; then echo "CONFIG_BSD_USER=3Dy" >> $config_target_mak fi =20 -if test -n "$target_compiler"; then - echo "CROSS_CC_GUEST=3D\"$target_compiler\"" >> $config_target_mak - - if test -n "$target_compiler_static"; then - echo "CROSS_CC_GUEST_STATIC=3D$target_compiler_static" >> $config_ta= rget_mak - fi - - if test -n "$target_compiler_cflags"; then - echo "CROSS_CC_GUEST_CFLAGS=3D$target_compiler_cflags" >> $config_ta= rget_mak - fi -fi - =20 # generate QEMU_CFLAGS/LDFLAGS for targets =20 @@ -7890,11 +7771,6 @@ done # for target in $targets echo "PIXMAN_CFLAGS=3D$pixman_cflags" >> $config_host_mak echo "PIXMAN_LIBS=3D$pixman_libs" >> $config_host_mak =20 -if test -n "$enabled_cross_compilers"; then - echo - echo "NOTE: cross-compilers enabled: $enabled_cross_compilers" -fi - if [ "$fdt" =3D "git" ]; then echo "config-host.h: dtc/all" >> $config_host_mak fi @@ -7923,15 +7799,14 @@ fi # so the build tree will be missing the link back to the new file, and # tests might fail. Prefer to keep the relevant files in their own # directory and symlink the directory instead. -DIRS=3D"tests tests/tcg tests/tcg/cris tests/tcg/lm32 tests/libqos tests/q= api-schema tests/tcg/xtensa tests/qemu-iotests tests/vm" +DIRS=3D"tests tests/tcg tests/tcg/lm32 tests/libqos tests/qapi-schema test= s/qemu-iotests tests/vm" DIRS=3D"$DIRS tests/fp tests/qgraph" DIRS=3D"$DIRS docs docs/interop fsdev scsi" DIRS=3D"$DIRS pc-bios/optionrom pc-bios/spapr-rtas pc-bios/s390-ccw" DIRS=3D"$DIRS roms/seabios roms/vgabios" -LINKS=3D"Makefile tests/tcg/Makefile" -LINKS=3D"$LINKS tests/tcg/cris/Makefile tests/tcg/cris/.gdbinit" -LINKS=3D"$LINKS tests/tcg/lm32/Makefile tests/tcg/xtensa/Makefile po/Makef= ile" -LINKS=3D"$LINKS tests/fp/Makefile" +LINKS=3D"Makefile" +LINKS=3D"$LINKS tests/tcg/lm32/Makefile po/Makefile" +LINKS=3D"$LINKS tests/tcg/Makefile.target tests/fp/Makefile" LINKS=3D"$LINKS pc-bios/optionrom/Makefile pc-bios/keymaps" LINKS=3D"$LINKS pc-bios/spapr-rtas/Makefile" LINKS=3D"$LINKS pc-bios/s390-ccw/Makefile" diff --git a/tests/Makefile.include b/tests/Makefile.include index 8bb5c97..a3ee649 100644 --- a/tests/Makefile.include +++ b/tests/Makefile.include @@ -1058,30 +1058,28 @@ BUILD_TCG_TARGET_RULES=3D$(patsubst %,build-tcg-tes= ts-%, $(TARGET_DIRS)) CLEAN_TCG_TARGET_RULES=3D$(patsubst %,clean-tcg-tests-%, $(TARGET_DIRS)) RUN_TCG_TARGET_RULES=3D$(patsubst %,run-tcg-tests-%, $(TARGET_DIRS)) =20 -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.prereqs)) -endif =20 build-tcg-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, \ + V=3D"$(V)" TARGET=3D"$*" guest-tests, \ "BUILD", "TCG tests for $*") =20 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, \ + V=3D"$(V)" TARGET=3D"$*" run-guest-tests, \ "RUN", "TCG tests for $*") =20 clean-tcg-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, \ + SRC_PATH=3D$(SRC_PATH) TARGET=3D"$*" clean-guest-tests, \ "RUN", "TCG tests for $*") =20 .PHONY: build-tcg diff --git a/tests/tcg/Makefile.prereqs b/tests/tcg/Makefile.prereqs index 53b0196..7494b31 100644 --- a/tests/tcg/Makefile.prereqs +++ b/tests/tcg/Makefile.prereqs @@ -7,24 +7,12 @@ # selection of required docker targets before we invoke a sub-make for # 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 - -# Then we load up the target architecture makefiles which tell us -# about the compilers DOCKER_IMAGE:=3D =20 --include $(SRC_PATH)/tests/tcg/$(TARGET_BASE_ARCH)/Makefile.include --include $(SRC_PATH)/tests/tcg/$(TARGET_NAME)/Makefile.include +-include $(BUILD_DIR)/tests/tcg/config-$(PROBE_TARGET).mak =20 -ifndef CROSS_CC_GUEST ifneq ($(DOCKER_IMAGE),) build-tcg-tests-$(PROBE_TARGET): docker-image-$(DOCKER_IMAGE) +$(BUILD_DIR)/tests/tcg/config_$(PROBE_TARGET).mak: config-host.mak +config-host.mak: $(SRC_PATH)/tests/tcg/configure.sh endif -endif - -# Clean-up -# undefine TARGET_NAME -# undefine TARGET_BASE_ARCH -# undefine TARGET_ABI_DIR diff --git a/tests/tcg/Makefile.qemu b/tests/tcg/Makefile.qemu index d3f3437..c8bec7b 100644 --- a/tests/tcg/Makefile.qemu +++ b/tests/tcg/Makefile.qemu @@ -8,17 +8,22 @@ # to do it for us. # =20 -# The per ARCH makefile, if it exists, holds extra information about +include $(SRC_PATH)/rules.mak + +# The configure script fills in extra information about # useful docker images or alternative compiler flags. =20 -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) +CROSS_CC_GUEST:=3D +DOCKER_IMAGE:=3D +-include $(BUILD_DIR)/tests/tcg/config-$(TARGET).mak =20 GUEST_BUILD=3D TCG_MAKE=3D../Makefile.target + +# We also need the Docker make rules to depend on +SKIP_DOCKER_BUILD=3D1 +include $(SRC_PATH)/tests/docker/Makefile.include + # Support installed Cross Compilers =20 ifdef CROSS_CC_GUEST @@ -26,11 +31,11 @@ ifdef CROSS_CC_GUEST .PHONY: cross-build-guest-tests cross-build-guest-tests: $(call quiet-command, \ - (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)" \ + (mkdir -p tests/tcg/$(TARGET) && cd tests/tcg/$(TARGET) && \ + $(MAKE) -f $(TCG_MAKE) TARGET=3D"$(TARGET)" 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)") + EXTRA_CFLAGS=3D"$(CROSS_CC_GUEST_CFLAGS)"), \ + "BUILD","$(TARGET) guest-tests with $(CROSS_CC_GUEST)") =20 GUEST_BUILD=3Dcross-build-guest-tests =20 @@ -38,31 +43,25 @@ endif =20 # Support building with Docker =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 - DOCKER_COMPILE_CMD=3D"$(DOCKER_SCRIPT) cc --user $(shell id -u) \ - --cc $(DOCKER_CROSS_COMPILER) \ + --cc $(DOCKER_CROSS_CC_GUEST) \ -i qemu:$(DOCKER_IMAGE) \ -s $(SRC_PATH) -- " =20 .PHONY: docker-build-guest-tests docker-build-guest-tests: docker-image-$(DOCKER_IMAGE) $(call quiet-command, \ - (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) \ + (mkdir -p tests/tcg/$(TARGET) && cd tests/tcg/$(TARGET) && \ + $(MAKE) -f $(TCG_MAKE) TARGET=3D"$(TARGET)" CC=3D$(DOCKER_COMPILE_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)") + EXTRA_CFLAGS=3D"$(CROSS_CC_GUEST_CFLAGS)"), \ + "BUILD","$(TARGET) guest-tests with docker qemu:$(DOCKER_IMAGE)") =20 GUEST_BUILD=3Ddocker-build-guest-tests =20 endif -endif =20 # Final targets all: @@ -75,22 +74,22 @@ guest-tests: $(GUEST_BUILD) =20 run-guest-tests: guest-tests $(call quiet-command, \ - (cd tests/tcg/$(TARGET_DIR) && \ - $(MAKE) -f $(TCG_MAKE) TARGET_DIR=3D"$(TARGET_DIR)" \ + (cd tests/tcg/$(TARGET) && \ + $(MAKE) -f $(TCG_MAKE) TARGET=3D"$(TARGET)" \ 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_DIR) guest-tests SKIPPED") + "$(TARGET) guest-tests SKIPPED") =20 run-guest-tests: $(call quiet-command, /bin/true, "RUN", \ - "tests for $(TARGET_DIR) SKIPPED") + "tests for $(TARGET) SKIPPED") endif =20 # It doesn't matter if these don't exits .PHONY: clean-guest-tests clean-guest-tests: - rm -rf tests/tcg/$(TARGET_DIR) + rm -rf tests/tcg/$(TARGET) diff --git a/tests/tcg/Makefile.target b/tests/tcg/Makefile.target index 8dbcba4..8808bea 100644 --- a/tests/tcg/Makefile.target +++ b/tests/tcg/Makefile.target @@ -31,7 +31,7 @@ =20 all: -include ../../config-host.mak --include ../../../$(TARGET_DIR)/config-target.mak +-include ../config-$(TARGET).mak =20 # for including , in command strings COMMA :=3D , @@ -63,12 +63,6 @@ CFLAGS=3D QEMU_CFLAGS=3D LDFLAGS=3D =20 -# The QEMU for this TARGET -ifdef CONFIG_USER_ONLY -QEMU=3D../../../$(TARGET_DIR)/qemu-$(TARGET_NAME) -else -QEMU=3D../../../$(TARGET_DIR)/qemu-system-$(TARGET_NAME) -endif QEMU_OPTS=3D =20 =20 diff --git a/tests/tcg/aarch64/Makefile.include b/tests/tcg/aarch64/Makefil= e.include deleted file mode 100644 index 5d4e4c6..0000000 --- a/tests/tcg/aarch64/Makefile.include +++ /dev/null @@ -1,8 +0,0 @@ -# Makefile.include for AArch64 targets -# -# We don't have any bigendian build tools so we only use this for AArch64 - -ifeq ($(TARGET_NAME),aarch64) -DOCKER_IMAGE=3Ddebian-buster-arm64-cross -DOCKER_CROSS_COMPILER=3Daarch64-linux-gnu-gcc -endif diff --git a/tests/tcg/alpha/Makefile.include b/tests/tcg/alpha/Makefile.in= clude deleted file mode 100644 index c7dc48e..0000000 --- a/tests/tcg/alpha/Makefile.include +++ /dev/null @@ -1,2 +0,0 @@ -DOCKER_IMAGE=3Ddebian-alpha-cross -DOCKER_CROSS_COMPILER=3Dalpha-linux-gnu-gcc diff --git a/tests/tcg/arm/Makefile.include b/tests/tcg/arm/Makefile.include deleted file mode 100644 index 8e7eac0..0000000 --- a/tests/tcg/arm/Makefile.include +++ /dev/null @@ -1,8 +0,0 @@ -# Makefile.include for all ARM targets -# -# We don't have any bigendian build tools so we only use this for armhf - -ifeq ($(TARGET_NAME),arm) -DOCKER_IMAGE=3Ddebian-armhf-cross -DOCKER_CROSS_COMPILER=3Darm-linux-gnueabihf-gcc -endif diff --git a/tests/tcg/configure.sh b/tests/tcg/configure.sh new file mode 100644 index 0000000..5a8f52e --- /dev/null +++ b/tests/tcg/configure.sh @@ -0,0 +1,228 @@ +#!/bin/sh + +if test -z "$source_path"; then + echo Do not invoke this script directly. It is called + echo automatically by configure. + exit 1 +fi + +write_c_skeleton() { + cat > $TMPC </dev/null 2>&1 +} + +do_compiler() { + # Run the compiler, capturing its output to the log. First argument + # is compiler binary to execute. + local compiler=3D"$1" + shift + if test -n "$BASH_VERSION"; then eval ' + echo >>config.log " +funcs: ${FUNCNAME[*]} +lines: ${BASH_LINENO[*]}" + '; fi + echo $compiler "$@" >> config.log + $compiler "$@" >> config.log 2>&1 || return $? +} + + +TMPDIR1=3D"config-temp" +TMPC=3D"${TMPDIR1}/qemu-conf.c" +TMPE=3D"${TMPDIR1}/qemu-conf.exe" + +if has docker; then + docker=3D$($python $source_path/tests/docker/docker.py probe) +fi + +# cross compilers defaults, can be overridden with --cross-cc-ARCH +: ${cross_cc_aarch64=3D"aarch64-linux-gnu-gcc"} +: ${cross_cc_aarch64_be=3D"$cross_cc_aarch64"} +: ${cross_cc_cflags_aarch64_be=3D"-mbig-endian"} +: ${cross_cc_arm=3D"arm-linux-gnueabihf-gcc"} +: ${cross_cc_cflags_armeb=3D"-mbig-endian"} +: ${cross_cc_i386=3D"i386-pc-linux-gnu-gcc"} +: ${cross_cc_cflags_i386=3D"-m32"} +: ${cross_cc_x86_64=3D"x86_64-pc-linux-gnu-gcc"} +: ${cross_cc_cflags_x86_64=3D"-m64"} +: ${cross_cc_ppc=3D"powerpc-linux-gnu-gcc"} +: ${cross_cc_cflags_ppc=3D"-m32"} +: ${cross_cc_ppc64=3D"powerpc-linux-gnu-gcc"} +: ${cross_cc_cflags_ppc64=3D"-m64"} +: ${cross_cc_ppc64le=3D"powerpc64le-linux-gnu-gcc"} +: ${cross_cc_cflags_s390x=3D"-m64"} +: ${cross_cc_cflags_sparc=3D"-m32 -mv8plus -mcpu=3Dultrasparc"} +: ${cross_cc_cflags_sparc64=3D"-m64 -mcpu=3Dultrasparc"} + +for target in $target_list; do + arch=3D${target%%-*} + case $arch in + arm|armeb) + arches=3Darm + ;; + aarch64|aarch64_be) + arches=3D"aarch64 arm" + ;; + mips*) + arches=3Dmips + ;; + ppc*) + arches=3Dppc + ;; + sh4|sh4eb) + arches=3Dsh4 + ;; + x86_64) + arches=3D"x86_64 i386" + ;; + xtensa|xtensaeb) + arches=3Dxtensa + ;; + alpha|cris|hppa|i386|lm32|m68k|openrisc|riscv64|s390x|sh4|sparc64) + arches=3D$target + ;; + *) + continue + ;; + esac + + docker_image=3D + case $target in + aarch64-*) + # We don't have any bigendian build tools so we only use this for AA= rch64 + docker_image=3Ddebian-buster-arm64-cross + docker_cross_cc=3Daarch64-linux-gnu-gcc + ;; + alpha-*) + docker_image=3Ddebian-alpha-cross + docker_cross_cc=3Dalpha-linux-gnu-gcc + ;; + arm-*) + # We don't have any bigendian build tools so we only use this for AA= rch64 + docker_image=3Ddebian-armhf-cross + docker_cross_cc=3Darm-linux-gnueabihf-gcc + ;; + cris-*) + docker_image=3Dfedora-cris-cross + docker_cross_cc=3Dcris-linux-gnu-gcc + ;; + hppa-*) + docker_image=3Ddebian-hppa-cross + docker_cross_cc=3Dhppa-linux-gnu-gcc + ;; + i386-*) + docker_image=3Dfedora-i386-cross + docker_cross_cc=3Dgcc + ;; + m68k-*) + docker_image=3Ddebian-m68k-cross + docker_cross_cc=3Dm68k-linux-gnu-gcc + ;; + mips64el-*) + docker_image=3Ddebian-mips64el-cross + docker_cross_cc=3Dmips64el-linux-gnuabi64-gcc + ;; + mips64-*) + docker_image=3Ddebian-mips64-cross + docker_cross_cc=3Dmips64-linux-gnuabi64-gcc + ;; + mipsel-*) + docker_image=3Ddebian-mipsel-cross + docker_cross_cc=3Dmipsel-linux-gnu-gcc + ;; + mips-*) + docker_image=3Ddebian-mips-cross + docker_cross_cc=3Dmips-linux-gnu-gcc + ;; + ppc-*) + docker_image=3Ddebian-powerpc-cross + docker_cross_cc=3Dpowerpc-linux-gnu-gcc + ;; + ppc64-*) + docker_image=3Ddebian-ppc64-cross + docker_cross_cc=3Dpowerpc64-linux-gnu-gcc + ;; + ppc64le-*) + docker_image=3Ddebian-ppc64el-cross + docker_cross_cc=3Dpowerpc64le-linux-gnu-gcc + ;; + riscv64-*) + docker_image=3Ddebian-riscv64-cross + docker_cross_cc=3Driscv64-linux-gnu-gcc + ;; + s390x-*) + docker_image=3Ddebian-s390x-cross + docker_cross_cc=3Ds390x-linux-gnu-gcc + ;; + sh4-*) + docker_image=3Ddebian-sh4-cross + docker_cross_cc=3Dsh4-linux-gnu-gcc + ;; + sparc64-*) + docker_image=3Ddebian-sparc64-cross + docker_cross_cc=3Dsparc64-linux-gnu-gcc + ;; + xtensa*-softmmu) + docker_image=3Ddebian-xtensa-cross + + # default to the dc232b cpu + docker_cross_cc=3D/opt/2018.02/xtensa-dc232b-elf/bin/xtensa-dc232b-e= lf-gcc + ;; + esac + + config_target_mak=3Dtests/tcg/config-$target.mak + + echo "# Automatically generated by configure - do not modify" > $config_= target_mak + echo "TARGET_NAME=3D$arch" >> $config_target_mak + case $target in + *-linux-user | *-bsd-user) + echo "CONFIG_USER_ONLY=3Dy" >> $config_target_mak + echo "QEMU=3D\$(BUILD_DIR)/$target/qemu-$arch" >> $config_target_mak + ;; + *-softmmu) + echo "CONFIG_SOFTMMU=3Dy" >> $config_target_mak + echo "QEMU=3D\$(BUILD_DIR)/$target/qemu-system-$arch" >> $config_tar= get_mak + ;; + esac + + eval "target_compiler_cflags=3D\${cross_cc_cflags_$arch}" + echo "CROSS_CC_GUEST_CFLAGS=3D$target_compiler_cflags" >> $config_target= _mak + + got_cross_cc=3Dno + for i in $arch $arches; do + if eval test "x\${cross_cc_$i+yes}" !=3D xyes; then + continue + fi + + eval "target_compiler=3D\${cross_cc_$i}" + if ! has $target_compiler; then + continue + fi + write_c_skeleton + if ! do_compiler "$target_compiler" $target_compiler_cflags -o $TMPE $= TMPC -static ; then + # For host systems we might get away with building without -static + if ! do_compiler "$target_compiler" $target_compiler_cflags -o $TMPE= $TMPC ; then + continue + fi + echo "CROSS_CC_GUEST_STATIC=3Dy" >> $config_target_mak + fi + echo "CROSS_CC_GUEST=3D$target_compiler" >> $config_target_mak + enabled_cross_compilers=3D"$enabled_cross_compilers $target_compiler" + got_cross_cc=3Dyes + break + done + + if test $got_cross_cc =3D no && test "$docker" !=3D no && test -n "$dock= er_image"; then + echo "DOCKER_IMAGE=3D$docker_image" >> $config_target_mak + echo "DOCKER_CROSS_CC_GUEST=3D$docker_cross_cc" >> $config_target_mak + fi +done + +if test -n "$enabled_cross_compilers"; then + echo + echo "NOTE: guest cross-compilers enabled:$enabled_cross_compilers" +fi diff --git a/tests/tcg/cris/Makefile.include b/tests/tcg/cris/Makefile.incl= ude deleted file mode 100644 index 1c03782..0000000 --- a/tests/tcg/cris/Makefile.include +++ /dev/null @@ -1,6 +0,0 @@ -# -# Makefile.include for all CRIS targets -# - -DOCKER_IMAGE=3Dfedora-cris-cross -DOCKER_CROSS_COMPILER=3Dcris-linux-gnu-gcc diff --git a/tests/tcg/hppa/Makefile.include b/tests/tcg/hppa/Makefile.incl= ude deleted file mode 100644 index da23534..0000000 --- a/tests/tcg/hppa/Makefile.include +++ /dev/null @@ -1,2 +0,0 @@ -DOCKER_IMAGE=3Ddebian-hppa-cross -DOCKER_CROSS_COMPILER=3Dhppa-linux-gnu-gcc diff --git a/tests/tcg/i386/Makefile.include b/tests/tcg/i386/Makefile.incl= ude deleted file mode 100644 index be1c300..0000000 --- a/tests/tcg/i386/Makefile.include +++ /dev/null @@ -1,9 +0,0 @@ -# -# Makefile.include for all i386 -# -# There is enough brokeness in x86_64 compilers that we don't default -# to using the x86_64 system compiler for i386 binaries. -# - -DOCKER_IMAGE=3Dfedora-i386-cross -DOCKER_CROSS_COMPILER=3Dgcc diff --git a/tests/tcg/m68k/Makefile.include b/tests/tcg/m68k/Makefile.incl= ude deleted file mode 100644 index cd7c6bf..0000000 --- a/tests/tcg/m68k/Makefile.include +++ /dev/null @@ -1,2 +0,0 @@ -DOCKER_IMAGE=3Ddebian-m68k-cross -DOCKER_CROSS_COMPILER=3Dm68k-linux-gnu-gcc diff --git a/tests/tcg/mips/Makefile.include b/tests/tcg/mips/Makefile.incl= ude deleted file mode 100644 index 4a14fc0..0000000 --- a/tests/tcg/mips/Makefile.include +++ /dev/null @@ -1,20 +0,0 @@ -# -# Makefile.include for all MIPs targets -# -# As Debian doesn't support mip64 in big endian mode the only way to -# build BE is to pass a working cross compiler to ./configure -# - -ifeq ($(TARGET_NAME),mips64el) -DOCKER_IMAGE=3Ddebian-mips64el-cross -DOCKER_CROSS_COMPILER=3Dmips64el-linux-gnuabi64-gcc -else ifeq ($(TARGET_NAME),mips64) -DOCKER_IMAGE=3Ddebian-mips64-cross -DOCKER_CROSS_COMPILER=3Dmips64-linux-gnuabi64-gcc -else ifeq ($(TARGET_NAME),mipsel) -DOCKER_IMAGE=3Ddebian-mipsel-cross -DOCKER_CROSS_COMPILER=3Dmipsel-linux-gnu-gcc -else ifeq ($(TARGET_NAME),mips) -DOCKER_IMAGE=3Ddebian-mips-cross -DOCKER_CROSS_COMPILER=3Dmips-linux-gnu-gcc -endif diff --git a/tests/tcg/ppc/Makefile.include b/tests/tcg/ppc/Makefile.include deleted file mode 100644 index ae01fb8..0000000 --- a/tests/tcg/ppc/Makefile.include +++ /dev/null @@ -1,10 +0,0 @@ -ifeq ($(TARGET_NAME),ppc) -DOCKER_IMAGE=3Ddebian-powerpc-cross -DOCKER_CROSS_COMPILER=3Dpowerpc-linux-gnu-gcc -else ifeq ($(TARGET_NAME),ppc64) -DOCKER_IMAGE=3Ddebian-ppc64-cross -DOCKER_CROSS_COMPILER=3Dpowerpc64-linux-gnu-gcc -else ifeq ($(TARGET_NAME),ppc64le) -DOCKER_IMAGE=3Ddebian-ppc64el-cross -DOCKER_CROSS_COMPILER=3Dpowerpc64le-linux-gnu-gcc -endif diff --git a/tests/tcg/riscv/Makefile.include b/tests/tcg/riscv/Makefile.in= clude deleted file mode 100644 index d92ac6c..0000000 --- a/tests/tcg/riscv/Makefile.include +++ /dev/null @@ -1,10 +0,0 @@ -# -# Makefile.include for all RISCV targets -# -# Debian only really cares about 64 bit going forward -# - -ifeq ($(TARGET_NAME),riscv64) -DOCKER_IMAGE=3Ddebian-riscv64-cross -DOCKER_CROSS_COMPILER=3Driscv64-linux-gnu-gcc -endif diff --git a/tests/tcg/s390x/Makefile.include b/tests/tcg/s390x/Makefile.in= clude deleted file mode 100644 index 1f58115..0000000 --- a/tests/tcg/s390x/Makefile.include +++ /dev/null @@ -1,2 +0,0 @@ -DOCKER_IMAGE=3Ddebian-s390x-cross -DOCKER_CROSS_COMPILER=3Ds390x-linux-gnu-gcc diff --git a/tests/tcg/sh4/Makefile.include b/tests/tcg/sh4/Makefile.include deleted file mode 100644 index ad21594..0000000 --- a/tests/tcg/sh4/Makefile.include +++ /dev/null @@ -1,4 +0,0 @@ -ifneq ($(TARGET_NAME), sh4eb) -DOCKER_IMAGE=3Ddebian-sh4-cross -DOCKER_CROSS_COMPILER=3Dsh4-linux-gnu-gcc -endif diff --git a/tests/tcg/sparc64/Makefile.include b/tests/tcg/sparc64/Makefil= e.include deleted file mode 100644 index 95fc8de..0000000 --- a/tests/tcg/sparc64/Makefile.include +++ /dev/null @@ -1,2 +0,0 @@ -DOCKER_IMAGE=3Ddebian-sparc64-cross -DOCKER_CROSS_COMPILER=3Dsparc64-linux-gnu-gcc diff --git a/tests/tcg/xtensa/Makefile.include b/tests/tcg/xtensa/Makefile.= include deleted file mode 100644 index 423c00a..0000000 --- a/tests/tcg/xtensa/Makefile.include +++ /dev/null @@ -1,11 +0,0 @@ -# Makefile.include for xtensa targets -# -# The compilers can only be used for building system tests - -ifeq ($(CONFIG_SOFTMMU),y) -DOCKER_IMAGE=3Ddebian-xtensa-cross - -# default to the dc232b cpu -DOCKER_CROSS_COMPILER=3D/opt/2018.02/xtensa-dc232b-elf/bin/xtensa-dc232b-e= lf-gcc -DOCKER_CROSS_LINKER=3D/opt/2018.02/xtensa-dc232b-elf/bin/xtensa-dc232b-elf= -ld -endif --=20 1.8.3.1