10d163575Sopenharmony_ci# Copyright (c) 2013-2019 Huawei Technologies Co., Ltd. All rights reserved. 20d163575Sopenharmony_ci# Copyright (c) 2020-2021 Huawei Device Co., Ltd. All rights reserved. 30d163575Sopenharmony_ci# 40d163575Sopenharmony_ci# Redistribution and use in source and binary forms, with or without modification, 50d163575Sopenharmony_ci# are permitted provided that the following conditions are met: 60d163575Sopenharmony_ci# 70d163575Sopenharmony_ci# 1. Redistributions of source code must retain the above copyright notice, this list of 80d163575Sopenharmony_ci# conditions and the following disclaimer. 90d163575Sopenharmony_ci# 100d163575Sopenharmony_ci# 2. Redistributions in binary form must reproduce the above copyright notice, this list 110d163575Sopenharmony_ci# of conditions and the following disclaimer in the documentation and/or other materials 120d163575Sopenharmony_ci# provided with the distribution. 130d163575Sopenharmony_ci# 140d163575Sopenharmony_ci# 3. Neither the name of the copyright holder nor the names of its contributors may be used 150d163575Sopenharmony_ci# to endorse or promote products derived from this software without specific prior written 160d163575Sopenharmony_ci# permission. 170d163575Sopenharmony_ci# 180d163575Sopenharmony_ci# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 190d163575Sopenharmony_ci# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, 200d163575Sopenharmony_ci# THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 210d163575Sopenharmony_ci# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR 220d163575Sopenharmony_ci# CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 230d163575Sopenharmony_ci# EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 240d163575Sopenharmony_ci# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; 250d163575Sopenharmony_ci# OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 260d163575Sopenharmony_ci# WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR 270d163575Sopenharmony_ci# OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF 280d163575Sopenharmony_ci# ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 290d163575Sopenharmony_ci 300d163575Sopenharmony_ci# strip quotation mark in configuration 310d163575Sopenharmony_ci 320d163575Sopenharmony_ciLOSCFG_ARCH_CPU_STRIP := $(subst $\",,$(LOSCFG_ARCH_CPU)) 330d163575Sopenharmony_ciLOSCFG_ARCH_CPU = $(LOSCFG_ARCH_CPU_STRIP) 340d163575Sopenharmony_ci 350d163575Sopenharmony_ciLOSCFG_ARCH_FPU_STRIP := $(subst $\",,$(LOSCFG_ARCH_FPU)) 360d163575Sopenharmony_ciLOSCFG_ARCH_FPU = $(LOSCFG_ARCH_FPU_STRIP) 370d163575Sopenharmony_ci 380d163575Sopenharmony_ciifeq ($(LOSCFG_ARCH_ARM_AARCH32), y) 390d163575Sopenharmony_ciARCH := arm 400d163575Sopenharmony_cielse ifeq ($(LOSCFG_ARCH_ARM_AARCH64), y) 410d163575Sopenharmony_ciARCH := aarch64 420d163575Sopenharmony_ciendif 430d163575Sopenharmony_ci 440d163575Sopenharmony_ciLITEOS_BASELIB += -l$(LOSCFG_ARCH_CPU) 450d163575Sopenharmony_ciLITEOS_BASELIB += -lgic 460d163575Sopenharmony_ci 470d163575Sopenharmony_ciLIB_SUBDIRS += arch/arm/$(ARCH) 480d163575Sopenharmony_ciLIB_SUBDIRS += arch/arm/gic 490d163575Sopenharmony_ci 500d163575Sopenharmony_ci# CPU compile options 510d163575Sopenharmony_ciifeq ($(LOSCFG_ARCH_ARM_AARCH64), y) 520d163575Sopenharmony_ciifeq ($(LOSCFG_ARCH_FPU_DISABLE), y) 530d163575Sopenharmony_ciEXTENSION := +nofp 540d163575Sopenharmony_ciendif 550d163575Sopenharmony_ciendif 560d163575Sopenharmony_ciLITEOS_CPU_OPTS := -mcpu=$(LOSCFG_ARCH_CPU)$(EXTENSION) 570d163575Sopenharmony_ci 580d163575Sopenharmony_ci# FPU compile options 590d163575Sopenharmony_ci# -mfloat and -mfpu is ignored with AArch64 targets 600d163575Sopenharmony_ciifeq ($(LOSCFG_ARCH_ARM_AARCH32), y) 610d163575Sopenharmony_ciLITEOS_FLOAT_OPTS := -mfloat-abi=softfp 620d163575Sopenharmony_ciLITEOS_FPU_OPTS := -mfpu=$(LOSCFG_ARCH_FPU) 630d163575Sopenharmony_ci# gcc libc folder style is combine with core and fpu 640d163575Sopenharmony_ci# for example, cortex-a7 with softfp abi and neon vfp4 is: a7_softfp_neon_vfp4 650d163575Sopenharmony_ciLITEOS_GCCLIB := $(subst cortex-,,$(LOSCFG_ARCH_CPU))_softfp_$(LOSCFG_ARCH_FPU) 660d163575Sopenharmony_ciendif 670d163575Sopenharmony_ci 680d163575Sopenharmony_ciLITEOS_CORE_COPTS = $(or $(ARCH_CFLAGS),$(LITEOS_CPU_OPTS) $(LITEOS_FLOAT_OPTS) $(LITEOS_FPU_OPTS)) 690d163575Sopenharmony_ciLITEOS_ASOPTS += $(LITEOS_CPU_OPTS) 700d163575Sopenharmony_ciLITEOS_CXXOPTS_BASE += $(LITEOS_CORE_COPTS) 710d163575Sopenharmony_ci 720d163575Sopenharmony_ciARCH_INCLUDE := -I $(LITEOSTOPDIR)/arch/arm/include \ 730d163575Sopenharmony_ci -I $(LITEOSTOPDIR)/arch/arm/$(ARCH)/include \ 740d163575Sopenharmony_ci -I $(LITEOSTOPDIR)/arch/arm/$(ARCH)/src/include 750d163575Sopenharmony_ci 760d163575Sopenharmony_ciLITEOS_PLATFORM_INCLUDE += $(ARCH_INCLUDE) 77