Skip to content

Commit e8eb28f

Browse files
authored
ios simulator arm64 and arm64e support (#1086)
* Adding support for iphonesimulator arm64 architecture for m1 arm64 based simulator and optional parameter for deployment target
1 parent 0a6b18f commit e8eb28f

File tree

3 files changed

+28
-19
lines changed

3 files changed

+28
-19
lines changed

CMakeLists.txt

+13-10
Original file line numberDiff line numberDiff line change
@@ -26,6 +26,9 @@ if(APPLE)
2626
# iOS build options
2727
option(BUILD_IOS "Build for iOS" NO)
2828
option(FORCE_RESET_OSX_DEPLOYMENT_TARGET "Clear the OSX Deployment Target Set" YES)
29+
if (DEFINED FORCE_RESET_DEPLOYMENT_TARGET)
30+
set(FORCE_RESET_OSX_DEPLOYMENT_TARGET ${FORCE_RESET_DEPLOYMENT_TARGET})
31+
endif()
2932

3033
if(BUILD_IOS)
3134
set(TARGET_ARCH "APPLE")
@@ -34,14 +37,14 @@ if(APPLE)
3437

3538
if(FORCE_RESET_OSX_DEPLOYMENT_TARGET)
3639
set(CMAKE_OSX_DEPLOYMENT_TARGET "" CACHE STRING "Force unset of the deployment target for iOS" FORCE)
37-
endif()
38-
39-
if((${IOS_PLAT} STREQUAL "iphonesimulator") AND (${IOS_ARCH} STREQUAL "arm64"))
40-
# iOS arm64 simulator is supported starting BigSur
41-
# Unfortunately, CMAKE produces a device binary (not simulator) when providing -miphoneos-version-min flag when building iOS arm64 simulator
42-
else()
43-
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -miphoneos-version-min=${IOS_DEPLOYMENT_TARGET}")
44-
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -miphoneos-version-min=${IOS_DEPLOYMENT_TARGET}")
40+
41+
if((${IOS_PLAT} STREQUAL "iphonesimulator") AND ((${IOS_ARCH} STREQUAL "arm64") OR (${IOS_ARCH} STREQUAL "arm64e")))
42+
# iOS arm64 simulator is supported starting BigSur
43+
# Unfortunately, CMAKE produces a device binary (not simulator) when providing -miphoneos-version-min flag when building iOS arm64 simulator
44+
else()
45+
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -miphoneos-version-min=${IOS_DEPLOYMENT_TARGET}")
46+
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -miphoneos-version-min=${IOS_DEPLOYMENT_TARGET}")
47+
endif()
4548
endif()
4649

4750
if((${IOS_PLAT} STREQUAL "iphoneos") OR (${IOS_PLAT} STREQUAL "iphonesimulator"))
@@ -54,12 +57,12 @@ if(APPLE)
5457
set(IOS_PLATFORM "iphonesimulator")
5558
set(CMAKE_SYSTEM_PROCESSOR x86_64)
5659
elseif(${IOS_ARCH} STREQUAL "arm64")
57-
set(IOS_PLATFORM "iphoneos")
60+
set(IOS_PLATFORM ${IOS_PLAT})
5861
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -arch arm64")
5962
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -arch arm64")
6063
set(CMAKE_SYSTEM_PROCESSOR arm64)
6164
elseif(${IOS_ARCH} STREQUAL "arm64e")
62-
set(IOS_PLATFORM "iphoneos")
65+
set(IOS_PLATFORM ${IOS_PLAT})
6366
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -arch arm64e")
6467
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -arch arm64e")
6568
set(CMAKE_SYSTEM_PROCESSOR arm64e)

build-ios.sh

+11-3
Original file line numberDiff line numberDiff line change
@@ -23,14 +23,22 @@ IOS_ARCH="x86_64"
2323
fi
2424

2525
# Set Platform: device or simulator
26-
if [ "$2" == "device" ] || [ "$3" == "device" ]; then
26+
if [ "$2" == "device" ] || [ "$3" == "device" ] || [ "$4" == "device" ]; then
2727
IOS_PLAT="iphoneos"
2828
else
2929
IOS_PLAT="iphonesimulator"
3030
fi
3131

3232
# Set target iOS minver
33-
IOS_DEPLOYMENT_TARGET=10.0
33+
default_ios_target=10.0
34+
if [ -z $IOS_DEPLOYMENT_TARGET ]; then
35+
export IOS_DEPLOYMENT_TARGET=${default_ios_target}
36+
export FORCE_RESET_DEPLOYMENT_TARGET=YES
37+
else
38+
export FORCE_RESET_DEPLOYMENT_TARGET=NO
39+
fi
40+
echo "ios deployment target="$IOS_DEPLOYMENT_TARGET
41+
echo "force reset deployment target="$FORCE_RESET_DEPLOYMENT_TARGET
3442

3543
# Install build tools and recent sqlite3
3644
FILE=.buildtools
@@ -54,7 +62,7 @@ cd out
5462

5563
CMAKE_PACKAGE_TYPE=tgz
5664

57-
cmake_cmd="cmake -DBUILD_IOS=YES -DIOS_ARCH=$IOS_ARCH -DIOS_PLAT=$IOS_PLAT -DIOS_DEPLOYMENT_TARGET=$IOS_DEPLOYMENT_TARGET -DBUILD_UNIT_TESTS=YES -DBUILD_FUNC_TESTS=YES -DCMAKE_BUILD_TYPE=$BUILD_TYPE -DCMAKE_PACKAGE_TYPE=$CMAKE_PACKAGE_TYPE $CMAKE_OPTS .."
65+
cmake_cmd="cmake -DCMAKE_OSX_SYSROOT=$IOS_PLAT -DCMAKE_SYSTEM_NAME=iOS -DCMAKE_IOS_ARCH_ABI=$IOS_ARCH -DCMAKE_OSX_DEPLOYMENT_TARGET=$IOS_DEPLOYMENT_TARGET -DBUILD_IOS=YES -DIOS_ARCH=$IOS_ARCH -DIOS_PLAT=$IOS_PLAT -DIOS_DEPLOYMENT_TARGET=$IOS_DEPLOYMENT_TARGET -DBUILD_UNIT_TESTS=YES -DBUILD_FUNC_TESTS=YES -DCMAKE_BUILD_TYPE=$BUILD_TYPE -DCMAKE_PACKAGE_TYPE=$CMAKE_PACKAGE_TYPE -DFORCE_RESET_DEPLOYMENT_TARGET=$FORCE_RESET_DEPLOYMENT_TARGET $CMAKE_OPTS .."
5866
echo $cmake_cmd
5967
eval $cmake_cmd
6068

build.sh

+4-6
Original file line numberDiff line numberDiff line change
@@ -70,6 +70,7 @@ while getopts "h?vl:D:" opt; do
7070
echo "Environment variables: "
7171
echo "CMAKE_OPTS - any additional cmake options. "
7272
echo "GIT_PULL_TOKEN - authorization token for Microsoft-proprietary modules. "
73+
echo "MACOSX_DEPLOYMENT_TARGET - optional parameter for setting macosx deployment target "
7374
echo "Plus any other environment variables respected by CMake build system. "
7475
exit 0
7576
;;
@@ -91,12 +92,9 @@ if [ "$LINK_TYPE" == "shared" ]; then
9192
fi
9293

9394
# Set target MacOS minver
94-
if [ "$MAC_ARCH" == "arm64" ]; then
95-
export MACOSX_DEPLOYMENT_TARGET=11.10
96-
else
97-
export MACOSX_DEPLOYMENT_TARGET=10.10
98-
fi
99-
95+
default_mac_os_target=$([ "$MAC_ARCH" == "arm64" ] && echo "11.10" || echo "10.10")
96+
[ -z $MACOSX_DEPLOYMENT_TARGET ] && export MACOSX_DEPLOYMENT_TARGET=${default_mac_os_target}
97+
echo "macosx deployment target="$MACOSX_DEPLOYMENT_TARGET
10098

10199
# Install build tools and recent sqlite3
102100
FILE=.buildtools

0 commit comments

Comments
 (0)