blob: 0675050c9ca45836b16b2ba92ba192d18f58d702 [file] [log] [blame]
# 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" ]
}