This is the initial commit the port to the SAMD5x/E5x MCU family and also support for the Adafruit Metro M4 board. It port is untested and unfinished. It currently will not even link due to some missing clock related logic.
Squashed commit of the following:
arch/arm/src/samd5e5: Clean-up EIC logic.
arch/arm/src/samd5e5: Fix some compilation issues; Still issues with the EIC logic from samd2x.
arch/arm/src/samd5e5: Fix some compilation issues; bring in some EIC logic from samd2x.
arch/arm/src/samd5e5: Add NVMCTRL header file, fix some compiler problems, misc. clean-up.
configs/metro-m4: Add LED support.
arch/arm/src/samd5e5: Bring in SAML21 clock configuration. This is a WIP; it cannot possible even compile yet.
arch/arm/src/samd5e5: Leverage Cortex-M4 interrupt and SysTick logic from the SAM3/4.
arch/arm/src/samd5e5: Add SERCOM utility function.
arch/arm/src/samd5e5: Bring all SERCOM USART logic from SAMD2L2 to SAMD5E5. This is a brute coy with nothing more than more that name changes and extension from 5 to 7 SERCOMs.
arch/arm/src/samd5e5: Add sam_config.h header file
arch/arm/src/samd5e5/: Add Generic Clock (GCLK) utility functions.
arch/arm/src/samd5e5: Add EVSYS register definition file
arch/arm/src/samd5e5 and configs/metro-m4: Use SERCOM3 for the Arduino serial shield as console.
arch/arm/src/samd5e5/chip: Add SERCOM USART, SPI, I2C master, and slave register defintions header files
arch/arm/src/samd5e5/chip: Add AES, PM, TRNG, and WDT header files.
arch/arm/src/samd5e5/chip: Add pin multiplexing header files.
Various fixes to configuration system; fix metro-m4/nsh defconfig file.
configs/metro-m4: Add initial support for the Adafruit Metro M4 board.
arch/arm/src/samd5e5: Add peripheral clock helpers.
arch/arm/src/samd5e5/chip: Add PAC register definition header file. Fix some errors in the memory map header file.
arch/arm/src/samd5e5: Add chip.h headerf file.
arch/arm/src/samd5e5: Add PORT register definitions and support from SAML21.
arch/arm/include/samd5e5: Add interrupt vector definitions.
arch/arm/src/samd5e5: Add some boilerplate files. Correct some typos.
arch/arm/src/samd5e5/chip/sam_eic.h: Add EIC register definitions.
arch/arm/src/samd5e5/chip: Add OSC32KCTRL and OSCCTRL register definitions.
arch/arm/src/samd5e5/chip: Add GCLK, MCLK, and RSTC header files.
arch/arm/src/samd5e5/chip/sam_cmcc.h: Add CMCC register definitions
arch/arm/src/samd5e5/chip/sam_supc.h: Add SUPC header file.
arch/arm/src/samd5e5: Add start-up logic.
arch/arm/src/samd5e5: Add Make.defs file
arch/arm/src/samd5e5/chip: Add memory map header file.
arch/arm/include/samd5e5: Add chip.h header file.
arch/arm/Kconfig and arch/arm/src/samd5e5/Kconfig: Add configuration logic for the SAMD5x/Ex family.
2018-07-27 02:08:58 +08:00
|
|
|
#
|
|
|
|
# For a description of the syntax of this configuration file,
|
|
|
|
# see the file kconfig-language.txt in the NuttX tools repository.
|
|
|
|
#
|
|
|
|
|
|
|
|
if ARCH_BOARD_METRO_M4
|
2018-08-04 05:26:44 +08:00
|
|
|
|
|
|
|
choice
|
|
|
|
prompt "Execution memory"
|
|
|
|
default METRO_M4_RUNFROMFLASH
|
|
|
|
|
|
|
|
config METRO_M4_RUNFROMFLASH
|
|
|
|
bool "Run from FLASH"
|
2023-02-09 16:01:01 +08:00
|
|
|
depends on BOOT_RUNFROMFLASH
|
2018-08-04 05:26:44 +08:00
|
|
|
---help---
|
|
|
|
This is the normal configuration for building METRO M4 code.
|
|
|
|
|
|
|
|
config METRO_M4_RUNFROMSRAM
|
|
|
|
bool "Run from SRAM"
|
2023-02-09 16:01:01 +08:00
|
|
|
depends on BOOT_RUNFROMISRAM
|
2018-08-04 05:26:44 +08:00
|
|
|
---help---
|
|
|
|
During early bring-up, it is safer to execute entirely from
|
|
|
|
SRAM until you are confident in the initialization logic.
|
|
|
|
Then you can safely switch to FLASH.
|
|
|
|
|
|
|
|
REVISIT: This auto-selects CONFIG_BOOT_RUNFROMISRAM but I have
|
|
|
|
found, with some difficulty, that that choice still defaults to
|
|
|
|
CONFIG_BOOT_RUNFROMFLASH, causing link-time failures when running
|
|
|
|
from SRAM.
|
|
|
|
|
|
|
|
endchoice # Execution memory
|
2018-09-02 04:38:19 +08:00
|
|
|
|
|
|
|
config METRO_M4_32KHZXTAL
|
|
|
|
bool "32.768 KHz XTAL"
|
|
|
|
default n
|
|
|
|
---help---
|
|
|
|
According to the schematic, a 32.768 KHz crystal is installed on
|
|
|
|
board. However, I have been unable to use this crystal and thought
|
|
|
|
perhaps it is missing or defective on my board (there is a metal
|
|
|
|
package that could be a crystal on board, but I am not certain).
|
|
|
|
Another, more likely option is that there is a coding error on my
|
|
|
|
part that prevents the 32.768 KHz crystal from usable(?)
|
|
|
|
|
|
|
|
The configuration defaults to using the always-on OSCULP32 as the
|
|
|
|
slow clock source. This option will select instead XOSC32 as the
|
|
|
|
slow clock source.
|
|
|
|
|
2020-08-20 12:07:22 +08:00
|
|
|
config METRO_M4_AT24_BLOCKMOUNT
|
|
|
|
bool "AT24 Serial EEPROM auto-mount"
|
|
|
|
default n
|
|
|
|
depends on MTD_AT24XX
|
|
|
|
---help---
|
|
|
|
Automatically initialize the AT24 I2C EEPROM driver when NSH starts.
|
|
|
|
|
|
|
|
choice
|
|
|
|
prompt "AT24 serial EPPROM configuration"
|
|
|
|
default METRO_M4_AT24_FTL
|
|
|
|
depends on METRO_M4_AT24_BLOCKMOUNT
|
|
|
|
|
|
|
|
config METRO_M4_AT24_FTL
|
|
|
|
bool "Create AT24 block driver"
|
|
|
|
---help---
|
|
|
|
Create the MTD driver for the AT24 and "wrap" the AT24 as a standard
|
|
|
|
block driver that could then, for example, be mounted using FAT or
|
|
|
|
any other file system. Any file system may be used, but there will
|
|
|
|
be no wear-leveling.
|
|
|
|
|
|
|
|
config METRO_M4_AT24_NXFFS
|
|
|
|
bool "Create AT24 NXFFS file system"
|
|
|
|
depends on FS_NXFFS
|
|
|
|
---help---
|
|
|
|
Create the MTD driver for the AT24 and mount the AT24 device as
|
|
|
|
a wear-leveling, NuttX FLASH file system (NXFFS). The downside of
|
|
|
|
NXFFS is that it can be very slow.
|
|
|
|
|
|
|
|
endchoice # AT24 serial EPPROM configuration
|
|
|
|
|
2020-08-11 04:11:34 +08:00
|
|
|
if FS_AUTOMOUNTER
|
|
|
|
config METRO_M4_USB_AUTOMOUNT
|
|
|
|
bool "USB automounter"
|
|
|
|
default n
|
|
|
|
|
|
|
|
if METRO_M4_USB_AUTOMOUNT
|
|
|
|
|
|
|
|
config METRO_M4_USB_AUTOMOUNT_FSTYPE
|
|
|
|
string "USB file system type"
|
|
|
|
default "vfat"
|
|
|
|
|
|
|
|
config METRO_M4_USB_AUTOMOUNT_BLKDEV
|
|
|
|
string "USB block device"
|
|
|
|
default "/dev/sda"
|
|
|
|
|
|
|
|
config METRO_M4_USB_AUTOMOUNT_MOUNTPOINT
|
|
|
|
string "USB mount point"
|
|
|
|
default "/mnt/usb"
|
|
|
|
|
|
|
|
config METRO_M4_USB_AUTOMOUNT_DDELAY
|
|
|
|
int "USB debounce delay (milliseconds)"
|
|
|
|
default 1000
|
|
|
|
|
|
|
|
config METRO_M4_USB_AUTOMOUNT_UDELAY
|
|
|
|
int "USB unmount retry delay (milliseconds)"
|
|
|
|
default 2000
|
|
|
|
|
|
|
|
endif # METRO_M4_USB_AUTOMOUNT
|
|
|
|
endif # FS_AUTOMOUNTER
|
2018-09-02 04:38:19 +08:00
|
|
|
|
2018-08-04 05:26:44 +08:00
|
|
|
endif # ARCH_BOARD_METRO_M4
|