Add IAR compiler support for ADuCRF101
This commit is contained in:
parent
4f1fc3557c
commit
07201d13a3
7 changed files with 195 additions and 55 deletions
|
@ -171,7 +171,7 @@ __vector_table
|
||||||
|
|
||||||
|
|
||||||
THUMB
|
THUMB
|
||||||
SECTION .text:CODE:REORDER(1)
|
SECTION .text:CODE:REORDER:NOROOT(1)
|
||||||
Nmi_Handler
|
Nmi_Handler
|
||||||
Fault_Handler
|
Fault_Handler
|
||||||
MemManage_Handler
|
MemManage_Handler
|
|
@ -36,51 +36,12 @@
|
||||||
|
|
||||||
CONTIKI_CPU = $(CONTIKI)/cpu/arm/aducrf101
|
CONTIKI_CPU = $(CONTIKI)/cpu/arm/aducrf101
|
||||||
|
|
||||||
CROSS_COMPILE = arm-none-eabi-
|
ifdef IAR
|
||||||
|
include $(CONTIKI_CPU)/Makefile.aducrf101.iar
|
||||||
CC = $(CROSS_COMPILE)gcc
|
else
|
||||||
LD = $(CROSS_COMPILE)gcc
|
include $(CONTIKI_CPU)/Makefile.aducrf101.gnu
|
||||||
AS = $(CROSS_COMPILE)gcc
|
|
||||||
AR = $(CROSS_COMPILE)ar
|
|
||||||
NM = $(CROSS_COMPILE)nm
|
|
||||||
OBJCOPY = $(CROSS_COMPILE)objcopy
|
|
||||||
OBJDUMP = $(CROSS_COMPILE)objdump
|
|
||||||
STRIP = $(CROSS_COMPILE)strip
|
|
||||||
|
|
||||||
CFLAGS_OPT ?= -Os
|
|
||||||
CFLAGS_DEBUG ?= -ggdb3 -fomit-frame-pointer
|
|
||||||
CFLAGS += $(CFLAGS_OPT) $(CFLAGS_DEBUG)
|
|
||||||
CFLAGS += -std=gnu99
|
|
||||||
CFLAGS += -ffreestanding -mcpu=cortex-m3 -mthumb -mno-thumb-interwork
|
|
||||||
CFLAGS += -ffunction-sections -fdata-sections -fno-common -fno-builtin
|
|
||||||
CFLAGS += -flto
|
|
||||||
|
|
||||||
ifdef WERROR
|
|
||||||
CFLAGS += -Wall -Werror
|
|
||||||
# These warnings are triggered by existing Contiki code
|
|
||||||
CFLAGS += -Wno-error=pointer-sign
|
|
||||||
CFLAGS += -Wno-error=char-subscripts
|
|
||||||
CFLAGS += -Wno-error=unused-variable
|
|
||||||
CFLAGS += -Wno-error=unused-but-set-variable
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# UIP code does not follow C aliasing rules
|
|
||||||
CFLAGS += -fno-strict-aliasing
|
|
||||||
|
|
||||||
LDFLAGS = $(CFLAGS)
|
|
||||||
LDFLAGS += -specs=nosys.specs -nostartfiles
|
|
||||||
|
|
||||||
# TODO: When it becomes more commonly available, switch to newlib-nano
|
|
||||||
# for significant size reduction, by uncommenting this:
|
|
||||||
# LDFLAGS += -specs=nano.specs
|
|
||||||
|
|
||||||
LDFLAGS += -Wl,--gc-sections
|
|
||||||
LDFLAGS += -Wl,-T$(CONTIKI_CPU)/Common/GCC/ADuCRF101.ld
|
|
||||||
|
|
||||||
# Compiler-specific startup code
|
|
||||||
CONTIKI_CPU_DIRS += Common/GCC
|
|
||||||
CONTIKI_SOURCEFILES += crt0.S
|
|
||||||
|
|
||||||
ifdef SERIAL_ID
|
ifdef SERIAL_ID
|
||||||
CFLAGS += -DSERIAL_ID='$(SERIAL_ID)'
|
CFLAGS += -DSERIAL_ID='$(SERIAL_ID)'
|
||||||
endif
|
endif
|
||||||
|
@ -113,8 +74,6 @@ CONTIKI_CPU_DIRS += Common
|
||||||
CONTIKI_SOURCEFILES += system_ADuCRF101.c
|
CONTIKI_SOURCEFILES += system_ADuCRF101.c
|
||||||
CONTIKI_SOURCEFILES += radioeng.c
|
CONTIKI_SOURCEFILES += radioeng.c
|
||||||
|
|
||||||
ASFLAGS += -c $(CFLAGS)
|
|
||||||
|
|
||||||
ifdef CORE
|
ifdef CORE
|
||||||
.PHONY: symbols.c symbols.h
|
.PHONY: symbols.c symbols.h
|
||||||
symbols.c symbols.h:
|
symbols.c symbols.h:
|
||||||
|
@ -127,6 +86,3 @@ symbols.c symbols.h:
|
||||||
endif
|
endif
|
||||||
|
|
||||||
contiki-$(TARGET).a: ${addprefix $(OBJECTDIR)/,symbols.o}
|
contiki-$(TARGET).a: ${addprefix $(OBJECTDIR)/,symbols.o}
|
||||||
|
|
||||||
%.hex: %
|
|
||||||
$(OBJCOPY) -O ihex $^ $@
|
|
||||||
|
|
86
cpu/arm/aducrf101/Makefile.aducrf101.gnu
Normal file
86
cpu/arm/aducrf101/Makefile.aducrf101.gnu
Normal file
|
@ -0,0 +1,86 @@
|
||||||
|
# -*- makefile -*-
|
||||||
|
|
||||||
|
# Copyright (c) 2014, Analog Devices, Inc. All rights reserved.
|
||||||
|
#
|
||||||
|
# Redistribution and use in source and binary forms, with or without
|
||||||
|
# modification, are permitted (subject to the limitations in the
|
||||||
|
# disclaimer below) provided that the following conditions are met:
|
||||||
|
#
|
||||||
|
# - Redistributions of source code must retain the above copyright
|
||||||
|
# notice, this list of conditions and the following disclaimer.
|
||||||
|
#
|
||||||
|
# - 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.
|
||||||
|
#
|
||||||
|
# - Neither the name of Analog Devices, Inc. nor the names of its
|
||||||
|
# contributors may be used to endorse or promote products derived
|
||||||
|
# from this software without specific prior written permission.
|
||||||
|
#
|
||||||
|
# NO EXPRESS OR IMPLIED LICENSES TO ANY PARTY'S PATENT RIGHTS ARE
|
||||||
|
# GRANTED BY THIS LICENSE. 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.
|
||||||
|
|
||||||
|
# Author: Jim Paris <jim.paris@rigado.com>
|
||||||
|
|
||||||
|
CROSS_COMPILE = arm-none-eabi-
|
||||||
|
|
||||||
|
CC = $(CROSS_COMPILE)gcc
|
||||||
|
LD = $(CROSS_COMPILE)gcc
|
||||||
|
AS = $(CROSS_COMPILE)gcc
|
||||||
|
AR = $(CROSS_COMPILE)ar
|
||||||
|
NM = $(CROSS_COMPILE)nm
|
||||||
|
OBJCOPY = $(CROSS_COMPILE)objcopy
|
||||||
|
OBJDUMP = $(CROSS_COMPILE)objdump
|
||||||
|
STRIP = $(CROSS_COMPILE)strip
|
||||||
|
|
||||||
|
CFLAGS_OPT ?= -Os
|
||||||
|
CFLAGS_DEBUG ?= -ggdb3 -fomit-frame-pointer
|
||||||
|
CFLAGS += $(CFLAGS_OPT) $(CFLAGS_DEBUG)
|
||||||
|
CFLAGS += -std=gnu99
|
||||||
|
CFLAGS += -ffreestanding -mcpu=cortex-m3 -mthumb -mno-thumb-interwork
|
||||||
|
CFLAGS += -ffunction-sections -fdata-sections -fno-common -fno-builtin
|
||||||
|
CFLAGS += -flto
|
||||||
|
|
||||||
|
ifdef WERROR
|
||||||
|
CFLAGS += -Wall -Werror
|
||||||
|
# These warnings are triggered by existing Contiki code
|
||||||
|
CFLAGS += -Wno-error=pointer-sign
|
||||||
|
CFLAGS += -Wno-error=char-subscripts
|
||||||
|
CFLAGS += -Wno-error=unused-variable
|
||||||
|
CFLAGS += -Wno-error=unused-but-set-variable
|
||||||
|
endif
|
||||||
|
|
||||||
|
# UIP code does not follow C aliasing rules
|
||||||
|
CFLAGS += -fno-strict-aliasing
|
||||||
|
|
||||||
|
LDFLAGS = $(CFLAGS)
|
||||||
|
LDFLAGS += -specs=nosys.specs -nostartfiles
|
||||||
|
|
||||||
|
# TODO: When it becomes more commonly available, switch to newlib-nano
|
||||||
|
# for significant size reduction, by uncommenting this:
|
||||||
|
# LDFLAGS += -specs=nano.specs
|
||||||
|
|
||||||
|
LDFLAGS += -Wl,--gc-sections
|
||||||
|
LDFLAGS += -Wl,-T$(CONTIKI_CPU)/Common/GCC/ADuCRF101.ld
|
||||||
|
|
||||||
|
ASFLAGS += -c $(CFLAGS)
|
||||||
|
|
||||||
|
# Compiler-specific startup code
|
||||||
|
CONTIKI_CPU_DIRS += Common/GCC
|
||||||
|
CONTIKI_SOURCEFILES += crt0.S
|
||||||
|
|
||||||
|
# Rules
|
||||||
|
%.hex: %
|
||||||
|
$(OBJCOPY) -O ihex $^ $@
|
94
cpu/arm/aducrf101/Makefile.aducrf101.iar
Normal file
94
cpu/arm/aducrf101/Makefile.aducrf101.iar
Normal file
|
@ -0,0 +1,94 @@
|
||||||
|
# -*- makefile -*-
|
||||||
|
|
||||||
|
# Copyright (c) 2014, Analog Devices, Inc. All rights reserved.
|
||||||
|
#
|
||||||
|
# Redistribution and use in source and binary forms, with or without
|
||||||
|
# modification, are permitted (subject to the limitations in the
|
||||||
|
# disclaimer below) provided that the following conditions are met:
|
||||||
|
#
|
||||||
|
# - Redistributions of source code must retain the above copyright
|
||||||
|
# notice, this list of conditions and the following disclaimer.
|
||||||
|
#
|
||||||
|
# - 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.
|
||||||
|
#
|
||||||
|
# - Neither the name of Analog Devices, Inc. nor the names of its
|
||||||
|
# contributors may be used to endorse or promote products derived
|
||||||
|
# from this software without specific prior written permission.
|
||||||
|
#
|
||||||
|
# NO EXPRESS OR IMPLIED LICENSES TO ANY PARTY'S PATENT RIGHTS ARE
|
||||||
|
# GRANTED BY THIS LICENSE. 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.
|
||||||
|
|
||||||
|
# Author: Jim Paris <jim.paris@rigado.com>
|
||||||
|
|
||||||
|
# Filename quoting here is very tricky, and probably depends on which Windows
|
||||||
|
# build of "make" is being used. This works for mingw32-make.
|
||||||
|
|
||||||
|
ifeq ($(IAR_PATH),)
|
||||||
|
IAR_SUBPATH := $(shell ls "${PROGRAMFILES}\IAR Systems" 2>/dev/null | tail -1)
|
||||||
|
ifeq ($(IAR_SUBPATH),)
|
||||||
|
define iar_error
|
||||||
|
|
||||||
|
Unable to find the IAR installation path. Please specify IAR_PATH.
|
||||||
|
For example: $(MAKE) IAR_PATH="C:\\Program Files (x86)\\IAR Systems\\Embedded Workbench 7.0\\arm"
|
||||||
|
endef
|
||||||
|
$(error $(iar_error))
|
||||||
|
endif
|
||||||
|
IAR_PATH := ${PROGRAMFILES}\IAR Systems\${IAR_SUBPATH}\arm
|
||||||
|
endif
|
||||||
|
|
||||||
|
CC := "$(IAR_PATH)""\\bin\iccarm"
|
||||||
|
LD := "$(IAR_PATH)""\\bin\ilinkarm"
|
||||||
|
AS := "$(IAR_PATH)""\\bin\iasmarm"
|
||||||
|
AR := "$(IAR_PATH)""\\bin\iarchive"
|
||||||
|
OBJCOPY := "$(IAR_PATH)""\\bin\ielftool"
|
||||||
|
|
||||||
|
CFLAGS += -Ohz
|
||||||
|
CFLAGS += --silent
|
||||||
|
CFLAGS += --debug
|
||||||
|
CFLAGS += --endian=little
|
||||||
|
CFLAGS += --cpu=Cortex-M3
|
||||||
|
CFLAGS += -I"$(IAR_PATH)""\\inc"
|
||||||
|
CFLAGS += -D__ICCARM__
|
||||||
|
|
||||||
|
AROPTS = --create
|
||||||
|
ASFLAGS = -S -s+ -w+ --cpu Cortex-M3
|
||||||
|
|
||||||
|
LDFLAGS += --config $(CONTIKI_CPU)/Common/IAR/ADUCRF101.icf
|
||||||
|
|
||||||
|
# Compiler-specific startup code
|
||||||
|
CONTIKI_CPU_DIRS += Common/IAR
|
||||||
|
CONTIKI_SOURCEFILES += startup_ADuCRF101.S
|
||||||
|
|
||||||
|
# Rules
|
||||||
|
|
||||||
|
CUSTOM_RULE_C_TO_OBJECTDIR_O = 1
|
||||||
|
$(OBJECTDIR)/%.o: %.c | $(OBJECTDIR)
|
||||||
|
$(TRACE_CC)
|
||||||
|
$(Q)$(CC) $(CFLAGS) $< --dependencies=m $(@:.o=.d) -o $@
|
||||||
|
|
||||||
|
CUSTOM_RULE_C_TO_O = 1
|
||||||
|
%.co: %.c
|
||||||
|
$(TRACE_CC)
|
||||||
|
$(Q)$(CC) $(CFLAGS) $< -o $@
|
||||||
|
|
||||||
|
CUSTOM_RULE_C_TO_CO = 1
|
||||||
|
%.co: %.c
|
||||||
|
$(TRACE_CC)
|
||||||
|
$(Q)$(CC) $(CFLAGS) -DAUTOSTART_ENABLE $< -o $@
|
||||||
|
|
||||||
|
%.hex: %
|
||||||
|
$(OBJCOPY) --silent --ihex $^ $@
|
|
@ -43,9 +43,6 @@ static volatile clock_time_t current_clock = 0;
|
||||||
static volatile unsigned long current_seconds = 0;
|
static volatile unsigned long current_seconds = 0;
|
||||||
static unsigned int second_countdown = CLOCK_SECOND;
|
static unsigned int second_countdown = CLOCK_SECOND;
|
||||||
|
|
||||||
void
|
|
||||||
SysTick_handler(void) __attribute__ ((interrupt));
|
|
||||||
|
|
||||||
void
|
void
|
||||||
SysTick_Handler(void)
|
SysTick_Handler(void)
|
||||||
{
|
{
|
||||||
|
|
|
@ -35,7 +35,6 @@
|
||||||
* \author Jim Paris <jim.paris@rigado.com>
|
* \author Jim Paris <jim.paris@rigado.com>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <unistd.h>
|
|
||||||
#include <aducrf101-include.h>
|
#include <aducrf101-include.h>
|
||||||
|
|
||||||
static int (*uart_input_handler)(unsigned char c);
|
static int (*uart_input_handler)(unsigned char c);
|
||||||
|
@ -105,7 +104,7 @@ _write(int fd, const void *buf, size_t len)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(fd == STDOUT_FILENO || fd == STDERR_FILENO) {
|
if(fd == 1 || fd == 2) {
|
||||||
int n = len;
|
int n = len;
|
||||||
const unsigned char *p = buf;
|
const unsigned char *p = buf;
|
||||||
while(n--)
|
while(n--)
|
||||||
|
@ -114,3 +113,12 @@ _write(int fd, const void *buf, size_t len)
|
||||||
}
|
}
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
/*---------------------------------------------------------------------------*/
|
||||||
|
#ifdef __ICCARM__
|
||||||
|
/* Connect IAR's __write function to the UART. */
|
||||||
|
size_t
|
||||||
|
__write(int fd, const unsigned char *buf, size_t count)
|
||||||
|
{
|
||||||
|
return _write(fd, buf, count);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
|
@ -37,7 +37,6 @@
|
||||||
|
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <unistd.h>
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include "contiki.h"
|
#include "contiki.h"
|
||||||
|
|
Loading…
Add table
Reference in a new issue