From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mp2 ([2001:41d0:2:4a6f::]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)) by ms0.migadu.com with LMTPS id 1NcwLLra6mAnUQAAgWs5BA (envelope-from ) for ; Sun, 11 Jul 2021 13:49:14 +0200 Received: from aspmx1.migadu.com ([2001:41d0:2:4a6f::]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)) by mp2 with LMTPS id oL1wJ7ra6mD9NwAAB5/wlQ (envelope-from ) for ; Sun, 11 Jul 2021 11:49:14 +0000 Received: from lists.gnu.org (lists.gnu.org [209.51.188.17]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by aspmx1.migadu.com (Postfix) with ESMTPS id 5298E2A13C for ; Sun, 11 Jul 2021 13:49:14 +0200 (CEST) Received: from localhost ([::1]:49262 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1m2XxR-000423-Al for larch@yhetil.org; Sun, 11 Jul 2021 07:49:13 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:57508) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1m2XxG-00041K-QP for guix-patches@gnu.org; Sun, 11 Jul 2021 07:49:02 -0400 Received: from debbugs.gnu.org ([209.51.188.43]:50769) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1m2XxG-0008H6-Ig for guix-patches@gnu.org; Sun, 11 Jul 2021 07:49:02 -0400 Received: from Debian-debbugs by debbugs.gnu.org with local (Exim 4.84_2) (envelope-from ) id 1m2XxG-00073a-IR for guix-patches@gnu.org; Sun, 11 Jul 2021 07:49:02 -0400 X-Loop: help-debbugs@gnu.org Subject: [bug#49025] [PATCH v5 02/20] utils: Define a target-x86-32? and target-x86-64? predicate. Resent-From: Maxime Devos Original-Sender: "Debbugs-submit" Resent-CC: guix-patches@gnu.org Resent-Date: Sun, 11 Jul 2021 11:49:02 +0000 Resent-Message-ID: Resent-Sender: help-debbugs@gnu.org X-GNU-PR-Message: followup 49025 X-GNU-PR-Package: guix-patches X-GNU-PR-Keywords: patch To: 49025@debbugs.gnu.org Cc: Maxime Devos Received: via spool by 49025-submit@debbugs.gnu.org id=B49025.162600408526874 (code B ref 49025); Sun, 11 Jul 2021 11:49:02 +0000 Received: (at 49025) by debbugs.gnu.org; 11 Jul 2021 11:48:05 +0000 Received: from localhost ([127.0.0.1]:34022 helo=debbugs.gnu.org) by debbugs.gnu.org with esmtp (Exim 4.84_2) (envelope-from ) id 1m2XwK-0006z6-2t for submit@debbugs.gnu.org; Sun, 11 Jul 2021 07:48:04 -0400 Received: from xavier.telenet-ops.be ([195.130.132.52]:38492) by debbugs.gnu.org with esmtp (Exim 4.84_2) (envelope-from ) id 1m2XwH-0006y4-HA for 49025@debbugs.gnu.org; Sun, 11 Jul 2021 07:48:02 -0400 Received: from localhost.localdomain ([213.119.242.127]) by xavier.telenet-ops.be with bizsmtp id Tnno2500V2ldwth01no0r2; Sun, 11 Jul 2021 13:48:00 +0200 From: Maxime Devos Date: Sun, 11 Jul 2021 13:47:05 +0200 Message-Id: <20210711114723.27568-3-maximedevos@telenet.be> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210711114723.27568-1-maximedevos@telenet.be> References: <419215938396207999184dafa43afaed6d7a0715.camel@telenet.be> <20210711114723.27568-1-maximedevos@telenet.be> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=telenet.be; s=r21; t=1626004080; bh=lf5YV93HuGoFIHD1h6x01QuYB2H0sCsCvf+MhMqf3Ic=; h=From:To:Cc:Subject:Date:In-Reply-To:References; b=OEYLruNOj0JR9cguKaPzvCYBvZ6fMewVwuBF/wVADMAClkMJNhO2iSFJ3Oi4gIl8Z T+oaxcBG3p5w+eTgXKUj8b/F3sUj2xL8690ZdhOiDu+5+BsHGxiVCGXZ2DHTWYcLsF XnEE0FdqrYiM1h1DkD7bJrS/qrpIjZ1I6417FW57S5lo3Lfp7cBYHUbyqKBmkhiNk/ lTUvbqjIJN67OXesIsVdLzRmRKO0evnvLa8WF4gMysnec/SvQXOo9+lqqpc6Qsi3XU ASj/7ejFgKNtZ8K5g1OjdmMBWDY4ZtS/LVC9u2e/QYlP0P2MD77beSexBvCRBuDf2g ZpJQVpfP9vGhw== X-BeenThere: debbugs-submit@debbugs.gnu.org X-Mailman-Version: 2.1.18 Precedence: list X-BeenThere: guix-patches@gnu.org List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: guix-patches-bounces+larch=yhetil.org@gnu.org Sender: "Guix-patches" X-Migadu-Flow: FLOW_IN ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=yhetil.org; s=key1; t=1626004154; h=from:from:sender:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding:resent-cc: resent-from:resent-sender:resent-message-id:in-reply-to:in-reply-to: references:references:list-id:list-help:list-unsubscribe: list-subscribe:list-post:dkim-signature; bh=lf5YV93HuGoFIHD1h6x01QuYB2H0sCsCvf+MhMqf3Ic=; b=uJoVnNXL95AWu3GgLdjQKwajRLiwEsPHk6s3jlCFrU0ZQz8d96CiMN15JHVtWPEg2rrBUK BZ566BSQzud+IGrs9lPz7OZuUiSADbcTrZUfYYGhBEoGWvxnYXVt4oPankMZSbx6tmDB+A kPoxev8bku/RdMOvpiQO2CCZEZqasGC/ADvQ8n+tLo2s4BXrg0cMe3CT+cKy/7oFcJdK9z jWlD4lTv9aNJq8jGHadCRkpHP76NQffo0n6CCHF1ZSjQsKjRB+s+ZbpoG/xPuRmmMwYN+e sjla9GeQGncF0tkwQUbOcZmyEEq9ZDhWz5NRBy9YDTP1D8V07Lv0zt7fAkURtQ== ARC-Seal: i=1; s=key1; d=yhetil.org; t=1626004154; a=rsa-sha256; cv=none; b=of7E8iNkD54kIj7qWsl8vRMDEiYVjQBTdnyzNyhkutZqucCSeZCL855AK9wxGl3Q6rBcIU OGlx83+wHc6uTTvIZSyrVp3SCmRcw+JmIW5Nf73xRKsBxk5v+dv+6RwO4cO9LdUblH0abS XdOAJiFFhuU/xkAZQ5Xd7IHeFXz3PPySD0ZnPImW0wmWB30LlhAeAPIy817fA7pI+06vij GcuM+djwjgo3buSly5ndqEYiNj1iOPsfbbU+j4+TunCC8FJwUa8sqLaDzbPZf/KKQ1gfky IaZyvUNBg/G5p/S47dIXlJKnynHBhFyvYBHllMHwb36hBfABD9ue7HW4veFu3Q== ARC-Authentication-Results: i=1; aspmx1.migadu.com; dkim=fail ("headers rsa verify failed") header.d=telenet.be header.s=r21 header.b=OEYLruNO; spf=pass (aspmx1.migadu.com: domain of guix-patches-bounces@gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=guix-patches-bounces@gnu.org X-Migadu-Spam-Score: 3.69 Authentication-Results: aspmx1.migadu.com; dkim=fail ("headers rsa verify failed") header.d=telenet.be header.s=r21 header.b=OEYLruNO; dmarc=fail reason="SPF not aligned (relaxed)" header.from=telenet.be (policy=none); spf=pass (aspmx1.migadu.com: domain of guix-patches-bounces@gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=guix-patches-bounces@gnu.org X-Migadu-Queue-Id: 5298E2A13C X-Spam-Score: 3.69 X-Migadu-Scanner: scn0.migadu.com X-TUID: luDOsmPsACbI * guix/utils.scm (target-x86-32?, target-x86-64?): New predicates. * tests/utils.scm ("target-x86-32?", "target-x86-64?"): New tests. --- guix/utils.scm | 20 ++++++++++++++++++++ tests/utils.scm | 23 +++++++++++++++++++++++ 2 files changed, 43 insertions(+) diff --git a/guix/utils.scm b/guix/utils.scm index 4ff2602e23..2256ea2ca6 100644 --- a/guix/utils.scm +++ b/guix/utils.scm @@ -84,6 +84,8 @@ package-name->name+version target-linux? target-mingw? + target-x86-32? + target-x86-64? target-arm32? target-aarch64? target-arm? @@ -553,6 +555,24 @@ a character other than '@'." (and target (string-suffix? "-mingw32" target))) +(define* (target-x86-32? #:optional (target (or (%current-target-system) + (%current-system)))) + "Is the architecture of TARGET a variant of Intel's 32-bit architecture +(IA32)?" + ;; Intel also has a 16-bit architecture in the iN86 series, i286 + ;; (see, e.g. https://en.wikipedia.org/wiki/Intel/808286) so this + ;; procedure is not named target-x86?. + (or (string-prefix? "i386-" target) + (string-prefix? "i486-" target) + (string-prefix? "i586-" target) + (string-prefix? "i686-" target))) + +(define* (target-x86-64? #:optional (target (or (%current-target-system) + (%current-system)))) + "Is the architecture of TARGET a variant of Intel/AMD's 64-bit +architecture (x86_64)?" + (string-prefix? "x86_64-" target)) + (define* (target-arm32? #:optional (target (or (%current-target-system) (%current-system)))) (string-prefix? "arm" target)) diff --git a/tests/utils.scm b/tests/utils.scm index 80a0e669a4..92439b5587 100644 --- a/tests/utils.scm +++ b/tests/utils.scm @@ -306,6 +306,29 @@ skip these tests." '("i686-linux-gnu" "i686-pc-gnu" "i686-w64-mingw32"))) +(test-equal "target-x86-32?" + '(#f #f #f #t #t #t #t #f) + ;; These are (according to Wikipedia) two RISC architectures + ;; by Intel and presumably not compatible with the x86-32 series. + (map target-x86-32? + '("i860-gnu" "i960-gnu" + ;; This is a 16-bit architecture + "i286-gnu" + ;; These are part of the x86-32 series. + "i386-gnu" "i486-gnu" "i586-gnu" "i686-gnu" + ;; Maybe this one will exist some day, but not yet. + "i786-gnu"))) + +(test-equal "target-x86-64?" + '(#t #f #f #f) + (map target-x86-64? + `("x86_64-linux-gnu" "i386-linux-gnu" + ;; Just because it includes "64" doesn't make it 64-bit. + "aarch64-linux-gnu" + ;; Note that (expt 2 109) in decimal notation starts with 64. + ;; However, it isn't 32-bit. + ,(format #f "x86_~a-linux-gnu" (expt 2 109))))) + (test-end) (false-if-exception (delete-file temp-file)) -- 2.32.0