Skip to content

Commit

Permalink
Patch to allow compiling for iOS simulator on Apple Silicon
Browse files Browse the repository at this point in the history
From https://gist.github.com/indragiek/e14162c0098d97ee976bceae9441f04d#file-ios_sim_arm64-patch

Referenced at bazelbuild/rules_apple#980

To build:
bazel build ... --cpu=ios_sim_arm64 --apple_platform_type=ios
  • Loading branch information
kjteske committed Jun 4, 2021
1 parent c4975ef commit f38f620
Show file tree
Hide file tree
Showing 3 changed files with 126 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ public enum ApplePlatform implements ApplePlatformApi {
CATALYST("catalyst", "MacOSX", PlatformType.CATALYST, true);

private static final ImmutableSet<String> IOS_SIMULATOR_TARGET_CPUS =
ImmutableSet.of("ios_x86_64", "ios_i386");
ImmutableSet.of("ios_x86_64", "ios_i386", "ios_sim_arm64");
private static final ImmutableSet<String> IOS_DEVICE_TARGET_CPUS =
ImmutableSet.of("ios_armv6", "ios_arm64", "ios_armv7", "ios_armv7s", "ios_arm64e");
private static final ImmutableSet<String> WATCHOS_SIMULATOR_TARGET_CPUS =
Expand Down
124 changes: 123 additions & 1 deletion tools/osx/crosstool/cc_toolchain_config.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -63,6 +63,8 @@ def _impl(ctx):
toolchain_identifier = "darwin_arm64e"
elif (ctx.attr.cpu == "ios_arm64"):
toolchain_identifier = "ios_arm64"
elif (ctx.attr.cpu == "ios_sim_arm64"):
toolchain_identifier = "ios_sim_arm64"
elif (ctx.attr.cpu == "ios_arm64e"):
toolchain_identifier = "ios_arm64e"
elif (ctx.attr.cpu == "ios_armv7"):
Expand Down Expand Up @@ -94,6 +96,7 @@ def _impl(ctx):
ctx.attr.cpu == "darwin_arm64" or
ctx.attr.cpu == "darwin_arm64e" or
ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "ios_arm64e" or
ctx.attr.cpu == "ios_armv7" or
ctx.attr.cpu == "ios_i386" or
Expand All @@ -110,6 +113,8 @@ def _impl(ctx):

if (ctx.attr.cpu == "ios_arm64"):
target_system_name = "arm64-apple-ios"
elif (ctx.attr.cpu == "ios_sim_arm64"):
target_system_name = "arm64-apple-ios-simulator"
elif (ctx.attr.cpu == "tvos_arm64"):
target_system_name = "arm64-apple-tvos"
elif (ctx.attr.cpu == "watchos_arm64_32"):
Expand Down Expand Up @@ -151,6 +156,8 @@ def _impl(ctx):
target_cpu = "darwin_arm64e"
elif (ctx.attr.cpu == "ios_arm64"):
target_cpu = "ios_arm64"
elif (ctx.attr.cpu == "ios_sim_arm64"):
target_cpu = "ios_sim_arm64"
elif (ctx.attr.cpu == "ios_arm64e"):
target_cpu = "ios_arm64e"
elif (ctx.attr.cpu == "ios_armv7"):
Expand All @@ -177,6 +184,7 @@ def _impl(ctx):
if (ctx.attr.cpu == "armeabi-v7a"):
target_libc = "armeabi-v7a"
elif (ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "ios_arm64e" or
ctx.attr.cpu == "ios_armv7" or
ctx.attr.cpu == "ios_i386" or
Expand Down Expand Up @@ -206,6 +214,7 @@ def _impl(ctx):
elif (ctx.attr.cpu == "darwin_arm64" or
ctx.attr.cpu == "darwin_arm64e" or
ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "ios_arm64e" or
ctx.attr.cpu == "ios_armv7" or
ctx.attr.cpu == "ios_i386" or
Expand All @@ -227,6 +236,7 @@ def _impl(ctx):
elif (ctx.attr.cpu == "darwin_arm64" or
ctx.attr.cpu == "darwin_arm64e" or
ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "ios_arm64e" or
ctx.attr.cpu == "ios_armv7" or
ctx.attr.cpu == "ios_i386" or
Expand Down Expand Up @@ -343,6 +353,7 @@ def _impl(ctx):
ctx.attr.cpu == "darwin_arm64" or
ctx.attr.cpu == "darwin_arm64e" or
ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "ios_arm64e" or
ctx.attr.cpu == "ios_armv7" or
ctx.attr.cpu == "ios_i386" or
Expand Down Expand Up @@ -474,6 +485,39 @@ def _impl(ctx):
),
],
)
elif (ctx.attr.cpu == "ios_sim_arm64"):
objc_compile_action = action_config(
action_name = ACTION_NAMES.objc_compile,
flag_sets = [
flag_set(
flag_groups = [flag_group(flags = ["-arch", "arm64"])],
),
],
implies = [
"compiler_input_flags",
"compiler_output_flags",
"objc_actions",
"apply_default_compiler_flags",
"apply_default_warnings",
"framework_paths",
"preprocessor_defines",
"include_system_dirs",
"version_min",
"objc_arc",
"no_objc_arc",
"apple_env",
"user_compile_flags",
"sysroot",
"unfiltered_compile_flags",
"apply_simulator_compiler_flags",
],
tools = [
tool(
path = "wrapped_clang",
execution_requirements = xcode_execution_requirements,
),
],
)
elif (ctx.attr.cpu == "ios_arm64e" or
ctx.attr.cpu == "darwin_arm64e"):
objc_compile_action = action_config(
Expand Down Expand Up @@ -800,6 +844,7 @@ def _impl(ctx):
],
)
elif (ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "tvos_arm64" or
ctx.attr.cpu == "darwin_arm64"):
objcpp_executable_action = action_config(
Expand Down Expand Up @@ -1213,6 +1258,7 @@ def _impl(ctx):
ctx.attr.cpu == "darwin_arm64" or
ctx.attr.cpu == "darwin_arm64e" or
ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "ios_arm64e" or
ctx.attr.cpu == "ios_armv7" or
ctx.attr.cpu == "ios_i386" or
Expand Down Expand Up @@ -1295,6 +1341,7 @@ def _impl(ctx):
ctx.attr.cpu == "darwin_arm64" or
ctx.attr.cpu == "darwin_arm64e" or
ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "ios_arm64e" or
ctx.attr.cpu == "ios_armv7" or
ctx.attr.cpu == "ios_i386" or
Expand Down Expand Up @@ -1358,6 +1405,7 @@ def _impl(ctx):
ctx.attr.cpu == "darwin_arm64" or
ctx.attr.cpu == "darwin_arm64e" or
ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "ios_arm64e" or
ctx.attr.cpu == "ios_armv7" or
ctx.attr.cpu == "ios_i386" or
Expand Down Expand Up @@ -1472,6 +1520,7 @@ def _impl(ctx):
],
)
elif (ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "tvos_arm64" or
ctx.attr.cpu == "darwin_arm64"):
objcpp_compile_action = action_config(
Expand Down Expand Up @@ -1755,6 +1804,7 @@ def _impl(ctx):
ctx.attr.cpu == "darwin_arm64" or
ctx.attr.cpu == "darwin_arm64e" or
ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "ios_arm64e" or
ctx.attr.cpu == "ios_armv7" or
ctx.attr.cpu == "ios_i386" or
Expand Down Expand Up @@ -1816,6 +1866,7 @@ def _impl(ctx):
ctx.attr.cpu == "darwin_arm64" or
ctx.attr.cpu == "darwin_arm64e" or
ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "ios_arm64e" or
ctx.attr.cpu == "ios_armv7" or
ctx.attr.cpu == "ios_i386" or
Expand Down Expand Up @@ -1912,6 +1963,7 @@ def _impl(ctx):
],
)
elif (ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "tvos_arm64" or
ctx.attr.cpu == "darwin_arm64"):
objc_archive_action = action_config(
Expand Down Expand Up @@ -2240,6 +2292,7 @@ def _impl(ctx):
],
)
elif (ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "tvos_arm64" or
ctx.attr.cpu == "darwin_arm64"):
objc_executable_action = action_config(
Expand Down Expand Up @@ -2676,6 +2729,7 @@ def _impl(ctx):
ctx.attr.cpu == "darwin_arm64" or
ctx.attr.cpu == "darwin_arm64e" or
ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "ios_arm64e" or
ctx.attr.cpu == "ios_armv7" or
ctx.attr.cpu == "ios_i386" or
Expand Down Expand Up @@ -2763,6 +2817,7 @@ def _impl(ctx):
ctx.attr.cpu == "darwin_arm64" or
ctx.attr.cpu == "darwin_arm64e" or
ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "ios_arm64e" or
ctx.attr.cpu == "ios_armv7" or
ctx.attr.cpu == "ios_i386" or
Expand Down Expand Up @@ -2828,6 +2883,7 @@ def _impl(ctx):
ctx.attr.cpu == "darwin_arm64" or
ctx.attr.cpu == "darwin_arm64e" or
ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "ios_arm64e" or
ctx.attr.cpu == "ios_armv7" or
ctx.attr.cpu == "ios_i386" or
Expand Down Expand Up @@ -2946,6 +3002,7 @@ def _impl(ctx):
],
)
elif (ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "tvos_arm64"):
objc_fully_link_action = action_config(
action_name = "objc-fully-link",
Expand Down Expand Up @@ -3211,6 +3268,7 @@ def _impl(ctx):
ctx.attr.cpu == "darwin_arm64" or
ctx.attr.cpu == "darwin_arm64e" or
ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "ios_arm64e" or
ctx.attr.cpu == "ios_armv7" or
ctx.attr.cpu == "ios_i386" or
Expand Down Expand Up @@ -3253,6 +3311,7 @@ def _impl(ctx):

if (ctx.attr.cpu == "armeabi-v7a" or
ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "ios_arm64e" or
ctx.attr.cpu == "ios_armv7" or
ctx.attr.cpu == "ios_i386" or
Expand Down Expand Up @@ -3409,6 +3468,7 @@ def _impl(ctx):
ctx.attr.cpu == "darwin_arm64" or
ctx.attr.cpu == "darwin_arm64e" or
ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "ios_arm64e" or
ctx.attr.cpu == "ios_armv7" or
ctx.attr.cpu == "ios_i386" or
Expand Down Expand Up @@ -3504,6 +3564,7 @@ def _impl(ctx):
ctx.attr.cpu == "darwin_arm64" or
ctx.attr.cpu == "darwin_arm64e" or
ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "ios_arm64e" or
ctx.attr.cpu == "ios_armv7" or
ctx.attr.cpu == "tvos_arm64" or
Expand Down Expand Up @@ -3554,6 +3615,7 @@ def _impl(ctx):

if (ctx.attr.cpu == "armeabi-v7a" or
ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "ios_arm64e" or
ctx.attr.cpu == "ios_armv7" or
ctx.attr.cpu == "ios_i386" or
Expand Down Expand Up @@ -3681,6 +3743,26 @@ def _impl(ctx):
),
],
)
elif (ctx.attr.cpu == "ios_sim_arm64"):
default_link_flags_feature = feature(
name = "default_link_flags",
enabled = True,
flag_sets = [
flag_set(
actions = all_link_actions +
["objc-executable", "objc++-executable"],
flag_groups = [
flag_group(
flags = [
"-no-canonical-prefixes",
"-target",
"arm64-apple-ios-simulator",
],
),
],
),
],
)
elif (ctx.attr.cpu == "tvos_arm64"):
default_link_flags_feature = feature(
name = "default_link_flags",
Expand Down Expand Up @@ -4055,7 +4137,8 @@ def _impl(ctx):
# This stub doesn't have a sensible value for this feature
version_min_feature = feature(name = "version_min")
elif (ctx.attr.cpu == "ios_i386" or
ctx.attr.cpu == "ios_x86_64"):
ctx.attr.cpu == "ios_x86_64" or
ctx.attr.cpu == "ios_sim_arm64"):
version_min_feature = feature(
name = "version_min",
flag_sets = [
Expand Down Expand Up @@ -4566,6 +4649,7 @@ def _impl(ctx):

if (ctx.attr.cpu == "armeabi-v7a" or
ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "ios_arm64e" or
ctx.attr.cpu == "ios_armv7" or
ctx.attr.cpu == "ios_i386" or
Expand Down Expand Up @@ -4793,6 +4877,37 @@ def _impl(ctx):
),
],
)
elif (ctx.attr.cpu == "ios_sim_arm64"):
unfiltered_compile_flags_feature = feature(
name = "unfiltered_compile_flags",
flag_sets = [
flag_set(
actions = [
ACTION_NAMES.assemble,
ACTION_NAMES.preprocess_assemble,
ACTION_NAMES.c_compile,
ACTION_NAMES.cpp_compile,
ACTION_NAMES.cpp_header_parsing,
ACTION_NAMES.cpp_module_compile,
ACTION_NAMES.cpp_module_codegen,
ACTION_NAMES.linkstamp_compile,
],
flag_groups = [
flag_group(
flags = [
"-no-canonical-prefixes",
"-Wno-builtin-macro-redefined",
"-D__DATE__=\"redacted\"",
"-D__TIMESTAMP__=\"redacted\"",
"-D__TIME__=\"redacted\"",
"-target",
"arm64-apple-ios-simulator",
],
),
],
),
],
)
elif (ctx.attr.cpu == "tvos_arm64"):
unfiltered_compile_flags_feature = feature(
name = "unfiltered_compile_flags",
Expand Down Expand Up @@ -5371,6 +5486,7 @@ def _impl(ctx):
ctx.attr.cpu == "darwin_arm64" or
ctx.attr.cpu == "darwin_arm64e" or
ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "ios_arm64e" or
ctx.attr.cpu == "ios_armv7" or
ctx.attr.cpu == "ios_i386" or
Expand Down Expand Up @@ -5625,6 +5741,7 @@ def _impl(ctx):
ctx.attr.cpu == "darwin_arm64" or
ctx.attr.cpu == "darwin_arm64e" or
ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "ios_armv7" or
ctx.attr.cpu == "ios_i386" or
ctx.attr.cpu == "ios_x86_64" or
Expand Down Expand Up @@ -5857,6 +5974,7 @@ def _impl(ctx):
elif (ctx.attr.cpu == "armeabi-v7a" or
ctx.attr.cpu == "darwin_arm64" or
ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "ios_arm64e" or
ctx.attr.cpu == "ios_armv7" or
ctx.attr.cpu == "ios_i386" or
Expand Down Expand Up @@ -5988,6 +6106,7 @@ def _impl(ctx):
)
elif (ctx.attr.cpu == "armeabi-v7a" or
ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "ios_arm64e" or
ctx.attr.cpu == "ios_armv7" or
ctx.attr.cpu == "ios_i386" or
Expand Down Expand Up @@ -6048,6 +6167,7 @@ def _impl(ctx):
)

if (ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "ios_arm64e" or
ctx.attr.cpu == "ios_armv7" or
ctx.attr.cpu == "tvos_arm64" or
Expand Down Expand Up @@ -6296,6 +6416,7 @@ def _impl(ctx):
)

if (ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "ios_arm64e" or
ctx.attr.cpu == "ios_armv7" or
ctx.attr.cpu == "ios_i386" or
Expand Down Expand Up @@ -6581,6 +6702,7 @@ def _impl(ctx):
ctx.attr.cpu == "darwin_arm64" or
ctx.attr.cpu == "darwin_arm64e" or
ctx.attr.cpu == "ios_arm64" or
ctx.attr.cpu == "ios_sim_arm64" or
ctx.attr.cpu == "ios_arm64e" or
ctx.attr.cpu == "ios_armv7" or
ctx.attr.cpu == "ios_i386" or
Expand Down
Loading

0 comments on commit f38f620

Please sign in to comment.