mirror of
https://github.com/apache/nuttx.git
synced 2025-01-13 10:58:49 +08:00
avr32dev1: Fix compilation and nsh boot-up
I recently imported NuttX version 6.0 (and nsh) into a Microchip Studio project [1] on Windows to figure out what was going wrong with the avr32dev1 build. I also briefly checked NuttX version 10. I worked with the assumption that the avr32 (avr32dev1) specific changes to the codebase were minimal across NuttX releases. For the initial proof of concept I used Microchip Studio version 7.0 (with the recent Microchip's ASF updates). I use avr32-gcc (4.4.7) hosted here [2] for building NuttX for avr32dev1 on GNU/Linux. Even with the Microchip Studio project, I had initial debug problems with just stepping through the code a line at a time. I had to bring in crt0, a trampoline stub and the linker file from one of my older projects to really build on the suspicion I had with the linker file. Perhaps an older version of avr32-gcc did something differently. I am not sure about this. I used avr32-objdump to see the output sections of the generated elf file. I just had to tweak the linker script to ensure correct linking of the sections. With those changes, I was able to inspect the UART sections within NuttX Microchip Studio project. Second important change: the transmit pin: I had to reassign the pin to see the nsh console. These are the currently assigned UART pins: RX: PA_24 -> Physical IC pin 59 TX: PB_02 -> Physical IC pin 24 For the avr32dev1 board, they are pins: J1 (berg pin 28) and J2 (berg pin 10). In addition, the PR fixes silly compilation problems with avr32dev1. I have tested the nsh build with my avr32dev1 boards. I used Atmel ICE to program one of them (flash at 0x80000000) and dfu-programmer to test my other board (flash at 0x80002000). The other RS-232 parameters are the same as they were. References: [1]: https://github.com/ramangopalan/nuttx_avr32dev1 [2]: https://github.com/ramangopalan/avr32-gnu-toolchain-linux_x86_64
This commit is contained in:
parent
eaba1bef1e
commit
0967eb4c24
4 changed files with 16 additions and 11 deletions
|
@ -79,7 +79,7 @@ typedef int _wchar_t;
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define unsigned signed
|
#define unsigned signed
|
||||||
typedef __SIZE_TYPE__ _ssize_t;
|
typedef int _ssize_t; /* Keep avr32-gcc 4.4.7 happy. */
|
||||||
#undef unsigned
|
#undef unsigned
|
||||||
typedef __SIZE_TYPE__ _size_t;
|
typedef __SIZE_TYPE__ _size_t;
|
||||||
#elif defined(CONFIG_ARCH_SIZET_LONG)
|
#elif defined(CONFIG_ARCH_SIZET_LONG)
|
||||||
|
|
|
@ -124,7 +124,7 @@
|
||||||
/* Pin muliplexing selecion *************************************************/
|
/* Pin muliplexing selecion *************************************************/
|
||||||
|
|
||||||
#define PINMUX_USART1_RXD PINMUX_USART1_RXD_2
|
#define PINMUX_USART1_RXD PINMUX_USART1_RXD_2
|
||||||
#define PINMUX_USART1_TXD PINMUX_USART1_TXD_1
|
#define PINMUX_USART1_TXD PINMUX_USART1_TXD_2
|
||||||
|
|
||||||
/* LED definitions **********************************************************/
|
/* LED definitions **********************************************************/
|
||||||
|
|
||||||
|
|
|
@ -39,7 +39,8 @@ MEMORY
|
||||||
SECTIONS
|
SECTIONS
|
||||||
{
|
{
|
||||||
.text : {
|
.text : {
|
||||||
_stext = ABSOLUTE(.);
|
. = ALIGN(4);
|
||||||
|
_stext = .;
|
||||||
*(.vectors)
|
*(.vectors)
|
||||||
*(.text .text.*)
|
*(.text .text.*)
|
||||||
*(.fixup)
|
*(.fixup)
|
||||||
|
@ -51,27 +52,29 @@ SECTIONS
|
||||||
*(.got)
|
*(.got)
|
||||||
*(.gcc_except_table)
|
*(.gcc_except_table)
|
||||||
*(.gnu.linkonce.r.*)
|
*(.gnu.linkonce.r.*)
|
||||||
_etext = ABSOLUTE(.);
|
. = ALIGN(4);
|
||||||
|
_etext = .;
|
||||||
} > flash
|
} > flash
|
||||||
|
|
||||||
_eronly = ABSOLUTE(.); /* See below */
|
_eronly = .; /* See below */
|
||||||
|
|
||||||
.data : {
|
.data : AT(_etext) {
|
||||||
_sdata = ABSOLUTE(.);
|
. = ALIGN(4);
|
||||||
|
_sdata = .;
|
||||||
*(.data .data.*)
|
*(.data .data.*)
|
||||||
*(.gnu.linkonce.d.*)
|
*(.gnu.linkonce.d.*)
|
||||||
CONSTRUCTORS
|
CONSTRUCTORS
|
||||||
. = ALIGN(4);
|
. = ALIGN(4);
|
||||||
_edata = ABSOLUTE(.);
|
_edata = .;
|
||||||
} > intram AT > flash
|
} > intram
|
||||||
|
|
||||||
.bss : { /* BSS */
|
.bss : { /* BSS */
|
||||||
_sbss = ABSOLUTE(.);
|
_sbss = .;
|
||||||
*(.bss .bss.*)
|
*(.bss .bss.*)
|
||||||
*(.gnu.linkonce.b.*)
|
*(.gnu.linkonce.b.*)
|
||||||
*(COMMON)
|
*(COMMON)
|
||||||
. = ALIGN(4);
|
. = ALIGN(4);
|
||||||
_ebss = ABSOLUTE(.);
|
_ebss = .;
|
||||||
} > intram
|
} > intram
|
||||||
/* Stabs debugging sections. */
|
/* Stabs debugging sections. */
|
||||||
.stab 0 : { *(.stab) }
|
.stab 0 : { *(.stab) }
|
||||||
|
|
|
@ -24,8 +24,10 @@ ifeq ($(CONFIG_STACK_CANARIES),y)
|
||||||
CSRCS += lib_stackchk.c
|
CSRCS += lib_stackchk.c
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifeq ($(CONFIG_LTO_NONE),n)
|
||||||
assert/lib_assert.c_CFLAGS += -fno-lto
|
assert/lib_assert.c_CFLAGS += -fno-lto
|
||||||
assert/lib_stackchk.c_CFLAGS += -fno-lto
|
assert/lib_stackchk.c_CFLAGS += -fno-lto
|
||||||
|
endif
|
||||||
|
|
||||||
# Add the assert directory to the build
|
# Add the assert directory to the build
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue