summaryrefslogtreecommitdiff
path: root/packages
diff options
context:
space:
mode:
authorChris Packham <judge.packham@gmail.com>2020-12-08 07:10:34 (GMT)
committerGitHub <noreply@github.com>2020-12-08 07:10:34 (GMT)
commit36db1595b035c3e41d708806925f51cdcfe65a9d (patch)
treeb7df8dbca3ebc5bc5496051e6870788967e950a2 /packages
parenta5219d6e048db7d5b29d7555daca167acb454a04 (diff)
parente7b3b20d0b201df11dde5af9fa86830603a51a28 (diff)
Merge pull request #1426 from galak/mac-arm
Initial changes to build cross compilers on new ARM based M1 Macs
Diffstat (limited to 'packages')
-rw-r--r--packages/gcc/10.2.0/0020-Darwin-Adjust-the-PCH-area-to-allow-for-16384byte-pa.patch35
-rw-r--r--packages/gcc/10.2.0/0021-Darwin-Arm64-Initial-support-for-the-self-host-drive.patch97
-rw-r--r--packages/gmp/6.2.0/chksum12
-rw-r--r--packages/gmp/6.2.1/0000-Avoid-the-x18-register.patch520
-rw-r--r--packages/gmp/6.2.1/chksum8
-rw-r--r--packages/gmp/6.2.1/version.desc (renamed from packages/gmp/6.2.0/version.desc)0
6 files changed, 660 insertions, 12 deletions
diff --git a/packages/gcc/10.2.0/0020-Darwin-Adjust-the-PCH-area-to-allow-for-16384byte-pa.patch b/packages/gcc/10.2.0/0020-Darwin-Adjust-the-PCH-area-to-allow-for-16384byte-pa.patch
new file mode 100644
index 0000000..4904368
--- /dev/null
+++ b/packages/gcc/10.2.0/0020-Darwin-Adjust-the-PCH-area-to-allow-for-16384byte-pa.patch
@@ -0,0 +1,35 @@
+From 22a26745add0b02a96d1b65c953529f217a52bad Mon Sep 17 00:00:00 2001
+From: Iain Sandoe <iain@sandoe.co.uk>
+Date: Sat, 8 Aug 2020 12:15:09 +0100
+Subject: [PATCH 1/2] Darwin: Adjust the PCH area to allow for 16384byte page
+ size.
+
+Newer versions of Darwin report pagesize 20 which means that we
+need to adjust the aligment of the PCH area.
+
+gcc/ChangeLog:
+
+ * config/host-darwin.c: Align pch_address_space to 16384.
+---
+ gcc/config/host-darwin.c | 5 ++++-
+ 1 file changed, 4 insertions(+), 1 deletion(-)
+
+diff --git a/gcc/config/host-darwin.c b/gcc/config/host-darwin.c
+index 0face6c450f..c862935dcf3 100644
+--- a/gcc/config/host-darwin.c
++++ b/gcc/config/host-darwin.c
+@@ -24,7 +24,10 @@
+ #include "config/host-darwin.h"
+
+ /* Yes, this is really supposed to work. */
+-static char pch_address_space[1024*1024*1024] __attribute__((aligned (4096)));
++/* This allows for a pagesize of 16384, which we have on Darwin20, but should
++ continue to work OK for pagesize 4096 which we have on earlier versions.
++ The size is 1 (binary) Gb. */
++static char pch_address_space[65536*16384] __attribute__((aligned (16384)));
+
+ /* Return the address of the PCH address space, if the PCH will fit in it. */
+
+--
+2.28.0
+
diff --git a/packages/gcc/10.2.0/0021-Darwin-Arm64-Initial-support-for-the-self-host-drive.patch b/packages/gcc/10.2.0/0021-Darwin-Arm64-Initial-support-for-the-self-host-drive.patch
new file mode 100644
index 0000000..12d99f8
--- /dev/null
+++ b/packages/gcc/10.2.0/0021-Darwin-Arm64-Initial-support-for-the-self-host-drive.patch
@@ -0,0 +1,97 @@
+From ffecb0ce72f51ec134dc33636eedcebe53e4ec9e Mon Sep 17 00:00:00 2001
+From: Iain Sandoe <iain@sandoe.co.uk>
+Date: Tue, 18 Aug 2020 22:29:51 +0100
+Subject: [PATCH 2/2] Darwin, Arm64: Initial support for the self-host driver.
+
+At present, this just includes the generic Darwin stuff.
+
+NOTE:
+
+This patch is pulled from: https://github.com/iains/gcc-darwin-arm64/
+
+See commit 89dc5a9d5ed3e6b2ba6a4725bd51841ee758b6cd
+
+Its been backported to gcc-10.2
+---
+ gcc/config.host | 7 +++++-
+ gcc/config/aarch64/host-aarch64-darwin.c | 32 ++++++++++++++++++++++++
+ gcc/config/aarch64/x-darwin | 3 +++
+ 3 files changed, 41 insertions(+), 1 deletion(-)
+ create mode 100644 gcc/config/aarch64/host-aarch64-darwin.c
+ create mode 100644 gcc/config/aarch64/x-darwin
+
+diff --git a/gcc/config.host b/gcc/config.host
+index 84f0433e2ad..8489145e1b1 100644
+--- a/gcc/config.host
++++ b/gcc/config.host
+@@ -99,7 +99,8 @@ case ${host} in
+ esac
+
+ case ${host} in
+- aarch64*-*-freebsd* | aarch64*-*-linux* | aarch64*-*-fuchsia*)
++ aarch64*-*-freebsd* | aarch64*-*-linux* | aarch64*-*-fuchsia* |\
++ aarch64-*-darwin* | arm64*-*-darwin*)
+ case ${target} in
+ aarch64*-*-*)
+ host_extra_gcc_objs="driver-aarch64.o"
+@@ -251,6 +252,10 @@ case ${host} in
+ host_extra_gcc_objs="${host_extra_gcc_objs} driver-mingw32.o"
+ host_lto_plugin_soname=liblto_plugin-0.dll
+ ;;
++ aarch64-*-darwin* | arm64-*-darwin*)
++ out_host_hook_obj="${out_host_hook_obj} host-aarch64-darwin.o"
++ host_xmake_file="${host_xmake_file} aarch64/x-darwin"
++ ;;
+ i[34567]86-*-darwin* | x86_64-*-darwin*)
+ out_host_hook_obj="${out_host_hook_obj} host-i386-darwin.o"
+ host_xmake_file="${host_xmake_file} i386/x-darwin"
+diff --git a/gcc/config/aarch64/host-aarch64-darwin.c b/gcc/config/aarch64/host-aarch64-darwin.c
+new file mode 100644
+index 00000000000..1a2cd4c9dab
+--- /dev/null
++++ b/gcc/config/aarch64/host-aarch64-darwin.c
+@@ -0,0 +1,32 @@
++/* Arm64-darwin host-specific hook definitions.
++ Copyright (C) 2020 Free Software Foundation, Inc.
++
++This file is part of GCC.
++
++GCC is free software; you can redistribute it and/or modify it under
++the terms of the GNU General Public License as published by the Free
++Software Foundation; either version 3, or (at your option) any later
++version.
++
++GCC is distributed in the hope that it will be useful, but WITHOUT ANY
++WARRANTY; without even the implied warranty of MERCHANTABILITY or
++FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
++for more details.
++
++You should have received a copy of the GNU General Public License
++along with GCC; see the file COPYING3. If not see
++<http://www.gnu.org/licenses/>. */
++
++#define IN_TARGET_CODE 1
++
++#include "config.h"
++#include "system.h"
++#include "coretypes.h"
++#include "hosthooks.h"
++#include "hosthooks-def.h"
++#include "config/host-darwin.h"
++
++/* Darwin doesn't do anything special for arm64/aarch64 hosts; this file
++ exists just to include the generic config/host-darwin.h. */
++
++const struct host_hooks host_hooks = HOST_HOOKS_INITIALIZER;
+diff --git a/gcc/config/aarch64/x-darwin b/gcc/config/aarch64/x-darwin
+new file mode 100644
+index 00000000000..6d788d5e89c
+--- /dev/null
++++ b/gcc/config/aarch64/x-darwin
+@@ -0,0 +1,3 @@
++host-aarch64-darwin.o : $(srcdir)/config/aarch64/host-aarch64-darwin.c
++ $(COMPILE) $<
++ $(POSTCOMPILE)
+--
+2.28.0
+
diff --git a/packages/gmp/6.2.0/chksum b/packages/gmp/6.2.0/chksum
deleted file mode 100644
index 5cc5bad..0000000
--- a/packages/gmp/6.2.0/chksum
+++ /dev/null
@@ -1,12 +0,0 @@
-md5 gmp-6.2.0.tar.xz a325e3f09e6d91e62101e59f9bda3ec1
-sha1 gmp-6.2.0.tar.xz 052a5411dc74054240eec58132d2cf41211d0ff6
-sha256 gmp-6.2.0.tar.xz 258e6cd51b3fbdfc185c716d55f82c08aff57df0c6fbd143cf6ed561267a1526
-sha512 gmp-6.2.0.tar.xz a066f0456f0314a1359f553c49fc2587e484ff8ac390ff88537266a146ea373f97a1c0ba24608bf6756f4eab11c9056f103c8deb99e5b57741b4f7f0ec44b90c
-md5 gmp-6.2.0.tar.lz e3e08ac185842a882204ba3c37985127
-sha1 gmp-6.2.0.tar.lz 93450c3197ab93173bf8f21c4e48c12814f4e8a3
-sha256 gmp-6.2.0.tar.lz 3f33f127bcb6b2c3601676cd3281df45824b148cbf688b73c0fc8248793667d9
-sha512 gmp-6.2.0.tar.lz 9975e8766e62a1d48c0b6d7bbdd2fccb5b22243819102ca6c8d91f0edd2d3a1cef21c526d647c2159bb29dd2a7dcbd0d621391b2e4b48662cf63a8e6749561cd
-md5 gmp-6.2.0.tar.bz2 c24161e0dd44cae78cd5f67193492a21
-sha1 gmp-6.2.0.tar.bz2 5e9341d3807bc7505376f9ed9f5c1c6c57050aa6
-sha256 gmp-6.2.0.tar.bz2 f51c99cb114deb21a60075ffb494c1a210eb9d7cb729ed042ddb7de9534451ea
-sha512 gmp-6.2.0.tar.bz2 ff22ed47fff176ed56301ecab0213316150a3abb370fed031635804f829c878296d7c65597b1f687f394479eef04fae6eba771162f7d363dc4c94c7334fc1fc0
diff --git a/packages/gmp/6.2.1/0000-Avoid-the-x18-register.patch b/packages/gmp/6.2.1/0000-Avoid-the-x18-register.patch
new file mode 100644
index 0000000..5c1c232
--- /dev/null
+++ b/packages/gmp/6.2.1/0000-Avoid-the-x18-register.patch
@@ -0,0 +1,520 @@
+# HG changeset patch
+# User Torbjorn Granlund <tg@gmplib.org>
+# Date 1606687643 -3600
+# Sun Nov 29 23:07:23 2020 +0100
+# Node ID f4ff6ff711edd8ff92f7d44d4994dbb223cbdc47
+# Parent 63bce6cacb48d9a1ade560db5f6e5da073969a09
+Avoid the x18 register since it is reserved on Darwin.
+
+diff -r 63bce6cacb48 -r f4ff6ff711ed mpn/arm64/aors_n.asm
+--- a/mpn/arm64/aors_n.asm Sun Nov 15 10:25:36 2020 +0100
++++ b/mpn/arm64/aors_n.asm Sun Nov 29 23:07:23 2020 +0100
+@@ -68,7 +68,7 @@
+ EPILOGUE()
+ PROLOGUE(func_n)
+ CLRCY
+-L(ent): lsr x18, n, #2
++L(ent): lsr x17, n, #2
+ tbz n, #0, L(bx0)
+
+ L(bx1): ldr x7, [up]
+@@ -77,7 +77,7 @@
+ str x13, [rp],#8
+ tbnz n, #1, L(b11)
+
+-L(b01): cbz x18, L(ret)
++L(b01): cbz x17, L(ret)
+ ldp x4, x5, [up,#8]
+ ldp x8, x9, [vp,#8]
+ sub up, up, #8
+@@ -88,7 +88,7 @@
+ ldp x10, x11, [vp,#8]
+ add up, up, #8
+ add vp, vp, #8
+- cbz x18, L(end)
++ cbz x17, L(end)
+ b L(top)
+
+ L(bx0): tbnz n, #1, L(b10)
+@@ -101,7 +101,7 @@
+
+ L(b10): ldp x6, x7, [up]
+ ldp x10, x11, [vp]
+- cbz x18, L(end)
++ cbz x17, L(end)
+
+ ALIGN(16)
+ L(top): ldp x4, x5, [up,#16]
+@@ -114,8 +114,8 @@
+ ADDSUBC x12, x4, x8
+ ADDSUBC x13, x5, x9
+ stp x12, x13, [rp],#16
+- sub x18, x18, #1
+- cbnz x18, L(top)
++ sub x17, x17, #1
++ cbnz x17, L(top)
+
+ L(end): ADDSUBC x12, x6, x10
+ ADDSUBC x13, x7, x11
+diff -r 63bce6cacb48 -r f4ff6ff711ed mpn/arm64/aorsmul_1.asm
+--- a/mpn/arm64/aorsmul_1.asm Sun Nov 15 10:25:36 2020 +0100
++++ b/mpn/arm64/aorsmul_1.asm Sun Nov 29 23:07:23 2020 +0100
+@@ -32,10 +32,15 @@
+
+ include(`../config.m4')
+
+-C cycles/limb
+-C Cortex-A53 9.3-9.8
+-C Cortex-A57 7.0
+-C X-Gene 5.0
++C addmul_1 submul_1
++C cycles/limb cycles/limb
++C Cortex-A53 9.3-9.8 9.3-9.8
++C Cortex-A55 9.0-9.5 9.3-9.8
++C Cortex-A57 7 7
++C Cortex-A72
++C Cortex-A73 6 6
++C X-Gene 5 5
++C Apple M1 1.75 1.75
+
+ C NOTES
+ C * It is possible to keep the carry chain alive between the addition blocks
+diff -r 63bce6cacb48 -r f4ff6ff711ed mpn/arm64/aorsorrlshC_n.asm
+--- a/mpn/arm64/aorsorrlshC_n.asm Sun Nov 15 10:25:36 2020 +0100
++++ b/mpn/arm64/aorsorrlshC_n.asm Sun Nov 29 23:07:23 2020 +0100
+@@ -65,14 +65,14 @@
+
+ ASM_START()
+ PROLOGUE(func_n)
+- lsr x18, n, #2
++ lsr x6, n, #2
+ tbz n, #0, L(bx0)
+
+ L(bx1): ldr x5, [up]
+ tbnz n, #1, L(b11)
+
+ L(b01): ldr x11, [vp]
+- cbz x18, L(1)
++ cbz x6, L(1)
+ ldp x8, x9, [vp,#8]
+ lsl x13, x11, #LSH
+ ADDSUB( x15, x13, x5)
+@@ -94,7 +94,7 @@
+ ADDSUB( x17, x13, x5)
+ str x17, [rp],#8
+ sub up, up, #8
+- cbz x18, L(end)
++ cbz x6, L(end)
+ b L(top)
+
+ L(bx0): tbnz n, #1, L(b10)
+@@ -107,7 +107,7 @@
+ L(b10): CLRRCY( x9)
+ ldp x10, x11, [vp]
+ sub up, up, #16
+- cbz x18, L(end)
++ cbz x6, L(end)
+
+ ALIGN(16)
+ L(top): ldp x4, x5, [up,#16]
+@@ -124,8 +124,8 @@
+ ADDSUBC(x16, x12, x4)
+ ADDSUBC(x17, x13, x5)
+ stp x16, x17, [rp],#16
+- sub x18, x18, #1
+- cbnz x18, L(top)
++ sub x6, x6, #1
++ cbnz x6, L(top)
+
+ L(end): ldp x4, x5, [up,#16]
+ extr x12, x10, x9, #RSH
+diff -r 63bce6cacb48 -r f4ff6ff711ed mpn/arm64/cnd_aors_n.asm
+--- a/mpn/arm64/cnd_aors_n.asm Sun Nov 15 10:25:36 2020 +0100
++++ b/mpn/arm64/cnd_aors_n.asm Sun Nov 29 23:07:23 2020 +0100
+@@ -65,7 +65,7 @@
+
+ CLRCY
+
+- lsr x18, n, #2
++ lsr x17, n, #2
+ tbz n, #0, L(bx0)
+
+ L(bx1): ldr x13, [vp]
+@@ -75,7 +75,7 @@
+ str x9, [rp]
+ tbnz n, #1, L(b11)
+
+-L(b01): cbz x18, L(rt)
++L(b01): cbz x17, L(rt)
+ ldp x12, x13, [vp,#8]
+ ldp x10, x11, [up,#8]
+ sub up, up, #8
+@@ -86,7 +86,7 @@
+ L(b11): ldp x12, x13, [vp,#8]!
+ ldp x10, x11, [up,#8]!
+ sub rp, rp, #8
+- cbz x18, L(end)
++ cbz x17, L(end)
+ b L(top)
+
+ L(bx0): ldp x12, x13, [vp]
+@@ -99,7 +99,7 @@
+ b L(mid)
+
+ L(b10): sub rp, rp, #16
+- cbz x18, L(end)
++ cbz x17, L(end)
+
+ ALIGN(16)
+ L(top): bic x6, x12, cnd
+@@ -116,8 +116,8 @@
+ ADDSUBC x9, x11, x7
+ ldp x10, x11, [up,#32]!
+ stp x8, x9, [rp,#32]!
+- sub x18, x18, #1
+- cbnz x18, L(top)
++ sub x17, x17, #1
++ cbnz x17, L(top)
+
+ L(end): bic x6, x12, cnd
+ bic x7, x13, cnd
+diff -r 63bce6cacb48 -r f4ff6ff711ed mpn/arm64/logops_n.asm
+--- a/mpn/arm64/logops_n.asm Sun Nov 15 10:25:36 2020 +0100
++++ b/mpn/arm64/logops_n.asm Sun Nov 29 23:07:23 2020 +0100
+@@ -78,7 +78,7 @@
+
+ ASM_START()
+ PROLOGUE(func)
+- lsr x18, n, #2
++ lsr x17, n, #2
+ tbz n, #0, L(bx0)
+
+ L(bx1): ldr x7, [up]
+@@ -88,7 +88,7 @@
+ str x15, [rp],#8
+ tbnz n, #1, L(b11)
+
+-L(b01): cbz x18, L(ret)
++L(b01): cbz x17, L(ret)
+ ldp x4, x5, [up,#8]
+ ldp x8, x9, [vp,#8]
+ sub up, up, #8
+@@ -99,7 +99,7 @@
+ ldp x10, x11, [vp,#8]
+ add up, up, #8
+ add vp, vp, #8
+- cbz x18, L(end)
++ cbz x17, L(end)
+ b L(top)
+
+ L(bx0): tbnz n, #1, L(b10)
+@@ -110,7 +110,7 @@
+
+ L(b10): ldp x6, x7, [up]
+ ldp x10, x11, [vp]
+- cbz x18, L(end)
++ cbz x17, L(end)
+
+ ALIGN(16)
+ L(top): ldp x4, x5, [up,#16]
+@@ -127,8 +127,8 @@
+ POSTOP( x12)
+ POSTOP( x13)
+ stp x12, x13, [rp],#16
+- sub x18, x18, #1
+- cbnz x18, L(top)
++ sub x17, x17, #1
++ cbnz x17, L(top)
+
+ L(end): LOGOP( x12, x6, x10)
+ LOGOP( x13, x7, x11)
+diff -r 63bce6cacb48 -r f4ff6ff711ed mpn/arm64/lshift.asm
+--- a/mpn/arm64/lshift.asm Sun Nov 15 10:25:36 2020 +0100
++++ b/mpn/arm64/lshift.asm Sun Nov 29 23:07:23 2020 +0100
+@@ -61,7 +61,7 @@
+ add rp, rp_arg, n, lsl #3
+ add up, up, n, lsl #3
+ sub tnc, xzr, cnt
+- lsr x18, n, #2
++ lsr x17, n, #2
+ tbz n, #0, L(bx0)
+
+ L(bx1): ldr x4, [up,#-8]
+@@ -69,7 +69,7 @@
+
+ L(b01): NSHIFT x0, x4, tnc
+ PSHIFT x2, x4, cnt
+- cbnz x18, L(gt1)
++ cbnz x17, L(gt1)
+ str x2, [rp,#-8]
+ ret
+ L(gt1): ldp x4, x5, [up,#-24]
+@@ -89,7 +89,7 @@
+ PSHIFT x13, x5, cnt
+ NSHIFT x10, x4, tnc
+ PSHIFT x2, x4, cnt
+- cbnz x18, L(gt2)
++ cbnz x17, L(gt2)
+ orr x10, x10, x13
+ stp x2, x10, [rp,#-16]
+ ret
+@@ -123,11 +123,11 @@
+ orr x11, x12, x2
+ stp x10, x11, [rp,#-32]!
+ PSHIFT x2, x4, cnt
+-L(lo0): sub x18, x18, #1
++L(lo0): sub x17, x17, #1
+ L(lo3): NSHIFT x10, x6, tnc
+ PSHIFT x13, x7, cnt
+ NSHIFT x12, x7, tnc
+- cbnz x18, L(top)
++ cbnz x17, L(top)
+
+ L(end): orr x10, x10, x13
+ orr x11, x12, x2
+diff -r 63bce6cacb48 -r f4ff6ff711ed mpn/arm64/lshiftc.asm
+--- a/mpn/arm64/lshiftc.asm Sun Nov 15 10:25:36 2020 +0100
++++ b/mpn/arm64/lshiftc.asm Sun Nov 29 23:07:23 2020 +0100
+@@ -61,7 +61,7 @@
+ add rp, rp_arg, n, lsl #3
+ add up, up, n, lsl #3
+ sub tnc, xzr, cnt
+- lsr x18, n, #2
++ lsr x17, n, #2
+ tbz n, #0, L(bx0)
+
+ L(bx1): ldr x4, [up,#-8]
+@@ -69,7 +69,7 @@
+
+ L(b01): NSHIFT x0, x4, tnc
+ PSHIFT x2, x4, cnt
+- cbnz x18, L(gt1)
++ cbnz x17, L(gt1)
+ mvn x2, x2
+ str x2, [rp,#-8]
+ ret
+@@ -90,7 +90,7 @@
+ PSHIFT x13, x5, cnt
+ NSHIFT x10, x4, tnc
+ PSHIFT x2, x4, cnt
+- cbnz x18, L(gt2)
++ cbnz x17, L(gt2)
+ eon x10, x10, x13
+ mvn x2, x2
+ stp x2, x10, [rp,#-16]
+@@ -125,11 +125,11 @@
+ eon x11, x12, x2
+ stp x10, x11, [rp,#-32]!
+ PSHIFT x2, x4, cnt
+-L(lo0): sub x18, x18, #1
++L(lo0): sub x17, x17, #1
+ L(lo3): NSHIFT x10, x6, tnc
+ PSHIFT x13, x7, cnt
+ NSHIFT x12, x7, tnc
+- cbnz x18, L(top)
++ cbnz x17, L(top)
+
+ L(end): eon x10, x10, x13
+ eon x11, x12, x2
+diff -r 63bce6cacb48 -r f4ff6ff711ed mpn/arm64/mul_1.asm
+--- a/mpn/arm64/mul_1.asm Sun Nov 15 10:25:36 2020 +0100
++++ b/mpn/arm64/mul_1.asm Sun Nov 29 23:07:23 2020 +0100
+@@ -56,7 +56,7 @@
+
+ PROLOGUE(mpn_mul_1)
+ adds x4, xzr, xzr C clear register and cy flag
+-L(com): lsr x18, n, #2
++L(com): lsr x17, n, #2
+ tbnz n, #0, L(bx1)
+
+ L(bx0): mov x11, x4
+@@ -65,7 +65,7 @@
+ L(b10): ldp x4, x5, [up]
+ mul x8, x4, v0
+ umulh x10, x4, v0
+- cbz x18, L(2)
++ cbz x17, L(2)
+ ldp x6, x7, [up,#16]!
+ mul x9, x5, v0
+ b L(mid)-8
+@@ -80,7 +80,7 @@
+ str x9, [rp],#8
+ tbnz n, #1, L(b10)
+
+-L(b01): cbz x18, L(1)
++L(b01): cbz x17, L(1)
+
+ L(b00): ldp x6, x7, [up]
+ mul x8, x6, v0
+@@ -90,8 +90,8 @@
+ adcs x12, x8, x11
+ umulh x11, x7, v0
+ add rp, rp, #16
+- sub x18, x18, #1
+- cbz x18, L(end)
++ sub x17, x17, #1
++ cbz x17, L(end)
+
+ ALIGN(16)
+ L(top): mul x8, x4, v0
+@@ -110,8 +110,8 @@
+ stp x12, x13, [rp],#32
+ adcs x12, x8, x11
+ umulh x11, x7, v0
+- sub x18, x18, #1
+- cbnz x18, L(top)
++ sub x17, x17, #1
++ cbnz x17, L(top)
+
+ L(end): mul x8, x4, v0
+ adcs x13, x9, x10
+diff -r 63bce6cacb48 -r f4ff6ff711ed mpn/arm64/rsh1aors_n.asm
+--- a/mpn/arm64/rsh1aors_n.asm Sun Nov 15 10:25:36 2020 +0100
++++ b/mpn/arm64/rsh1aors_n.asm Sun Nov 29 23:07:23 2020 +0100
+@@ -59,7 +59,7 @@
+
+ ASM_START()
+ PROLOGUE(func_n)
+- lsr x18, n, #2
++ lsr x6, n, #2
+
+ tbz n, #0, L(bx0)
+
+@@ -69,7 +69,7 @@
+
+ L(b01): ADDSUB x13, x5, x9
+ and x10, x13, #1
+- cbz x18, L(1)
++ cbz x6, L(1)
+ ldp x4, x5, [up],#48
+ ldp x8, x9, [vp],#48
+ ADDSUBC x14, x4, x8
+@@ -80,8 +80,8 @@
+ ADDSUBC x12, x4, x8
+ ADDSUBC x13, x5, x9
+ str x17, [rp], #24
+- sub x18, x18, #1
+- cbz x18, L(end)
++ sub x6, x6, #1
++ cbz x6, L(end)
+ b L(top)
+
+ L(1): cset x14, COND
+@@ -97,7 +97,7 @@
+ ldp x8, x9, [vp],#32
+ ADDSUBC x12, x4, x8
+ ADDSUBC x13, x5, x9
+- cbz x18, L(3)
++ cbz x6, L(3)
+ ldp x4, x5, [up,#-16]
+ ldp x8, x9, [vp,#-16]
+ extr x17, x12, x15, #1
+@@ -117,7 +117,7 @@
+ ADDSUB x12, x4, x8
+ ADDSUBC x13, x5, x9
+ and x10, x12, #1
+- cbz x18, L(2)
++ cbz x6, L(2)
+ ldp x4, x5, [up,#-16]
+ ldp x8, x9, [vp,#-16]
+ ADDSUBC x14, x4, x8
+@@ -134,8 +134,8 @@
+ ADDSUBC x12, x4, x8
+ ADDSUBC x13, x5, x9
+ add rp, rp, #16
+- sub x18, x18, #1
+- cbz x18, L(end)
++ sub x6, x6, #1
++ cbz x6, L(end)
+
+ ALIGN(16)
+ L(top): ldp x4, x5, [up,#-16]
+@@ -152,8 +152,8 @@
+ ADDSUBC x12, x4, x8
+ ADDSUBC x13, x5, x9
+ stp x16, x17, [rp],#32
+- sub x18, x18, #1
+- cbnz x18, L(top)
++ sub x6, x6, #1
++ cbnz x6, L(top)
+
+ L(end): extr x16, x15, x14, #1
+ extr x17, x12, x15, #1
+diff -r 63bce6cacb48 -r f4ff6ff711ed mpn/arm64/rshift.asm
+--- a/mpn/arm64/rshift.asm Sun Nov 15 10:25:36 2020 +0100
++++ b/mpn/arm64/rshift.asm Sun Nov 29 23:07:23 2020 +0100
+@@ -60,7 +60,7 @@
+ PROLOGUE(mpn_rshift)
+ mov rp, rp_arg
+ sub tnc, xzr, cnt
+- lsr x18, n, #2
++ lsr x17, n, #2
+ tbz n, #0, L(bx0)
+
+ L(bx1): ldr x5, [up]
+@@ -68,7 +68,7 @@
+
+ L(b01): NSHIFT x0, x5, tnc
+ PSHIFT x2, x5, cnt
+- cbnz x18, L(gt1)
++ cbnz x17, L(gt1)
+ str x2, [rp]
+ ret
+ L(gt1): ldp x4, x5, [up,#8]
+@@ -89,7 +89,7 @@
+ PSHIFT x13, x4, cnt
+ NSHIFT x10, x5, tnc
+ PSHIFT x2, x5, cnt
+- cbnz x18, L(gt2)
++ cbnz x17, L(gt2)
+ orr x10, x10, x13
+ stp x10, x2, [rp]
+ ret
+@@ -121,11 +121,11 @@
+ orr x11, x12, x2
+ stp x11, x10, [rp,#32]!
+ PSHIFT x2, x5, cnt
+-L(lo0): sub x18, x18, #1
++L(lo0): sub x17, x17, #1
+ L(lo3): NSHIFT x10, x7, tnc
+ NSHIFT x12, x6, tnc
+ PSHIFT x13, x6, cnt
+- cbnz x18, L(top)
++ cbnz x17, L(top)
+
+ L(end): orr x10, x10, x13
+ orr x11, x12, x2
+diff -r 63bce6cacb48 -r f4ff6ff711ed mpn/arm64/sqr_diag_addlsh1.asm
+--- a/mpn/arm64/sqr_diag_addlsh1.asm Sun Nov 15 10:25:36 2020 +0100
++++ b/mpn/arm64/sqr_diag_addlsh1.asm Sun Nov 29 23:07:23 2020 +0100
+@@ -47,7 +47,7 @@
+ ASM_START()
+ PROLOGUE(mpn_sqr_diag_addlsh1)
+ ldr x15, [up],#8
+- lsr x18, n, #1
++ lsr x14, n, #1
+ tbz n, #0, L(bx0)
+
+ L(bx1): adds x7, xzr, xzr
+@@ -62,8 +62,8 @@
+ ldr x17, [up],#16
+ ldp x6, x7, [tp],#32
+ umulh x11, x15, x15
+- sub x18, x18, #1
+- cbz x18, L(end)
++ sub x14, x14, #1
++ cbz x14, L(end)
+
+ ALIGN(16)
+ L(top): extr x9, x6, x5, #63
+@@ -84,8 +84,8 @@
+ extr x8, x5, x4, #63
+ stp x12, x13, [rp],#16
+ adcs x12, x8, x10
+- sub x18, x18, #1
+- cbnz x18, L(top)
++ sub x14, x14, #1
++ cbnz x14, L(top)
+
+ L(end): extr x9, x6, x5, #63
+ mul x10, x17, x17
diff --git a/packages/gmp/6.2.1/chksum b/packages/gmp/6.2.1/chksum
new file mode 100644
index 0000000..259a4b0
--- /dev/null
+++ b/packages/gmp/6.2.1/chksum
@@ -0,0 +1,8 @@
+md5 gmp-6.2.1.tar.xz 0b82665c4a92fd2ade7440c13fcaa42b
+sha1 gmp-6.2.1.tar.xz 0578d48607ec0e272177d175fd1807c30b00fdf2
+sha256 gmp-6.2.1.tar.xz fd4829912cddd12f84181c3451cc752be224643e87fac497b69edddadc49b4f2
+sha512 gmp-6.2.1.tar.xz c99be0950a1d05a0297d65641dd35b75b74466f7bf03c9e8a99895a3b2f9a0856cd17887738fa51cf7499781b65c049769271cbcb77d057d2e9f1ec52e07dd84
+md5 gmp-6.2.1.tar.lz 03a31d8cbaf29d136252f8f38875ed82
+sha1 gmp-6.2.1.tar.lz a035e45cb4fdb192074a46c6dd4dbe16ce3cf2a9
+sha256 gmp-6.2.1.tar.lz 2c7f4f0d370801b2849c48c9ef3f59553b5f1d3791d070cffb04599f9fc67b41
+sha512 gmp-6.2.1.tar.lz 40e1c80d1a2eda0ea190ba2a27e7bfe718ee1fc685082b4f2251f108ffbec94272199b35cf6df217c9f6f10ac4132eaf3c5014a9e25db0592b94f7f1ddd4994f
diff --git a/packages/gmp/6.2.0/version.desc b/packages/gmp/6.2.1/version.desc
index e69de29..e69de29 100644
--- a/packages/gmp/6.2.0/version.desc
+++ b/packages/gmp/6.2.1/version.desc