From 4dfe254edcafeb755ae6c37d1f9c00d8e2f2b2b3 Mon Sep 17 00:00:00 2001 From: rami3l Date: Mon, 14 Aug 2023 11:54:40 +0800 Subject: [PATCH] macOS `uname -m` can lie due to Rosetta shenanigans Fix originally provided in https://github.com/JuliaLang/juliaup/pull/701 --- rustup-init.sh | 17 +++++++++++++---- 1 file changed, 13 insertions(+), 4 deletions(-) diff --git a/rustup-init.sh b/rustup-init.sh index ddc99f2472..7e8de44ea5 100755 --- a/rustup-init.sh +++ b/rustup-init.sh @@ -255,10 +255,19 @@ get_architecture() { fi fi - if [ "$_ostype" = Darwin ] && [ "$_cputype" = i386 ]; then - # Darwin `uname -m` lies - if sysctl hw.optional.x86_64 | grep -q ': 1'; then - _cputype=x86_64 + if [ "$_ostype" = Darwin ]; then + # Darwin `uname -m` can lie due to Rosetta shenanigans. If you manage to + # invoke a native shell binary and then a native uname binary, you can + # get the real answer, but that's hard to ensure, so instead we use + # `sysctl` (which doesn't lie) to check for the actual architecture. + if [ "$_cputype" = i386 ]; then + if sysctl hw.optional.x86_64 | grep -q ': 1'; then + _cputype=x86_64 + fi + elif [ "$_cputype" = x86_64 ]; then + if sysctl hw.optional.arm64 | grep -q ': 1'; then + _cputype=arm64 + fi fi fi