2009-12-31 23:30:26 +01:00
|
|
|
############################################################################
|
2013-06-02 21:57:22 +02:00
|
|
|
# arch/arm/src/sam34/Make.defs
|
2009-12-31 23:30:26 +01:00
|
|
|
#
|
2015-02-03 14:00:54 +01:00
|
|
|
# Copyright (C) 2009-2011, 2013-2015 Gregory Nutt. All rights reserved.
|
2011-10-03 16:06:06 +02:00
|
|
|
# Author: Gregory Nutt <gnutt@nuttx.org>
|
2009-12-31 23:30:26 +01:00
|
|
|
#
|
|
|
|
# Redistribution and use in source and binary forms, with or without
|
|
|
|
# modification, are permitted provided that the following conditions
|
|
|
|
# are met:
|
|
|
|
#
|
|
|
|
# 1. Redistributions of source code must retain the above copyright
|
|
|
|
# notice, this list of conditions and the following disclaimer.
|
|
|
|
# 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
# notice, this list of conditions and the following disclaimer in
|
|
|
|
# the documentation and/or other materials provided with the
|
|
|
|
# distribution.
|
|
|
|
# 3. Neither the name NuttX nor the names of its contributors may be
|
|
|
|
# used to endorse or promote products derived from this software
|
|
|
|
# without specific prior written permission.
|
|
|
|
#
|
|
|
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
|
|
|
# FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
|
|
|
# COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
|
|
|
# BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
|
|
|
# OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
|
|
|
# AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
|
|
|
# ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
|
|
# POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
#
|
|
|
|
############################################################################
|
|
|
|
|
2010-04-02 18:23:10 +02:00
|
|
|
# The start-up, "head", file
|
|
|
|
|
2015-03-06 15:26:43 +01:00
|
|
|
ifeq ($(CONFIG_ARMV7M_CMNVECTOR),y)
|
|
|
|
HEAD_ASRC =
|
|
|
|
else
|
2013-06-02 21:04:40 +02:00
|
|
|
HEAD_ASRC = sam_vectors.S
|
2015-03-06 15:26:43 +01:00
|
|
|
endif
|
2009-12-31 23:30:26 +01:00
|
|
|
|
2010-04-02 18:23:10 +02:00
|
|
|
# Common ARM and Cortex-M3 files
|
|
|
|
|
2013-03-23 15:46:02 +01:00
|
|
|
CMN_UASRCS =
|
|
|
|
CMN_UCSRCS =
|
|
|
|
|
2013-03-14 23:44:06 +01:00
|
|
|
CMN_ASRCS = up_saveusercontext.S up_fullcontextrestore.S up_switchcontext.S
|
2016-02-09 20:44:22 +01:00
|
|
|
CMN_ASRCS += up_testset.S vfork.S
|
|
|
|
|
2013-07-24 01:52:06 +02:00
|
|
|
CMN_CSRCS = up_assert.c up_blocktask.c up_copyfullstate.c up_createstack.c
|
2013-03-14 23:44:06 +01:00
|
|
|
CMN_CSRCS += up_mdelay.c up_udelay.c up_exit.c up_idle.c up_initialize.c
|
|
|
|
CMN_CSRCS += up_initialstate.c up_interruptcontext.c up_memfault.c up_modifyreg8.c
|
|
|
|
CMN_CSRCS += up_modifyreg16.c up_modifyreg32.c up_releasepending.c
|
|
|
|
CMN_CSRCS += up_releasestack.c up_reprioritizertr.c up_schedulesigaction.c
|
2014-09-01 23:39:34 +02:00
|
|
|
CMN_CSRCS += up_sigdeliver.c up_stackframe.c up_unblocktask.c up_usestack.c
|
|
|
|
CMN_CSRCS += up_doirq.c up_hardfault.c up_svcall.c up_vfork.c
|
2009-12-31 23:30:26 +01:00
|
|
|
|
2011-04-08 20:36:51 +02:00
|
|
|
# Configuration-dependent common files
|
|
|
|
|
2015-03-06 15:26:43 +01:00
|
|
|
ifeq ($(CONFIG_ARMV7M_CMNVECTOR),y)
|
2015-03-11 19:30:14 +01:00
|
|
|
ifeq ($(CONFIG_ARMV7M_LAZYFPU),y)
|
2015-03-06 15:26:43 +01:00
|
|
|
CMN_ASRCS += up_lazyexception.S
|
|
|
|
else
|
|
|
|
CMN_ASRCS += up_exception.S
|
|
|
|
endif
|
|
|
|
CMN_CSRCS += up_vectors.c
|
|
|
|
endif
|
|
|
|
|
2013-03-18 22:10:08 +01:00
|
|
|
ifeq ($(CONFIG_ARCH_RAMVECTORS),y)
|
|
|
|
CMN_CSRCS += up_ramvec_initialize.c up_ramvec_attach.c
|
|
|
|
endif
|
|
|
|
|
2012-10-20 20:56:55 +02:00
|
|
|
ifeq ($(CONFIG_ARCH_MEMCPY),y)
|
2013-03-14 23:44:06 +01:00
|
|
|
CMN_ASRCS += up_memcpy.S
|
2012-10-20 20:56:55 +02:00
|
|
|
endif
|
|
|
|
|
2014-08-29 22:47:22 +02:00
|
|
|
ifeq ($(CONFIG_BUILD_PROTECTED),y)
|
2014-09-01 23:39:34 +02:00
|
|
|
CMN_CSRCS += up_mpu.c up_task_start.c up_pthread_start.c
|
2013-03-17 01:40:49 +01:00
|
|
|
ifneq ($(CONFIG_DISABLE_SIGNALS),y)
|
2013-03-23 15:46:02 +01:00
|
|
|
CMN_CSRCS += up_signal_dispatch.c
|
|
|
|
CMN_UASRCS += up_signal_handler.S
|
2013-03-17 01:40:49 +01:00
|
|
|
endif
|
2011-04-08 20:36:51 +02:00
|
|
|
endif
|
|
|
|
|
2012-10-26 21:53:20 +02:00
|
|
|
ifeq ($(CONFIG_ELF),y)
|
|
|
|
CMN_CSRCS += up_elf.c
|
2015-12-12 16:35:05 +01:00
|
|
|
else ifeq ($(CONFIG_MODULE),y)
|
|
|
|
CMN_CSRCS += up_elf.c
|
2012-10-26 21:53:20 +02:00
|
|
|
endif
|
|
|
|
|
2015-03-06 15:26:43 +01:00
|
|
|
ifeq ($(CONFIG_ARCH_FPU),y)
|
|
|
|
CMN_ASRCS += up_fpu.S
|
|
|
|
ifneq ($(CONFIG_ARMV7M_CMNVECTOR),y)
|
|
|
|
CMN_CSRCS += up_copyarmstate.c
|
2015-08-31 16:40:02 +02:00
|
|
|
else ifeq ($(CONFIG_ARMV7M_LAZYFPU),y)
|
|
|
|
CMN_CSRCS += up_copyarmstate.c
|
2015-03-06 15:26:43 +01:00
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
2015-01-24 13:03:39 +01:00
|
|
|
ifeq ($(CONFIG_STACK_COLORATION),y)
|
|
|
|
CMN_CSRCS += up_checkstack.c
|
|
|
|
endif
|
|
|
|
|
2013-06-02 18:33:57 +02:00
|
|
|
# Required SAM3/4 files
|
2010-04-02 18:23:10 +02:00
|
|
|
|
2013-06-02 18:33:57 +02:00
|
|
|
CHIP_ASRCS =
|
2015-07-03 17:33:52 +02:00
|
|
|
CHIP_CSRCS = sam_allocateheap.c sam_irq.c sam_lowputc.c sam_serial.c
|
|
|
|
CHIP_CSRCS += sam_start.c
|
2010-04-02 18:23:10 +02:00
|
|
|
|
2013-06-02 18:33:57 +02:00
|
|
|
# Configuration-dependent SAM3/4 files
|
2010-04-02 18:23:10 +02:00
|
|
|
|
2015-03-06 15:26:43 +01:00
|
|
|
ifeq ($(CONFIG_ARMV7M_CMNVECTOR),y)
|
|
|
|
CHIP_ASRCS += sam_vectors.S
|
|
|
|
endif
|
|
|
|
|
2014-08-07 00:26:01 +02:00
|
|
|
ifneq ($(CONFIG_SCHED_TICKLESS),y)
|
|
|
|
CHIP_CSRCS += sam_timerisr.c
|
|
|
|
endif
|
|
|
|
|
2014-07-07 16:03:18 +02:00
|
|
|
ifeq ($(CONFIG_CRYPTO_AES),y)
|
|
|
|
CHIP_CSRCS += sam_aes.c
|
|
|
|
endif
|
|
|
|
|
2014-06-25 16:25:52 +02:00
|
|
|
ifeq ($(CONFIG_ARCH_CHIP_SAM4CM),y)
|
|
|
|
CHIP_CSRCS += sam4cm_supc.c
|
|
|
|
endif
|
|
|
|
|
2013-06-04 23:12:56 +02:00
|
|
|
ifeq ($(CONFIG_ARCH_CHIP_SAM4L),y)
|
2013-06-06 02:48:30 +02:00
|
|
|
CHIP_CSRCS += sam4l_clockconfig.c sam4l_periphclks.c sam4l_gpio.c
|
2013-06-04 23:12:56 +02:00
|
|
|
else
|
2015-07-03 17:33:52 +02:00
|
|
|
CHIP_CSRCS += sam_clockconfig.c sam_gpio.c sam_gpioirq.c
|
2013-06-04 23:12:56 +02:00
|
|
|
endif
|
|
|
|
|
2014-08-29 22:47:22 +02:00
|
|
|
ifeq ($(CONFIG_BUILD_PROTECTED),y)
|
2013-06-02 21:04:40 +02:00
|
|
|
CHIP_CSRCS += sam_userspace.c sam_mpuinit.c
|
2011-04-08 17:24:50 +02:00
|
|
|
endif
|
|
|
|
|
2014-03-12 19:38:39 +01:00
|
|
|
ifeq ($(CONFIG_SAM34_CMCC),y)
|
|
|
|
CHIP_CSRCS += sam_cmcc.c
|
|
|
|
endif
|
|
|
|
|
2014-03-13 22:54:09 +01:00
|
|
|
ifeq ($(CONFIG_SAM34_DMAC0),y)
|
2014-02-25 17:56:23 +01:00
|
|
|
CHIP_CSRCS += sam_dmac.c
|
2013-06-20 02:38:31 +02:00
|
|
|
endif
|
|
|
|
|
2014-04-22 01:04:22 +02:00
|
|
|
ifeq ($(CONFIG_ARCH_CHIP_SAM4L),y)
|
2013-06-20 02:38:31 +02:00
|
|
|
ifeq ($(CONFIG_SAM34_PDCA),y)
|
|
|
|
CHIP_CSRCS += sam4l_pdca.c
|
2010-04-02 18:23:10 +02:00
|
|
|
endif
|
2014-04-22 01:04:22 +02:00
|
|
|
endif
|
2009-12-31 23:30:26 +01:00
|
|
|
|
2014-03-12 22:03:59 +01:00
|
|
|
ifeq ($(CONFIG_SAM34_EMAC),y)
|
|
|
|
CHIP_CSRCS += sam_emac.c
|
|
|
|
endif
|
|
|
|
|
2014-03-16 21:11:22 +01:00
|
|
|
ifeq ($(CONFIG_SAM34_UDP),y)
|
|
|
|
CHIP_CSRCS += sam_udp.c
|
|
|
|
endif
|
|
|
|
|
2013-06-02 18:33:57 +02:00
|
|
|
ifeq ($(CONFIG_SAM34_HSMCI),y)
|
2013-06-02 21:04:40 +02:00
|
|
|
CHIP_CSRCS += sam_hsmci.c
|
2010-04-02 18:23:10 +02:00
|
|
|
endif
|
2011-04-08 17:24:50 +02:00
|
|
|
|
2013-06-27 02:46:44 +02:00
|
|
|
ifeq ($(CONFIG_SAM34_SPI0),y)
|
2013-06-02 21:04:40 +02:00
|
|
|
CHIP_CSRCS += sam_spi.c
|
2014-03-13 17:34:35 +01:00
|
|
|
else
|
|
|
|
ifeq ($(CONFIG_SAM34_SPI1),y)
|
|
|
|
CHIP_CSRCS += sam_spi.c
|
|
|
|
endif
|
2011-10-03 16:06:06 +02:00
|
|
|
endif
|
2014-04-22 01:04:22 +02:00
|
|
|
|
2015-06-22 17:32:15 +02:00
|
|
|
ifeq ($(CONFIG_SAM34_TWIM),y)
|
|
|
|
CHIP_CSRCS += sam_twi.c
|
|
|
|
endif
|
|
|
|
|
2014-07-03 15:26:44 +02:00
|
|
|
ifeq ($(CONFIG_SAM34_AES),y)
|
|
|
|
CHIP_CSRCS += sam_aes.c
|
|
|
|
endif
|
|
|
|
|
2014-04-22 01:04:22 +02:00
|
|
|
ifeq ($(CONFIG_SAM34_RTC),y)
|
|
|
|
CHIP_CSRCS += sam_rtc.c
|
|
|
|
endif
|
2014-04-22 03:10:06 +02:00
|
|
|
|
2014-05-05 22:35:37 +02:00
|
|
|
ifeq ($(CONFIG_SAM34_RTT),y)
|
|
|
|
CHIP_CSRCS += sam_rtt.c
|
|
|
|
endif
|
|
|
|
|
2014-04-22 03:10:06 +02:00
|
|
|
ifeq ($(CONFIG_SAM34_WDT),y)
|
|
|
|
CHIP_CSRCS += sam_wdt.c
|
|
|
|
endif
|
2014-04-22 17:01:20 +02:00
|
|
|
|
|
|
|
ifeq ($(CONFIG_TIMER),y)
|
|
|
|
CHIP_CSRCS += sam_tc.c
|
|
|
|
endif
|
2015-02-03 14:00:54 +01:00
|
|
|
|
|
|
|
ifeq ($(CONFIG_ARCH_CHIP_SAM4CM),y)
|
|
|
|
ifeq ($(CONFIG_SAM34_TC),y)
|
|
|
|
CHIP_CSRCS += sam4cm_tc.c
|
|
|
|
ifeq ($(CONFIG_SAM34_ONESHOT),y)
|
|
|
|
CHIP_CSRCS += sam4cm_oneshot.c
|
|
|
|
endif
|
|
|
|
ifeq ($(CONFIG_SAM34_FREERUN),y)
|
|
|
|
CHIP_CSRCS += sam4cm_freerun.c
|
|
|
|
endif
|
|
|
|
ifeq ($(CONFIG_SCHED_TICKLESS),y)
|
|
|
|
CHIP_CSRCS += sam4cm_tickless.c
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endif
|