| # Copyright 2023 The Pigweed Authors |
| # |
| # Licensed under the Apache License, Version 2.0 (the "License"); you may not |
| # use this file except in compliance with the License. You may obtain a copy of |
| # the License at |
| # |
| # https://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT |
| # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the |
| # License for the specific language governing permissions and limitations under |
| # the License. |
| |
| import("//build_overrides/pigweed.gni") |
| |
| import("$dir_pw_build/error.gni") |
| import("$dir_pw_build/target_types.gni") |
| import("$dir_pw_docgen/docs.gni") |
| |
| declare_args() { |
| # This should be set to the path of the llvm compiler-rt/builtins directory. |
| dir_pw_third_party_llvm_builtins = "" |
| |
| # Points to a pw_source_set that enumerates builtins specific to |
| # the current toolchain. |
| pw_third_party_llvm_builtins_TARGET_BUILTINS = "" |
| |
| # List of files to be excluded from the builtins repo. |
| pw_third_party_llvm_builtins_ignore_list = [] |
| } |
| |
| config("no-warnings") { |
| cflags = [ |
| "-Wno-double-promotion", |
| "-Wno-undef", |
| "-Wno-unused-parameter", |
| "-Wno-strict-prototypes", |
| ] |
| } |
| |
| # Source files that are common between ARMv6M and ARMv7M. |
| generic_sources = [ |
| "absvdi2.c", |
| "absvsi2.c", |
| "absvti2.c", |
| "adddf3.c", |
| "addvdi3.c", |
| "addvsi3.c", |
| "addvti3.c", |
| "ashldi3.c", |
| "ashlti3.c", |
| "ashrdi3.c", |
| "ashrti3.c", |
| "clzti2.c", |
| "cmpdi2.c", |
| "cmpti2.c", |
| "comparedf2.c", |
| "ctzdi2.c", |
| "ctzsi2.c", |
| "ctzti2.c", |
| "divdc3.c", |
| "divdf3.c", |
| "divdi3.c", |
| "divmoddi4.c", |
| "divmodti4.c", |
| "divsc3.c", |
| "divsf3.c", |
| "divti3.c", |
| "extendhfsf2.c", |
| "extendsfdf2.c", |
| "ffsdi2.c", |
| "ffssi2.c", |
| "ffsti2.c", |
| "fixdfdi.c", |
| "fixdfsi.c", |
| "fixdfti.c", |
| "fixsfdi.c", |
| "fixsfsi.c", |
| "fixsfti.c", |
| "fixunsdfdi.c", |
| "fixunsdfsi.c", |
| "fixunsdfti.c", |
| "fixunssfdi.c", |
| "fixunssfsi.c", |
| "fixunssfti.c", |
| "floatdidf.c", |
| "floatdisf.c", |
| "floatsidf.c", |
| "floatsisf.c", |
| "floattidf.c", |
| "floattisf.c", |
| "floatundidf.c", |
| "floatundisf.c", |
| "floatunsidf.c", |
| "floatunsisf.c", |
| "floatuntidf.c", |
| "floatuntisf.c", |
| "int_util.c", |
| "lshrdi3.c", |
| "lshrti3.c", |
| "moddi3.c", |
| "modti3.c", |
| "muldc3.c", |
| "muldf3.c", |
| "muldi3.c", |
| "mulodi4.c", |
| "mulosi4.c", |
| "muloti4.c", |
| "mulsc3.c", |
| "mulsf3.c", |
| "multi3.c", |
| "mulvdi3.c", |
| "mulvsi3.c", |
| "mulvti3.c", |
| "negdf2.c", |
| "negdi2.c", |
| "negsf2.c", |
| "negti2.c", |
| "negvdi2.c", |
| "negvsi2.c", |
| "negvti2.c", |
| "os_version_check.c", |
| "paritydi2.c", |
| "paritysi2.c", |
| "parityti2.c", |
| "popcountdi2.c", |
| "popcountsi2.c", |
| "popcountti2.c", |
| "powidf2.c", |
| "powisf2.c", |
| "subdf3.c", |
| "subsf3.c", |
| "subvdi3.c", |
| "subvsi3.c", |
| "subvti3.c", |
| "trampoline_setup.c", |
| "truncdfhf2.c", |
| "truncdfsf2.c", |
| "truncsfhf2.c", |
| "ucmpdi2.c", |
| "ucmpti2.c", |
| "udivdi3.c", |
| "udivmoddi4.c", |
| "udivmodti4.c", |
| "udivti3.c", |
| "umoddi3.c", |
| "umodti3.c", |
| ] |
| |
| generic_tf_sources = [ |
| "addtf3.c", |
| "comparetf2.c", |
| "divtc3.c", |
| "divtf3.c", |
| "extenddftf2.c", |
| "extendhftf2.c", |
| "extendsftf2.c", |
| "fixtfdi.c", |
| "fixtfsi.c", |
| "fixtfti.c", |
| "fixunstfdi.c", |
| "fixunstfsi.c", |
| "fixunstfti.c", |
| "floatditf.c", |
| "floatsitf.c", |
| "floattitf.c", |
| "floatunditf.c", |
| "floatunsitf.c", |
| "floatuntitf.c", |
| "multc3.c", |
| "multf3.c", |
| "powitf2.c", |
| "subtf3.c", |
| "trunctfdf2.c", |
| "trunctfhf2.c", |
| "trunctfsf2.c", |
| ] |
| |
| armv7m_only_sources = [ |
| "addsf3.c", |
| ## Assembly equivalent version of these following sources are |
| ## provided by arm_or_thumb2_base_sources |
| # "bswapdi2.c", |
| # "bswapsi2.c", |
| # "clzdi2.c", |
| # "clzsi2.c", |
| # "comparesf2.c", |
| # "divmodsi4.c", |
| # "divsi3.c", |
| # "fp_mode.c", |
| # "modsi3.c", |
| # "udivmodsi4.c", |
| # "udivsi3.c", |
| # "umodsi3.c", |
| ] |
| |
| armv6m_only_sources = [ |
| "bswapdi2.c", |
| "bswapsi2.c", |
| "clzdi2.c", |
| "clzsi2.c", |
| "divmodsi4.c", |
| "fp_mode.c", |
| "modsi3.c", |
| "udivmodsi4.c", |
| "umodsi3.c", |
| |
| ## Assembly equivalent version of these following sources are |
| ## provided by thumb1_base_sources |
| # "addsf3.c", |
| # "divsi3.c", |
| # "udivsi3.c", |
| # "comparesf2.c", |
| ] |
| |
| arm_or_thumb2_base_sources = [ |
| "arm/bswapdi2.S", |
| "arm/bswapsi2.S", |
| "arm/clzdi2.S", |
| "arm/clzsi2.S", |
| "arm/comparesf2.S", |
| "arm/divmodsi4.S", |
| "arm/divsi3.S", |
| "arm/fp_mode.c", |
| "arm/modsi3.S", |
| "arm/udivmodsi4.S", |
| "arm/udivsi3.S", |
| "arm/umodsi3.S", |
| ] |
| |
| arm_sync_sources = [ |
| "arm/sync_fetch_and_add_4.S", |
| "arm/sync_fetch_and_add_8.S", |
| "arm/sync_fetch_and_and_4.S", |
| "arm/sync_fetch_and_and_8.S", |
| "arm/sync_fetch_and_max_4.S", |
| "arm/sync_fetch_and_max_8.S", |
| "arm/sync_fetch_and_min_4.S", |
| "arm/sync_fetch_and_min_8.S", |
| "arm/sync_fetch_and_nand_4.S", |
| "arm/sync_fetch_and_nand_8.S", |
| "arm/sync_fetch_and_or_4.S", |
| "arm/sync_fetch_and_or_8.S", |
| "arm/sync_fetch_and_sub_4.S", |
| "arm/sync_fetch_and_sub_8.S", |
| "arm/sync_fetch_and_umax_4.S", |
| "arm/sync_fetch_and_umax_8.S", |
| "arm/sync_fetch_and_umin_4.S", |
| "arm/sync_fetch_and_umin_8.S", |
| "arm/sync_fetch_and_xor_4.S", |
| "arm/sync_fetch_and_xor_8.S", |
| ] |
| |
| # builtin support for Thumb-only targets with very limited Thumb2 technology, |
| # such as v6-m and v8-m.baseline |
| thumb1_base_sources = [ |
| "arm/addsf3.S", |
| "arm/comparesf2.S", |
| "arm/divsi3.S", |
| "arm/udivsi3.S", |
| ] |
| |
| arm_eabi_sources = [ |
| "arm/aeabi_cdcmp.S", |
| "arm/aeabi_cdcmpeq_check_nan.c", |
| "arm/aeabi_cfcmp.S", |
| "arm/aeabi_cfcmpeq_check_nan.c", |
| "arm/aeabi_dcmp.S", |
| "arm/aeabi_div0.c", |
| "arm/aeabi_drsub.c", |
| "arm/aeabi_fcmp.S", |
| "arm/aeabi_frsub.c", |
| "arm/aeabi_idivmod.S", |
| "arm/aeabi_ldivmod.S", |
| "arm/aeabi_memcmp.S", |
| "arm/aeabi_memcpy.S", |
| "arm/aeabi_memmove.S", |
| "arm/aeabi_memset.S", |
| "arm/aeabi_uidivmod.S", |
| "arm/aeabi_uldivmod.S", |
| ] |
| |
| arm_thumb1_jt_sources = [ |
| "arm/switch16.S", |
| "arm/switch32.S", |
| "arm/switch8.S", |
| "arm/switchu8.S", |
| ] |
| |
| arm_thumb1_icache_sources = [ "arm/sync_synchronize.S" ] |
| |
| # thumb1 calling into Arm to cover support |
| arm_thumb1_sources = arm_thumb1_jt_sources + arm_thumb1_icache_sources |
| |
| arm_sources = arm_or_thumb2_base_sources + arm_sync_sources + arm_eabi_sources + |
| arm_thumb1_sources + generic_sources + armv7m_only_sources + |
| generic_tf_sources |
| |
| thumb1_sources = thumb1_base_sources + arm_eabi_sources + generic_sources + |
| armv6m_only_sources + generic_tf_sources |
| |
| armv6m_sources = thumb1_sources |
| armv7m_sources = arm_sources |
| |
| # ARM builtins for ARMv7-M. |
| # Because this is unconditionally added to all clang-based ARM toolchains, |
| # this library should be a no-op if `dir_pw_third_party_llvm_builtins` is |
| # not configured. |
| pw_source_set("arm_builtins_armv7m") { |
| configs = [ ":no-warnings" ] |
| remove_configs = [ "//pw_build:extra_strict_warnings" ] |
| |
| sources = [] |
| |
| arm_files = armv7m_sources |
| |
| if (dir_pw_third_party_llvm_builtins != "") { |
| effective_arm_files = |
| filter_exclude(arm_files, pw_third_party_llvm_builtins_ignore_list) |
| foreach(file, effective_arm_files) { |
| sources += [ "$dir_pw_third_party_llvm_builtins/$file" ] |
| } |
| } else { |
| not_needed([ "arm_files" ]) |
| } |
| } |
| |
| # ARM builtins for ARMv6-M. |
| # Because this is unconditionally added to all clang-based ARM toolchains, |
| # this library should be a no-op if `dir_pw_third_party_llvm_builtins` is |
| # not configured. |
| pw_source_set("arm_builtins_armv6m") { |
| configs = [ ":no-warnings" ] |
| remove_configs = [ "//pw_build:extra_strict_warnings" ] |
| |
| sources = [] |
| |
| arm_files = armv6m_sources |
| |
| if (dir_pw_third_party_llvm_builtins != "") { |
| effective_arm_files = |
| filter_exclude(arm_files, pw_third_party_llvm_builtins_ignore_list) |
| foreach(file, effective_arm_files) { |
| sources += [ "$dir_pw_third_party_llvm_builtins/$file" ] |
| } |
| } else { |
| not_needed([ "arm_files" ]) |
| } |
| } |
| |
| # Because this is unconditionally added to all clang-based ARM toolchains, |
| # this library should be a no-op if `dir_pw_third_party_llvm_builtins` is |
| # not configured. |
| pw_static_library("llvm_builtins") { |
| add_global_link_deps = false |
| configs = [ ":no-warnings" ] |
| remove_configs = [ "//pw_build:extra_strict_warnings" ] |
| sources = [] |
| |
| # Architecture specific pw_source_set created from LLVM builtins |
| # source files. e.g. arm_builtins_armv6m. |
| # If this property is not set, no architecture specific builtin |
| # functions will be included from the repo. |
| if (pw_third_party_llvm_builtins_TARGET_BUILTINS != "") { |
| deps = [ pw_third_party_llvm_builtins_TARGET_BUILTINS ] |
| } |
| } |
| |
| pw_doc_group("docs") { |
| sources = [ "docs.rst" ] |
| } |