From 67e6bbe391388c8a8c720e911043716a403828f8 Mon Sep 17 00:00:00 2001 From: Paco Wong Date: Wed, 16 Oct 2024 00:18:25 +0800 Subject: [PATCH 1/6] Add protobuf_cmake.patch --- cmake/patches/protobuf/protobuf_cmake.patch | 31 +++++++++++++++++++++ 1 file changed, 31 insertions(+) create mode 100644 cmake/patches/protobuf/protobuf_cmake.patch diff --git a/cmake/patches/protobuf/protobuf_cmake.patch b/cmake/patches/protobuf/protobuf_cmake.patch new file mode 100644 index 0000000000000..fe8bd25ab147a --- /dev/null +++ b/cmake/patches/protobuf/protobuf_cmake.patch @@ -0,0 +1,31 @@ +diff --git a/CMakeLists.txt b/CMakeLists.txt +index 04cb3303a..4025805cf 100644 +--- a/CMakeLists.txt ++++ b/CMakeLists.txt +@@ -249,9 +249,7 @@ if (MSVC) + # MSVC warning suppressions + add_definitions( + /wd4065 # switch statement contains 'default' but no 'case' labels +- /wd4244 # 'conversion' conversion from 'type1' to 'type2', possible loss of data + /wd4251 # 'identifier' : class 'type' needs to have dll-interface to be used by clients of class 'type2' +- /wd4267 # 'var' : conversion from 'size_t' to 'type', possible loss of data + /wd4305 # 'identifier' : truncation from 'type1' to 'type2' + /wd4307 # 'operator' : integral constant overflow + /wd4309 # 'conversion' : truncation of constant value +@@ -259,7 +257,6 @@ if (MSVC) + /wd4355 # 'this' : used in base member initializer list + /wd4506 # no definition for inline function 'function' + /wd4800 # 'type' : forcing value to bool 'true' or 'false' (performance warning) +- /wd4996 # The compiler encountered a deprecated declaration. + ) + # Allow big object + add_definitions(/bigobj) +@@ -289,7 +286,7 @@ if (MSVC) + else (MSVC) + # No version.rc file. + set(protobuf_version_rc_file) +- ++ set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-parameter") + # When building with "make", "lib" prefix will be added automatically by + # the build tool. + set(LIB_PREFIX) From 0475018548f13339c44e73dfbdc8de595fc27f0b Mon Sep 17 00:00:00 2001 From: Paco Wong Date: Wed, 16 Oct 2024 00:24:38 +0800 Subject: [PATCH 2/6] Remove legacy build_macabi_framework.py --- .../github/apple/build_macabi_framework.py | 226 ------------------ 1 file changed, 226 deletions(-) delete mode 100644 tools/ci_build/github/apple/build_macabi_framework.py diff --git a/tools/ci_build/github/apple/build_macabi_framework.py b/tools/ci_build/github/apple/build_macabi_framework.py deleted file mode 100644 index 61e9d01f9ec02..0000000000000 --- a/tools/ci_build/github/apple/build_macabi_framework.py +++ /dev/null @@ -1,226 +0,0 @@ -#!/usr/bin/env python3 -# Copyright (c) Microsoft Corporation. All rights reserved. -# Licensed under the MIT License. - -import argparse -import glob -import json -import os -import pathlib -import shutil -import subprocess -import sys - -SCRIPT_DIR = os.path.dirname(os.path.realpath(__file__)) -REPO_DIR = os.path.normpath(os.path.join(SCRIPT_DIR, "..", "..", "..", "..")) -BUILD_PY = os.path.join(REPO_DIR, "tools", "ci_build", "build.py") - -# We by default will build below 3 archs -DEFAULT_BUILD_OSX_ARCHS = { - "macabi": ["arm64", "x86_64"], -} - -MACABI_IOS_SYSROOT = subprocess.run(['xcrun', '--sdk', 'macosx', '--show-sdk-path'], stdout=subprocess.PIPE).stdout.decode('utf-8').strip() - -def _parse_build_settings(args): - with open(args.build_settings_file.resolve()) as f: - build_settings_data = json.load(f) - - build_settings = {} - - build_settings["build_osx_archs"] = build_settings_data.get("build_osx_archs", DEFAULT_BUILD_OSX_ARCHS) - - build_params = [] - if "build_params" in build_settings_data: - build_params += build_settings_data["build_params"] - else: - raise ValueError("build_params is required in the build config file") - - build_settings["build_params"] = build_params - return build_settings - - -# Build fat framework for all archs of a single sysroot -# For example, arm64 and x86_64 for iphonesimulator -def _build_for_ios_sysroot( - build_config, intermediates_dir, base_build_command, sysroot, archs, build_dynamic_framework -): - # paths of the onnxruntime libraries for different archs - ort_libs = [] - info_plist_path = "" - - # Build binary for each arch, one by one - for current_arch in archs: - build_dir_current_arch = os.path.join(intermediates_dir, sysroot + "_" + current_arch) - build_command = base_build_command + [ - "--ios_sysroot=" + MACABI_IOS_SYSROOT, - "--osx_arch=" + current_arch, - "--build_dir=" + build_dir_current_arch, - ] - - # the actual build process for current arch - subprocess.run(build_command, shell=False, check=True, cwd=REPO_DIR) - print("Paco finished subprocess.run(build_command, shell=False, check=True, cwd=REPO_DIR)") - #exit(-1) - # get the compiled lib path - framework_dir = os.path.join( - build_dir_current_arch, - build_config, - # build_config + "-" + sysroot, - "onnxruntime.framework" - if build_dynamic_framework - else os.path.join("static_framework", "onnxruntime.framework"), - ) - ort_libs.append(os.path.join(framework_dir, "onnxruntime")) - - # We only need to copy Info.plist, framework_info.json, and headers once since they are the same - if not info_plist_path: - info_plist_path = os.path.join(build_dir_current_arch, build_config, "Info.plist") - framework_info_path = os.path.join(build_dir_current_arch, build_config, "framework_info.json") - headers = glob.glob(os.path.join(framework_dir, "Headers", "*.h")) - - # manually create the fat framework - framework_dir = os.path.join(intermediates_dir, "frameworks", sysroot, "onnxruntime.framework") - # remove the existing framework if any - if os.path.exists(framework_dir): - shutil.rmtree(framework_dir) - pathlib.Path(framework_dir).mkdir(parents=True, exist_ok=True) - - # copy the Info.plist, framework_info.json, and header files - shutil.copy(info_plist_path, framework_dir) - shutil.copy(framework_info_path, os.path.dirname(framework_dir)) - header_dir = os.path.join(framework_dir, "Headers") - pathlib.Path(header_dir).mkdir(parents=True, exist_ok=True) - for _header in headers: - shutil.copy(_header, header_dir) - - # use lipo to create a fat ort library - lipo_command = ["lipo", "-create"] - lipo_command += ort_libs - lipo_command += ["-output", os.path.join(framework_dir, "onnxruntime")] - subprocess.run(lipo_command, shell=False, check=True) - - return framework_dir - - -def _build_package(args): - build_settings = _parse_build_settings(args) - build_dir = os.path.abspath(args.build_dir) - - # Temp dirs to hold building results - intermediates_dir = os.path.join(build_dir, "intermediates") - build_config = args.config - base_build_command = [sys.executable, BUILD_PY] + build_settings["build_params"] + ["--config=" + build_config] - - if args.include_ops_by_config is not None: - base_build_command += ["--include_ops_by_config=" + str(args.include_ops_by_config.resolve())] - - if args.path_to_protoc_exe is not None: - base_build_command += ["--path_to_protoc_exe=" + str(args.path_to_protoc_exe.resolve())] - - print("In _build_package") - print(build_settings) - - # build framework for individual sysroot - framework_dirs = [] - framework_info_path = "" - public_headers_path = "" - for sysroot in build_settings["build_osx_archs"]: - framework_dir = _build_for_ios_sysroot( - build_config, - intermediates_dir, - base_build_command, - sysroot, - build_settings["build_osx_archs"][sysroot], - args.build_dynamic_framework, - ) - framework_dirs.append(framework_dir) - # podspec and headers for each sysroot are the same, pick one of them - if not framework_info_path: - framework_info_path = os.path.join(os.path.dirname(framework_dir), "framework_info.json") - public_headers_path = os.path.join(os.path.dirname(framework_dir), "onnxruntime.framework", "Headers") - - # create the folder for xcframework and copy the LICENSE and podspec file - xcframework_dir = os.path.join(build_dir, "framework_out") - pathlib.Path(xcframework_dir).mkdir(parents=True, exist_ok=True) - shutil.copy(os.path.join(REPO_DIR, "LICENSE"), xcframework_dir) - shutil.copytree(public_headers_path, os.path.join(xcframework_dir, "Headers"), dirs_exist_ok=True) - shutil.copy(framework_info_path, build_dir) - - # remove existing xcframework if any - xcframework_path = os.path.join(xcframework_dir, "onnxruntime.xcframework") - if os.path.exists(xcframework_path): - shutil.rmtree(xcframework_path) - - # Assemble the final xcframework - build_xcframework_cmd = ["xcrun", "xcodebuild", "-create-xcframework", "-output", xcframework_path] - for framework_dir in framework_dirs: - build_xcframework_cmd.extend(["-framework", framework_dir]) - - subprocess.run(build_xcframework_cmd, shell=False, check=True, cwd=REPO_DIR) - - -def parse_args(): - parser = argparse.ArgumentParser( - os.path.basename(__file__), - description="""Create iOS framework and podspec for one or more osx_archs (xcframework) - and building properties specified in the given build config file, see - tools/ci_build/github/apple/default_mobile_ios_framework_build_settings.json for details. - The output of the final xcframework and podspec can be found under [build_dir]/framework_out. - Please note, this building script will only work on macOS. - """, - ) - - parser.add_argument( - "--build_dir", - type=pathlib.Path, - default=os.path.join(REPO_DIR, "build/iOS_framework"), - help="Provide the root directory for build output", - ) - - parser.add_argument( - "--include_ops_by_config", - type=pathlib.Path, - help="Include ops from config file. See /docs/Reduced_Operator_Kernel_build.md for more information.", - ) - - parser.add_argument( - "--config", - type=str, - default="Release", - choices=["Debug", "MinSizeRel", "Release", "RelWithDebInfo"], - help="Configuration to build.", - ) - - parser.add_argument( - "--build_dynamic_framework", - action="store_true", - help="Build Dynamic Framework (default is build static framework).", - ) - - parser.add_argument( - "build_settings_file", type=pathlib.Path, help="Provide the file contains settings for building iOS framework" - ) - - parser.add_argument("--path_to_protoc_exe", type=pathlib.Path, help="Path to protoc exe.") - - args = parser.parse_args() - - if not args.build_settings_file.resolve().is_file(): - raise FileNotFoundError("Build config file {} is not a file.".format(args.build_settings_file.resolve())) - - if args.include_ops_by_config is not None: - include_ops_by_config_file = args.include_ops_by_config.resolve() - if not include_ops_by_config_file.is_file(): - raise FileNotFoundError("Include ops config file {} is not a file.".format(include_ops_by_config_file)) - - return args - - -def main(): - args = parse_args() - _build_package(args) - - -if __name__ == "__main__": - main() From a784f16bf86273ad342c2d1945aabe75b4ed12a1 Mon Sep 17 00:00:00 2001 From: Paco Wong Date: Wed, 16 Oct 2024 00:25:04 +0800 Subject: [PATCH 3/6] Remove legacy default_full_macabi_framework_build_settings.json --- ...lt_full_macabi_framework_build_settings.json | 17 ----------------- 1 file changed, 17 deletions(-) delete mode 100644 tools/ci_build/github/apple/default_full_macabi_framework_build_settings.json diff --git a/tools/ci_build/github/apple/default_full_macabi_framework_build_settings.json b/tools/ci_build/github/apple/default_full_macabi_framework_build_settings.json deleted file mode 100644 index ee9b6d1c0ccb9..0000000000000 --- a/tools/ci_build/github/apple/default_full_macabi_framework_build_settings.json +++ /dev/null @@ -1,17 +0,0 @@ -{ - "build_osx_archs": { - "macabi": [ - "arm64", - "x86_64" - ] - }, - "build_params": [ - "--macabi", - "--build_apple_framework", - "--use_coreml", - "--skip_tests", - "--config=Debug", - "--cmake_extra_defines=onnxruntime_BUILD_UNIT_TESTS=OFF", - "--apple_deploy_target=14.0" - ] -} From 2cdd6c2b1c8e52edbdf13054272093d2d776e35d Mon Sep 17 00:00:00 2001 From: Paco Wong Date: Wed, 16 Oct 2024 00:27:22 +0800 Subject: [PATCH 4/6] Update CMakeLists.txt --- cmake/CMakeLists.txt | 15 +-------------- 1 file changed, 1 insertion(+), 14 deletions(-) diff --git a/cmake/CMakeLists.txt b/cmake/CMakeLists.txt index be3ea67e041df..88c3e1d5c0b11 100644 --- a/cmake/CMakeLists.txt +++ b/cmake/CMakeLists.txt @@ -50,17 +50,6 @@ set_property(GLOBAL PROPERTY USE_FOLDERS ON) # NOTE: POSITION INDEPENDENT CODE hurts performance, and it only make sense on POSIX systems set(CMAKE_POSITION_INDEPENDENT_CODE ON) -#set(CMAKE_CXX_COMPILER "/usr/bin/clang++ --target=arm64-apple-macos14.0-macabi" ) #Paco -#set(CMAKE_C_COMPILER "/usr/bin/clang --target=arm64-apple-macos14.0-macabi" ) - -#set(CMAKE_CXX_FLAGS "--target=arm64-apple-macos14.0-macabi" ) #Paco -#set(CMAKE_C_FLAGS "--target=arm64-apple-macos14.0-macabi" ) - -# Suggested by https://gitlab.kitware.com/cmake/cmake/-/issues/20132 -# Because MacCatalyst does not support well in CMake -add_compile_options(-Wno-overriding-t-option) -add_link_options(-Wno-overriding-t-option) - # Enable CTest enable_testing() include(Dart) @@ -130,7 +119,7 @@ option(onnxruntime_DONT_VECTORIZE "Do not vectorize operations in Eigen" OFF) option(onnxruntime_USE_FULL_PROTOBUF "Link to libprotobuf instead of libprotobuf-lite when this option is ON" OFF) option(onnxruntime_ENABLE_LANGUAGE_INTEROP_OPS "Enable operator implemented in language other than cpp" OFF) -option(onnxruntime_DEBUG_NODE_INPUTS_OUTPUTS "Dump debug information about node inputs and outputs when executing the model." ON) +option(onnxruntime_DEBUG_NODE_INPUTS_OUTPUTS "Dump debug information about node inputs and outputs when executing the model." OFF) cmake_dependent_option(onnxruntime_DEBUG_NODE_INPUTS_OUTPUTS_ENABLE_DUMP_TO_SQLDB "Build dump debug information about node inputs and outputs with support for sql database." OFF "onnxruntime_DEBUG_NODE_INPUTS_OUTPUTS" OFF) option(onnxruntime_USE_DML "Build with DirectML support" OFF) option(onnxruntime_USE_MIGRAPHX "Build with AMDMIGraphX support" OFF) @@ -1661,8 +1650,6 @@ endif() #Now the 'onnxruntime_EXTERNAL_LIBRARIES' variable should be sealed. It will be used in onnxruntime.cmake which will be included in the next. #The order of the following targets matters. Right depends on left. If target A appears before target B. Then A.cmake can not use variables defined in B.cmake. set(ONNXRUNTIME_CMAKE_FILES onnxruntime_flatbuffers onnxruntime_common onnxruntime_mlas onnxruntime_graph onnxruntime_framework onnxruntime_util onnxruntime_providers onnxruntime_optimizer onnxruntime_session ${ONNXRUNTIME_EAGER_CMAKE_FILE_NAME}) -# set(ONNXRUNTIME_CMAKE_FILES onnxruntime_flatbuffers onnxruntime_common onnxruntime_mlas) #Paco to be disable -# set(ONNXRUNTIME_CMAKE_FILES onnxruntime_mlas) #Paco to be disable if (onnxruntime_USE_WINML) # WINML uses and depends on the shared lib. Note: You can build WINML without DML and you will get a From 24c4fe3de2ba71986298dd08d27af0caf2ab62dd Mon Sep 17 00:00:00 2001 From: Paco Wong Date: Wed, 16 Oct 2024 00:27:38 +0800 Subject: [PATCH 5/6] Update cmake dep --- cmake/adjust_global_compile_flags.cmake | 9 ++++----- cmake/deps.txt | 2 -- 2 files changed, 4 insertions(+), 7 deletions(-) diff --git a/cmake/adjust_global_compile_flags.cmake b/cmake/adjust_global_compile_flags.cmake index 0ff0b08dee76e..ae6fe3ac6ff33 100644 --- a/cmake/adjust_global_compile_flags.cmake +++ b/cmake/adjust_global_compile_flags.cmake @@ -19,11 +19,10 @@ endif() # Enable space optimization for gcc/clang # Cannot use "-ffunction-sections -fdata-sections" if we enable bitcode (iOS) -#TODO: Paco: need to find out onnxruntime_ENABLE_BITCODE turns ON even it is set to OFF -#if (NOT MSVC AND NOT onnxruntime_ENABLE_BITCODE) -# string(APPEND CMAKE_CXX_FLAGS " -ffunction-sections -fdata-sections") -# string(APPEND CMAKE_C_FLAGS " -ffunction-sections -fdata-sections") -#endif() +if (NOT MSVC AND NOT onnxruntime_ENABLE_BITCODE) + string(APPEND CMAKE_CXX_FLAGS " -ffunction-sections -fdata-sections") + string(APPEND CMAKE_C_FLAGS " -ffunction-sections -fdata-sections") +endif() if (CMAKE_SYSTEM_NAME STREQUAL "Emscripten") set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -s ALLOW_UNIMPLEMENTED_SYSCALLS=1 -s DEFAULT_TO_CXX=1") diff --git a/cmake/deps.txt b/cmake/deps.txt index 1d4b54ed8e75f..dc7fc5399fe0f 100644 --- a/cmake/deps.txt +++ b/cmake/deps.txt @@ -17,8 +17,6 @@ coremltools;https://github.com/apple/coremltools/archive/refs/tags/7.1.zip;f1bab cxxopts;https://github.com/jarro2783/cxxopts/archive/3c73d91c0b04e2b59462f0a741be8c07024c1bc0.zip;6c6ca7f8480b26c8d00476e0e24b7184717fe4f0 date;https://github.com/HowardHinnant/date/archive/refs/tags/v3.0.1.zip;2dac0c81dc54ebdd8f8d073a75c053b04b56e159 dlpack;https://github.com/dmlc/dlpack/archive/refs/tags/v0.6.zip;4d565dd2e5b31321e5549591d78aa7f377173445 -#flatbuffers;https://github.com/google/flatbuffers/archive/refs/tags/v1.12.0.zip;ba0a75fd12dbef8f6557a74e611b7a3d0c5fe7bf -#flatbuffers;https://github.com/google/flatbuffers/archive/refs/tags/v22.12.6.zip;d01b5232ee52ed5ed05e84f4de01118d5ff8730d # This Eigen commit id matches the eigen archive being consumed from https://gitlab.com/libeigen/eigen/-/archive/3.4/eigen-3.4.zip # prior to the 3.4.1 RC changing the bits and invalidating the hash. # it contains changes on top of 3.4.0 which are required to fix build issues. From 8d9a5ccd07aa14c60eea5592994b5e4fbfed0d2b Mon Sep 17 00:00:00 2001 From: Paco Wong Date: Wed, 16 Oct 2024 00:27:50 +0800 Subject: [PATCH 6/6] Update build script --- onnxruntime/core/flatbuffers/schema/ort.fbs.h | 6 -- tools/ci_build/build.py | 69 ------------------- .../github/apple/test_apple_packages.py | 10 --- 3 files changed, 85 deletions(-) diff --git a/onnxruntime/core/flatbuffers/schema/ort.fbs.h b/onnxruntime/core/flatbuffers/schema/ort.fbs.h index 9f79a0cccfcab..dc8a471f2d81f 100644 --- a/onnxruntime/core/flatbuffers/schema/ort.fbs.h +++ b/onnxruntime/core/flatbuffers/schema/ort.fbs.h @@ -1568,15 +1568,9 @@ struct Attribute FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table { verifier.VerifyString(name()) && VerifyOffset(verifier, VT_DOC_STRING) && verifier.VerifyString(doc_string()) && -<<<<<<< HEAD - VerifyField(verifier, VT_TYPE, sizeof(int32_t)) && - VerifyField(verifier, VT_F, sizeof(float)) && - VerifyField(verifier, VT_I, sizeof(int64_t)) && -======= VerifyField(verifier, VT_TYPE, 4) && VerifyField(verifier, VT_F, 4) && VerifyField(verifier, VT_I, 8) && ->>>>>>> main VerifyOffset(verifier, VT_S) && verifier.VerifyString(s()) && VerifyOffset(verifier, VT_T) && diff --git a/tools/ci_build/build.py b/tools/ci_build/build.py index ca5f1dae95202..4fb511c11ae55 100644 --- a/tools/ci_build/build.py +++ b/tools/ci_build/build.py @@ -415,11 +415,6 @@ def convert_arg_line_to_args(self, arg_line): default="", help="Path to ios toolchain file, or cmake/onnxruntime_ios.toolchain.cmake will be used", ) - parser.add_argument( - "--macabi_toolchain_file", - default="", - help="Path to macabi toolchain file, " "or cmake/onnxruntime_macabi.toolchain.cmake will be used", - ) parser.add_argument( "--xcode_code_signing_team_id", default="", help="The development team ID used for code signing in Xcode" ) @@ -446,7 +441,6 @@ def convert_arg_line_to_args(self, arg_line): "(e.g. macOS or iOS)" "This is only supported on MacOS", ) - parser.add_argument("--macabi", action="store_true", help="Build for macabi") # A 32-bit progress doesn't have enough memory to run all the tests in onnxruntime_test_all. # Mimalloc is incompatible with address sanitizer. # Address sanitizer itself is also a memory leak checker, so when it is enabled we should disable_memleak_checker. @@ -1019,7 +1013,6 @@ def generate_build_tree( "-Donnxruntime_BUILD_OBJC=" + ("ON" if args.build_objc else "OFF"), "-Donnxruntime_BUILD_SHARED_LIB=" + ("ON" if args.build_shared_lib else "OFF"), "-Donnxruntime_BUILD_APPLE_FRAMEWORK=" + ("ON" if args.build_apple_framework else "OFF"), - "-DFETCHCONTENT_TRY_FIND_PACKAGE_MODE=NEVER", #PACO "-Donnxruntime_USE_DNNL=" + ("ON" if args.use_dnnl else "OFF"), "-Donnxruntime_USE_NNAPI_BUILTIN=" + ("ON" if args.use_nnapi else "OFF"), "-Donnxruntime_USE_RKNPU=" + ("ON" if args.use_rknpu else "OFF"), @@ -1394,65 +1387,6 @@ def generate_build_tree( f"-DCMAKE_CC_FLAGS_RELEASE=-O3 -DNDEBUG --target={macabi_target}", ] - if args.macabi: - needed_args = [ - #args.use_xcode, - args.ios_sysroot, - args.apple_deploy_target, - ] - arg_names = [ - #"--use_xcode " + "", - "--ios_sysroot " + "", - "--apple_deploy_target " + "", - ] - if not all(needed_args): - raise BuildError( - "iOS build on MacOS canceled due to missing arguments: " - + ", ".join(val for val, cond in zip(arg_names, needed_args) if not cond) - ) - cmake_args += [ - "-DCMAKE_SYSTEM_NAME=Darwin", - "-Donnxruntime_BUILD_SHARED_LIB=ON", - "-DCMAKE_OSX_SYSROOT=" + args.ios_sysroot, - "-DCMAKE_OSX_DEPLOYMENT_TARGET=11.0", # + args.apple_deploy_target, - "-DCMAKE_CXX_OSX_DEPLOYMENT_TARGET_FLAG=" + args.apple_deploy_target, - "-DCMAKE_C_OSX_DEPLOYMENT_TARGET_FLAG=" + args.apple_deploy_target, - "-DCMAKE_CC_OSX_DEPLOYMENT_TARGET_FLAG=" + args.apple_deploy_target, - "-DCMAKE_CXX_COMPILER_TARGET=" + f"{args.osx_arch}-apple-ios{args.apple_deploy_target}-macabi", - "-DCMAKE_C_COMPILER_TARGET=" + f"{args.osx_arch}-apple-ios{args.apple_deploy_target}-macabi", - "-DCMAKE_CC_COMPILER_TARGET=" + f"{args.osx_arch}-apple-ios{args.apple_deploy_target}-macabi", - "-DCMAKE_CXX_FLAGS=" + f"--target={args.osx_arch}-apple-ios{args.apple_deploy_target}-macabi", - "-DCMAKE_CXX_FLAGS_RELEASE=" + f"-O3 -DNDEBUG --target={args.osx_arch}-apple-ios{args.apple_deploy_target}-macabi", - "-DCMAKE_C_FLAGS=" + f"--target={args.osx_arch}-apple-ios{args.apple_deploy_target}-macabi", - "-DCMAKE_C_FLAGS_RELEASE=" + f"-O3 -DNDEBUG --target={args.osx_arch}-apple-ios{args.apple_deploy_target}-macabi", - "-DCMAKE_CC_FLAGS=" + f"--target={args.osx_arch}-apple-ios{args.apple_deploy_target}-macabi", - "-DCMAKE_CC_FLAGS_RELEASE=" + f"-O3 -DNDEBUG --target={args.osx_arch}-apple-ios{args.apple_deploy_target}-macabi", - "-DCMAKE_OSX_SYSROOT=" + "/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX13.0.sdk", - "-DCMAKE_THREAD_LIBS_INIT=" + "-lpthread", - "-DCMAKE_HAVE_THREADS_LIBRARY=" + "1", - "-DCMAKE_USE_PTHREADS_INIT=1", - "-DTHREADS_PREFER_PTHREAD_FLAG=ON", - "-Donnxruntime_ENABLE_BITCODE=OFF", - "-DCMAKE_COMPILE_WARNING_AS_ERROR=OFF", - "-DCMAKE_OSX_ARCHITECTURES=" + f"{args.osx_arch}", - "-DCMAKE_CXX_OSX_DEPLOYMENT_TARGET_FLAG=", - # we do not need protoc binary for ios cross build - "-Dprotobuf_BUILD_PROTOC_BINARIES=OFF", - ] - - if args.osx_arch == "arm64": - cmake_args += ["-DPLATFORM=MAC_CATALYST_ARM64"] - elif args.osx_arch == "x86_64": - cmake_args += ["-DPLATFORM=MAC_CATALYST"] - #"-DPLATFORM=" + "MAC_CATALYST_ARM64" if args.osx_arch == "arm64" else "MAC_CATALYST", - #f"-DCMAKE_C_FLAGS={args.osx_arch}-apple-ios{args.apple_deploy_target}-macabi", - #"-DCMAKE_TOOLCHAIN_FILE=" - #+ (args.macabi_toolchain_file if args.macabi_toolchain_file else "../cmake/onnxruntime_macabi.toolchain.cmake.v1"), - print("args.macabi cmake config") - print(cmake_args) - #exit(-1) - - if args.build_wasm: emsdk_dir = os.path.join(cmake_dir, "external", "emsdk") emscripten_cmake_toolchain_file = os.path.join( @@ -1793,9 +1727,6 @@ def build_targets(args, cmake_path, build_dir, configs, num_parallel_jobs, targe if args.android: env["ANDROID_SDK_ROOT"] = args.android_sdk_path env["ANDROID_NDK_HOME"] = args.android_ndk_path - #cmd_args += ['--verbose'] - print(cmd_args) - print(env) run_subprocess(cmd_args, env=env) diff --git a/tools/ci_build/github/apple/test_apple_packages.py b/tools/ci_build/github/apple/test_apple_packages.py index d0724b11f0b76..3987a37fcc76c 100644 --- a/tools/ci_build/github/apple/test_apple_packages.py +++ b/tools/ci_build/github/apple/test_apple_packages.py @@ -121,16 +121,6 @@ def _test_apple_packages(args): if not args.prepare_test_project_only: simulator_device_info = subprocess.check_output( [ - # "xcrun", - # "xcodebuild", - # "test", - # "-workspace", - # "./ios_package_test.xcworkspace", - # "-scheme", - # "ios_package_test", - # "-destination", - # "platform=iOS Simulator,OS=latest,name=iPhone SE (2nd generation)", - # "platform=iOS Simulator,OS=latest,name=iPhone SE (2nd generation)", sys.executable, str(REPO_DIR / "tools" / "ci_build" / "github" / "apple" / "get_simulator_device_info.py"), ],