2018-11-17 20:23:03 +01:00
|
|
|
|
README
|
|
|
|
|
======
|
|
|
|
|
|
|
|
|
|
This directory holds NuttX board support for the Maxim Integrated
|
|
|
|
|
MAX32660-EVSYS board. That board features:
|
|
|
|
|
|
|
|
|
|
o MAX32660 Microcontroller
|
|
|
|
|
- Arm Cortex-M4F, 96MHz
|
|
|
|
|
- 256KB Flash Memory
|
|
|
|
|
- 96KB SRAM
|
|
|
|
|
- 16KB Instruction Cache
|
|
|
|
|
- Two SPIs
|
|
|
|
|
- Two I2Cs
|
|
|
|
|
- Two UARTs
|
|
|
|
|
- 14 GPIOs
|
|
|
|
|
o DIP Breakout Board
|
|
|
|
|
- 100mil Pitch Dual Inline Pin Headers
|
|
|
|
|
- Breadboard Compatible
|
|
|
|
|
o Integrated Peripherals
|
|
|
|
|
- Red Indicator LED
|
|
|
|
|
- User Pushbutton
|
|
|
|
|
o MAX32625PICO-Based Debug Adapter
|
|
|
|
|
- CMSIS-DAP SWD Debugger
|
|
|
|
|
- Virtual UART Console
|
|
|
|
|
|
|
|
|
|
Contents
|
|
|
|
|
========
|
|
|
|
|
|
2018-11-22 22:01:18 +01:00
|
|
|
|
o Status
|
2018-11-17 20:23:03 +01:00
|
|
|
|
o Serial Console
|
|
|
|
|
o LEDs and Buttons
|
2018-11-26 15:01:11 +01:00
|
|
|
|
o OpenOCD
|
2018-11-17 20:23:03 +01:00
|
|
|
|
|
2018-11-22 22:01:18 +01:00
|
|
|
|
Status
|
|
|
|
|
======
|
|
|
|
|
|
|
|
|
|
2018-11-21: The port is code complete but completely untested. I am
|
|
|
|
|
still waiting to receive hardware to perform the bringup. This initial
|
|
|
|
|
port will support an NSH console: Clock configuration, timer, GPIO
|
|
|
|
|
pin configuration, ICC, and UART. Additional untested drivers are
|
|
|
|
|
complete and ready for testing: DMA, GPIO interrupts, RTC, WDT. The
|
|
|
|
|
following drivers are not implemented: I2C, SPI, I2S.
|
2018-11-27 23:50:59 +01:00
|
|
|
|
2018-11-27: I received the MAX32660-EVSYS today and made a little debug
|
|
|
|
|
progress. Added a run-from-SRAM configuration to keep from locking
|
|
|
|
|
up the board on bad configurations. The rest of the bring-up will
|
|
|
|
|
use this SRAM configuration.
|
2018-11-29 14:50:45 +01:00
|
|
|
|
The NSH prompt comes up, but there is some interrupt-related problem
|
|
|
|
|
that makes the console unusable.
|
2018-11-28 18:20:31 +01:00
|
|
|
|
2018-11-28: Found that the WFI instruction in the IDLE loop was causing
|
|
|
|
|
instability. System ran OK until it was in IDLE then it became
|
2018-11-29 14:50:45 +01:00
|
|
|
|
unstable. Commenting out the WIF restores stability. The port now
|
|
|
|
|
runs safely from FLASH although still with missing UART interrupts.
|
2018-11-28 20:01:20 +01:00
|
|
|
|
Also fixed the on-board LED which now currently reflects the state.
|
2018-11-29 14:50:45 +01:00
|
|
|
|
2018-11-29: Resolved the UART interrupt issue. The NSH configuration
|
|
|
|
|
now appears fully functional. Removed EXPERIMENTAL from configuration.
|
2018-11-29 19:12:56 +01:00
|
|
|
|
Brought in the STM32 SPI driver as a starting point. It still does
|
|
|
|
|
not build correctly. Due to conflicts, only SPI0 will be available.
|
2018-11-30 22:12:38 +01:00
|
|
|
|
2018-11-30: Completed coding of the SPI driver. Added board support
|
|
|
|
|
for SPI and for and SPI-based micro-SD card. Initial testing with no
|
|
|
|
|
device attached shows that the first single byte SPI transfer hangs
|
|
|
|
|
with 1 byte in the Tx FIFO and nothing in the Rx FIFO. Data is not
|
|
|
|
|
moving.
|
2018-11-22 22:01:18 +01:00
|
|
|
|
|
2018-12-01 13:40:50 +01:00
|
|
|
|
I need to stop and work on some other things for a while. Here are the
|
|
|
|
|
things remaining to be done:
|
|
|
|
|
|
|
|
|
|
- Test the DMA, WDT and RTC drivers. These drivers are complete but
|
|
|
|
|
untested.
|
|
|
|
|
- Finish verification of the SPI0 master driver. It currently hangs as
|
|
|
|
|
described above.
|
|
|
|
|
- Add support for missing drivers.
|
|
|
|
|
|
|
|
|
|
Missing drivers include:
|
|
|
|
|
|
|
|
|
|
- SPI17Y: SPI0 master DMA support, SPI0 Slave
|
|
|
|
|
- SPIMSS: SPI1 master/slave, I2C
|
|
|
|
|
- I2C0/1 master/slave
|
|
|
|
|
- Timer/PWM
|
|
|
|
|
|
2018-11-17 20:23:03 +01:00
|
|
|
|
Serial Console
|
|
|
|
|
==============
|
|
|
|
|
|
2018-11-19 17:47:28 +01:00
|
|
|
|
UART1 Tx and Rx signals at port P0.10 and P0.11 are connected to the
|
|
|
|
|
programming and debug header JH2 pins 2 and 3 through 1kΩ resistors.
|
|
|
|
|
This provides a convenient way to communicate with a PC though the
|
|
|
|
|
virtual serial port available in Maxim’s CMSIS-DAP debug adapter. The
|
|
|
|
|
series resistors allow for these signals to be overdriven by other
|
|
|
|
|
circuits without modifying the board.
|
2018-11-17 20:23:03 +01:00
|
|
|
|
|
|
|
|
|
LEDs and Buttons
|
|
|
|
|
================
|
|
|
|
|
|
|
|
|
|
LEDs
|
|
|
|
|
----
|
|
|
|
|
|
|
|
|
|
A single red LED is available driven by GPIO P0.13.
|
|
|
|
|
|
|
|
|
|
This LED is not used by the board port unless CONFIG_ARCH_LEDS is
|
|
|
|
|
defined. In that case, the usage by the board port is defined in
|
|
|
|
|
include/board.h and src/sam_autoleds.c. The LED is used to encode
|
|
|
|
|
OS-related events as follows:
|
|
|
|
|
|
|
|
|
|
------------------- ----------------------- ------
|
|
|
|
|
SYMBOL Meaning LED
|
|
|
|
|
------------------- ----------------------- ------
|
|
|
|
|
LED_STARTED NuttX has been started OFF
|
|
|
|
|
LED_HEAPALLOCATE Heap has been allocated OFF
|
|
|
|
|
LED_IRQSENABLED Interrupts enabled OFF
|
|
|
|
|
LED_STACKCREATED Idle stack created ON
|
|
|
|
|
LED_INIRQ In an interrupt N/C
|
|
|
|
|
LED_SIGNAL In a signal handler N/C
|
|
|
|
|
LED_ASSERTION An assertion failed N/C
|
|
|
|
|
LED_PANIC The system has crashed FLASH
|
|
|
|
|
|
|
|
|
|
Thus if the LED is statically on, NuttX has successfully booted and is,
|
|
|
|
|
apparently, running normally. If the LED is flashing at approximately
|
|
|
|
|
2Hz, then a fatal error has been detected and the system has halted.
|
|
|
|
|
|
|
|
|
|
Buttons
|
|
|
|
|
-------
|
|
|
|
|
|
|
|
|
|
An single button is available on GPIO P0.12 for use by software.
|
2018-11-26 15:01:11 +01:00
|
|
|
|
|
|
|
|
|
OpenOCD
|
|
|
|
|
=======
|
|
|
|
|
|
2018-11-27 21:47:49 +01:00
|
|
|
|
Starting OpenOCD
|
|
|
|
|
----------------
|
|
|
|
|
|
2018-11-26 15:01:11 +01:00
|
|
|
|
An Eclipse based toolchain is available for download from Maxim Integrated.
|
|
|
|
|
If you (like me) are not an IDE user then the good news is the OpenOCD for
|
|
|
|
|
the MAX32660 is available within that toolchain.
|
|
|
|
|
|
|
|
|
|
As of this writing, the OpenOCD changes for the MAX32660 are not yet
|
|
|
|
|
incorporated into the mainline OpenOCD code so the Maxim Integrated version
|
|
|
|
|
within the Eclipse-based toolchain is the only show in town. Patches for
|
|
|
|
|
the MAX32660 have been submitted and this will most likely no longer be true
|
|
|
|
|
as you read this.
|
|
|
|
|
|
|
|
|
|
The Eclipse-based toolchain installs by default at C:\Maxim under Windows.
|
|
|
|
|
The following script tracks tracks down OpenOCD in that installation
|
|
|
|
|
(assuming Cygwin, hence the /cygdrive/c for the C: drive:
|
|
|
|
|
|
|
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
|
|
set -x
|
|
|
|
|
|
|
|
|
|
OPENOCD=/cygdrive/c/Maxim/Toolchain/bin/openocd.exe
|
|
|
|
|
IFCFG="C:\Maxim\Toolchain\share\openocd\scripts\interface\max32660_hdk.cfg"
|
|
|
|
|
MCUCFG="C:\Maxim\Toolchain\share\openocd\scripts\target\max32660.cfg"
|
|
|
|
|
|
2018-11-27 21:47:49 +01:00
|
|
|
|
${OPENOCD} ${1} -f ${IFCFG} # -f ${MCUCFG}
|
|
|
|
|
|
|
|
|
|
Loading Code:
|
|
|
|
|
|
|
|
|
|
Code can be loaded into FLASH using the convenient ARM MBED drag'n'drop
|
2018-11-27 23:50:59 +01:00
|
|
|
|
interface. Or it can be loaded into FLASH (or SRAM) using GDB as follows:
|
2018-11-27 21:47:49 +01:00
|
|
|
|
|
|
|
|
|
$ arm-none-eabi-gdb
|
|
|
|
|
(gdb) target remote localhost:3333
|
|
|
|
|
(gdb) mon reset
|
|
|
|
|
(gdb) mon halt
|
|
|
|
|
(gdb) load nuttx
|
|
|
|
|
|
|
|
|
|
This does not work so reliably for me, however.
|
|
|
|
|
|
2018-11-27 23:50:59 +01:00
|
|
|
|
Debugging from FLASH:
|
2018-11-27 21:47:49 +01:00
|
|
|
|
|
|
|
|
|
$ arm-none-eabi-gdb
|
|
|
|
|
(gdb) target remote localhost:3333
|
|
|
|
|
(gdb) mon reset
|
2018-11-28 18:20:31 +01:00
|
|
|
|
(gdb) mon reg pc __start # Set PC to __start entry point
|
2018-11-27 21:47:49 +01:00
|
|
|
|
(gdb) file nuttx
|
|
|
|
|
(gdb) b os_start
|
|
|
|
|
(gdb) c
|
|
|
|
|
|
|
|
|
|
Also not very reliable.
|
2018-11-27 23:50:59 +01:00
|
|
|
|
|
|
|
|
|
Debugging from SRAM:
|
|
|
|
|
|
2018-11-28 18:20:31 +01:00
|
|
|
|
Same except (1) that the __start entry point is 0x2000011c, not 0x11c, and
|
|
|
|
|
the code needs to be reloaded into SRAM each time:
|
|
|
|
|
|
|
|
|
|
(gdb) target remote localhost:3333
|
|
|
|
|
(gdb) mon reset
|
|
|
|
|
(gdb) mon halt
|
|
|
|
|
(gdb) load nuttx # Re-load code into SRAM
|
|
|
|
|
(gdb) mon reg pc __start # Set PC to __start entry point
|
|
|
|
|
(gdb) file nuttx
|
|
|
|
|
(gdb) b os_start
|
|
|
|
|
(gdb) c
|
2018-11-27 23:50:59 +01:00
|
|
|
|
|
|
|
|
|
Recovering from bad code in FLASH:
|
|
|
|
|
|
|
|
|
|
In my initial debug effort, I had a lethal bug that I thought had bricked
|
|
|
|
|
the board. It appears that initialization logic put the MAX32660 in a bad
|
|
|
|
|
state so that every time that I reset the board, I would re-enter this
|
|
|
|
|
same bad state and I could not connect the CMSIS-DAP debugger.
|
|
|
|
|
|
|
|
|
|
I was able to recover. I jumpered GND to RSTn the used the MBED MSC
|
|
|
|
|
interface to copy a known safe 'SysTick' demo program. The copy hung and
|
|
|
|
|
timed out with an error message. I yanked the jumper off RSTn and asked
|
|
|
|
|
to re-try copy. It continued to burn the safe code demo! I fixed it!
|
|
|
|
|
too much drama.
|