arch/arm/src/samd5e5: Updates to clock configuration from initial testing. With these changes the boot up gets through clock configuration but hangs in the low-level USART configuration before completing the boot.

This commit is contained in:
Gregory Nutt 2018-08-31 09:58:53 -06:00
parent 345d088661
commit ff906b0bef
9 changed files with 124 additions and 58 deletions

View File

@ -48,7 +48,7 @@
* Pre-processor Definitions * Pre-processor Definitions
********************************************************************************************/ ********************************************************************************************/
#define SAM_NGLCK 12 /* 12 Clock generators, 0-11 */ #define SAM_NGCLK 12 /* 12 Clock generators, 0-11 */
#define SAM_NCHANNELS 48 /* 48 Clock generators, 0..47 */ #define SAM_NCHANNELS 48 /* 48 Clock generators, 0..47 */
/* GCLK register offsets ********************************************************************/ /* GCLK register offsets ********************************************************************/
@ -98,7 +98,7 @@
# define GCLK_GENCTRL_SRC_XOSC0 (0 << GCLK_GENCTRL_SRC_SHIFT) /* XOSC 0 oscillator input */ # define GCLK_GENCTRL_SRC_XOSC0 (0 << GCLK_GENCTRL_SRC_SHIFT) /* XOSC 0 oscillator input */
# define GCLK_GENCTRL_SRC_XOSC1 (1 << GCLK_GENCTRL_SRC_SHIFT) /* XOSC 1 oscillator input */ # define GCLK_GENCTRL_SRC_XOSC1 (1 << GCLK_GENCTRL_SRC_SHIFT) /* XOSC 1 oscillator input */
# define GCLK_GENCTRL_SRC_GCLK_IN (2 << GCLK_GENCTRL_SRC_SHIFT) /* Generator input pad */ # define GCLK_GENCTRL_SRC_GCLK_IN (2 << GCLK_GENCTRL_SRC_SHIFT) /* Generator input pad */
# define GCLK_GENCTRL_SRC_GLCK_GEN1 (3 << GCLK_GENCTRL_SRC_SHIFT) /* Generic clock generater 1 output */ # define GCLK_GENCTRL_SRC_GCLK_GEN1 (3 << GCLK_GENCTRL_SRC_SHIFT) /* Generic clock generater 1 output */
# define GCLK_GENCTRL_SRC_OSCULP32K (4 << GCLK_GENCTRL_SRC_SHIFT) /* OSCULP32K oscillator output */ # define GCLK_GENCTRL_SRC_OSCULP32K (4 << GCLK_GENCTRL_SRC_SHIFT) /* OSCULP32K oscillator output */
# define GCLK_GENCTRL_SRC_XOSC32K (5 << GCLK_GENCTRL_SRC_SHIFT) /* XOSC32K oscillator output */ # define GCLK_GENCTRL_SRC_XOSC32K (5 << GCLK_GENCTRL_SRC_SHIFT) /* XOSC32K oscillator output */
# define GCLK_GENCTRL_SRC_DFLL (6 << GCLK_GENCTRL_SRC_SHIFT) /* DFLL oscillator output */ # define GCLK_GENCTRL_SRC_DFLL (6 << GCLK_GENCTRL_SRC_SHIFT) /* DFLL oscillator output */

View File

@ -277,7 +277,7 @@
#define OSCCTRL_DPLLCTRLB_REFLCK_SHIFT (5) /* Bits 5-7: Reference clock selection */ #define OSCCTRL_DPLLCTRLB_REFLCK_SHIFT (5) /* Bits 5-7: Reference clock selection */
#define OSCCTRL_DPLLCTRLB_REFLCK_MASK (3 << OSCCTRL_DPLLCTRLB_REFLCK_SHIFT) #define OSCCTRL_DPLLCTRLB_REFLCK_MASK (3 << OSCCTRL_DPLLCTRLB_REFLCK_SHIFT)
# define OSCCTRL_DPLLCTRLB_REFLCK(n) ((uint32_t)(n) << OSCCTRL_DPLLCTRLB_REFLCK_SHIFT) # define OSCCTRL_DPLLCTRLB_REFLCK(n) ((uint32_t)(n) << OSCCTRL_DPLLCTRLB_REFLCK_SHIFT)
# define OSCCTRL_DPLLCTRLB_REFLCK_GLCK (0 << OSCCTRL_DPLLCTRLB_REFLCK_SHIFT) /* Dedicated GCLK clock reference */ # define OSCCTRL_DPLLCTRLB_REFLCK_GCLK (0 << OSCCTRL_DPLLCTRLB_REFLCK_SHIFT) /* Dedicated GCLK clock reference */
# define OSCCTRL_DPLLCTRLB_REFLCK_XOSC32 (1 << OSCCTRL_DPLLCTRLB_REFLCK_SHIFT) /* XOSC32K clock reference (default) */ # define OSCCTRL_DPLLCTRLB_REFLCK_XOSC32 (1 << OSCCTRL_DPLLCTRLB_REFLCK_SHIFT) /* XOSC32K clock reference (default) */
# define OSCCTRL_DPLLCTRLB_REFLCK_XOSC0 (2 << OSCCTRL_DPLLCTRLB_REFLCK_SHIFT) /* XOSC0 clock reference */ # define OSCCTRL_DPLLCTRLB_REFLCK_XOSC0 (2 << OSCCTRL_DPLLCTRLB_REFLCK_SHIFT) /* XOSC0 clock reference */
# define OSCCTRL_DPLLCTRLB_REFLCK_XOSC1 (3 << OSCCTRL_DPLLCTRLB_REFLCK_SHIFT) /* XOSC2 clock reference */ # define OSCCTRL_DPLLCTRLB_REFLCK_XOSC1 (3 << OSCCTRL_DPLLCTRLB_REFLCK_SHIFT) /* XOSC2 clock reference */

View File

@ -78,8 +78,8 @@ static const struct sam_clockconfig_s g_initial_clocking =
{ {
.waitstates = BOARD_FLASH_WAITSTATES, .waitstates = BOARD_FLASH_WAITSTATES,
.cpudiv = BOARD_MCLK_CPUDIV, .cpudiv = BOARD_MCLK_CPUDIV,
.glckset1 = BOARD_GCLK_SET1, .gclkset1 = BOARD_GCLK_SET1,
.glckset2 = BOARD_GCLK_SET2, .gclkset2 = BOARD_GCLK_SET2,
.cpu_frequency = BOARD_CPU_FREQUENCY, .cpu_frequency = BOARD_CPU_FREQUENCY,
#if BOARD_HAVE_XOSC32K != 0 #if BOARD_HAVE_XOSC32K != 0
.xosc32k = .xosc32k =
@ -141,6 +141,7 @@ static const struct sam_clockconfig_s g_initial_clocking =
.bplckc = BOARD_DFLL_BPLCKC, .bplckc = BOARD_DFLL_BPLCKC,
.waitlock = BOARD_DFLL_WAITLOCK, .waitlock = BOARD_DFLL_WAITLOCK,
.caliben = BOARD_DFLL_CALIBEN, .caliben = BOARD_DFLL_CALIBEN,
.gclklock = BOARD_DFLL_GCLKLOCK,
.fcalib = BOARD_DFLL_FCALIB, .fcalib = BOARD_DFLL_FCALIB,
.ccalib = BOARD_DFLL_CCALIB, .ccalib = BOARD_DFLL_CCALIB,
.fstep = BOARD_DFLL_FSTEP, .fstep = BOARD_DFLL_FSTEP,
@ -157,6 +158,7 @@ static const struct sam_clockconfig_s g_initial_clocking =
.wuf = BOARD_DPLL0_WUF, .wuf = BOARD_DPLL0_WUF,
.runstdby = BOARD_DPLL0_RUNSTDBY, .runstdby = BOARD_DPLL0_RUNSTDBY,
.ondemand = BOARD_DPLL0_ONDEMAND, .ondemand = BOARD_DPLL0_ONDEMAND,
.reflock = BOARD_DPLL0_REFLOCK,
.refclk = BOARD_DPLL0_REFCLK, .refclk = BOARD_DPLL0_REFCLK,
.ltime = BOARD_DPLL0_LTIME, .ltime = BOARD_DPLL0_LTIME,
.filter = BOARD_DPLL0_FILTER, .filter = BOARD_DPLL0_FILTER,
@ -173,6 +175,7 @@ static const struct sam_clockconfig_s g_initial_clocking =
.wuf = BOARD_DPLL1_WUF, .wuf = BOARD_DPLL1_WUF,
.runstdby = BOARD_DPLL1_RUNSTDBY, .runstdby = BOARD_DPLL1_RUNSTDBY,
.ondemand = BOARD_DPLL1_ONDEMAND, .ondemand = BOARD_DPLL1_ONDEMAND,
.reflock = BOARD_DPLL1_REFLOCK,
.refclk = BOARD_DPLL1_REFCLK, .refclk = BOARD_DPLL1_REFCLK,
.ltime = BOARD_DPLL1_LTIME, .ltime = BOARD_DPLL1_LTIME,
.filter = BOARD_DPLL1_FILTER, .filter = BOARD_DPLL1_FILTER,
@ -609,7 +612,7 @@ static inline void sam_mclk_configure(uint8_t cpudiv)
* Name: sam_gclk_configure * Name: sam_gclk_configure
* *
* Description: * Description:
* Configure one GLCK * Configure one GCLK
* *
****************************************************************************/ ****************************************************************************/
@ -618,11 +621,11 @@ static void sam_gclk_configure(uintptr_t regaddr,
{ {
uint32_t regval; uint32_t regval;
/* Are we enabling or disabling the GLCK? */ /* Are we enabling or disabling the GCLK? */
if (config->enable) if (config->enable)
{ {
/* Get the GLCK configuration */ /* Get the GCLK configuration */
regval = GCLK_GENCTRL_SRC(config->source) | GCLK_GENCTRL_GENEN | regval = GCLK_GENCTRL_SRC(config->source) | GCLK_GENCTRL_GENEN |
GCLK_GENCTRL1_DIV(config->div); GCLK_GENCTRL1_DIV(config->div);
@ -654,7 +657,7 @@ static void sam_gclk_configure(uintptr_t regaddr,
} }
else else
{ {
/* Disable the GLCK */ /* Disable the GCLK */
regval = 0; regval = 0;
} }
@ -668,7 +671,7 @@ static void sam_gclk_configure(uintptr_t regaddr,
* Name: sam_gclkset_configure * Name: sam_gclkset_configure
* *
* Description: * Description:
* Configure a set of GLCKs * Configure a set of GCLKs
* *
****************************************************************************/ ****************************************************************************/
@ -680,7 +683,7 @@ static void sam_gclkset_configure(uint16_t gclkset,
/* Try every GCLK */ /* Try every GCLK */
for (gclk = 0; gclk < SAM_NGLCK && gclkset != 0; gclk++) for (gclk = 0; gclk < SAM_NGCLK && gclkset != 0; gclk++)
{ {
/* Check if this one is in the set */ /* Check if this one is in the set */
@ -720,14 +723,17 @@ static void sam_dfll_configure(const struct sam_dfll_config_s *config)
putreg8(0, SAM_OSCCTRL_DFLLCTRLA); putreg8(0, SAM_OSCCTRL_DFLLCTRLA);
/* If we are running in closed loop mode and we are in USB clock recover /* If we are running in closed loop mode and we are in USB clock recover
* mode, then set up the input source GCLK channel. * mode, then set up the input source GCLK channel (unless it has already
* been configured and the configuration is locked).
*/ */
if (config->usbcrm && config->mode) if (config->usbcrm && config->mode &&
!sam_gclk_chan_locked(GCLK_CHAN_OSCCTRL_DFLL))
{ {
/* Configure the GCLK channel */ /* Configure the DFLL GCLK channel to use the GCLK source. */
sam_gclk_chan_enable(GCLK_CHAN_OSCCTRL_DFLL, config->gclk, true); sam_gclk_chan_enable(GCLK_CHAN_OSCCTRL_DFLL, config->gclk,
(bool)config->gclklock);
} }
/* Setup the DFLLMUL register */ /* Setup the DFLLMUL register */
@ -905,7 +911,7 @@ static void sam_dfll_gclkready(const struct sam_dfll_config_s *config)
{ {
} }
/* Set the source of GLCK0 to to the configured source. */ /* Set the source of GCLK0 to to the configured source. */
regval32 = getreg32(SAM_GCLK_GENCTRL(0)); regval32 = getreg32(SAM_GCLK_GENCTRL(0));
regval32 &= ~GCLK_GENCTRL_SRC_MASK; regval32 &= ~GCLK_GENCTRL_SRC_MASK;
@ -924,15 +930,16 @@ static void sam_dfll_gclkready(const struct sam_dfll_config_s *config)
static void sam_dpll_gclkchannel(uint8_t chan, static void sam_dpll_gclkchannel(uint8_t chan,
const struct sam_dpll_config_s *config) const struct sam_dpll_config_s *config)
{ {
/* Check if we are using a dedicated GCLK as the reference clock (vs. the /* Check if we are using a dedicated GCLK as the reference clock. If so
* common GCLK0). * configure GCLK unless it has already been configured and configuration
* registers have been locked.
*/ */
if (config->refclk != 0) if (config->refclk == 0 && !sam_gclk_chan_locked(chan))
{ {
/* Yes.. configure the GCLK channel */ /* Yes.. configure the GCLK channel that will be used as refclk source */
sam_gclk_chan_enable(chan, config->gclk, true); sam_gclk_chan_enable(chan, config->gclk, (bool)config->reflock);
} }
} }
@ -1109,7 +1116,7 @@ void sam_clock_configure(const struct sam_clockconfig_s *config)
/* Pre-configure some GCLKs before configuring the DPLLs */ /* Pre-configure some GCLKs before configuring the DPLLs */
sam_gclkset_configure(config->glckset1, config->gclk); sam_gclkset_configure(config->gclkset1, config->gclk);
/* Configure loops: DFLL, DPLL0, and DPLL1. */ /* Configure loops: DFLL, DPLL0, and DPLL1. */
@ -1117,7 +1124,7 @@ void sam_clock_configure(const struct sam_clockconfig_s *config)
/* Configure the renaming GCLKs before configuring the DPLLs */ /* Configure the renaming GCLKs before configuring the DPLLs */
sam_gclkset_configure(config->glckset2, config->gclk); sam_gclkset_configure(config->gclkset2, config->gclk);
/* Check if the number of wait states is increasing or decreasing */ /* Check if the number of wait states is increasing or decreasing */

View File

@ -127,6 +127,7 @@ struct sam_dfll_config_s
uint8_t bplckc : 1; /* Bypass coarse clock */ uint8_t bplckc : 1; /* Bypass coarse clock */
uint8_t waitlock : 1; /* Wait lock */ uint8_t waitlock : 1; /* Wait lock */
uint8_t caliben : 1; /* Overwrite factory calibration */ uint8_t caliben : 1; /* Overwrite factory calibration */
uint8_t gclklock : 1; /* Lock GCLK source clock configuration */
uint8_t fcalib; /* Fine calibration value (if caliben != 0) */ uint8_t fcalib; /* Fine calibration value (if caliben != 0) */
uint8_t ccalib; /* Coarse calibration value (if caliben != 0) */ uint8_t ccalib; /* Coarse calibration value (if caliben != 0) */
uint8_t fstep; /* Fine maximum step */ uint8_t fstep; /* Fine maximum step */
@ -145,6 +146,7 @@ struct sam_dpll_config_s
uint8_t wuf : 1; /* Wake up fast */ uint8_t wuf : 1; /* Wake up fast */
uint8_t runstdby : 1; /* Run in standby */ uint8_t runstdby : 1; /* Run in standby */
uint8_t ondemand : 1; /* On demand clock activation */ uint8_t ondemand : 1; /* On demand clock activation */
uint8_t reflock : 1; /* Lock GCLK clock reference configuration */
uint8_t refclk; /* Reference clock selection uint8_t refclk; /* Reference clock selection
* 0 Dedicated GCLK clock reference * 0 Dedicated GCLK clock reference
* 1 XOSC32K clock reference * 1 XOSC32K clock reference
@ -190,7 +192,7 @@ struct sam_gclk_config_s
uint8_t oe : 1; /* True: Output enable */ uint8_t oe : 1; /* True: Output enable */
uint8_t divsel : 1; /* True: Clock source divider */ uint8_t divsel : 1; /* True: Clock source divider */
uint8_t runstdby : 1; /* Run in standby */ uint8_t runstdby : 1; /* Run in standby */
uint8_t source; /* GLCK clock source: uint8_t source; /* GCLK clock source:
* 0 XOSC 0 oscillator input * 0 XOSC 0 oscillator input
* 1 XOSC 1 oscillator input * 1 XOSC 1 oscillator input
* 2 Generator input pad * 2 Generator input pad
@ -209,8 +211,8 @@ struct sam_clockconfig_s
{ {
uint8_t waitstates; /* NVM read wait states 9-15 */ uint8_t waitstates; /* NVM read wait states 9-15 */
uint8_t cpudiv; /* MCLK divider to get CPU frequency */ uint8_t cpudiv; /* MCLK divider to get CPU frequency */
uint16_t glckset1; /* GLCKs to initialize prior to DPLL init */ uint16_t gclkset1; /* GCLKs to initialize prior to DPLL init */
uint16_t glckset2; /* GLCKs to initialize after to DPLL init */ uint16_t gclkset2; /* GCLKs to initialize after to DPLL init */
uint32_t cpu_frequency; /* Resulting CPU frequency */ uint32_t cpu_frequency; /* Resulting CPU frequency */
#if BOARD_HAVE_XOSC32K != 0 #if BOARD_HAVE_XOSC32K != 0
struct sam_xosc32_config_s xosc32k; /* XOSC32 configuration */ struct sam_xosc32_config_s xosc32k; /* XOSC32 configuration */
@ -223,7 +225,7 @@ struct sam_clockconfig_s
#endif #endif
struct sam_dfll_config_s dfll; /* DFLL configuration */ struct sam_dfll_config_s dfll; /* DFLL configuration */
struct sam_dpll_config_s dpll[2]; /* DPLL0/1 configurations */ struct sam_dpll_config_s dpll[2]; /* DPLL0/1 configurations */
struct sam_gclk_config_s gclk[12]; /* GLCK configurations */ struct sam_gclk_config_s gclk[12]; /* GCLK configurations */
}; };
/************************************************************************************ /************************************************************************************

View File

@ -145,10 +145,10 @@ int sam_eic_initialize(void)
*/ */
regaddr = SAM_GCLK_PCHCTRL(GCLK_CHAN_EIC); regaddr = SAM_GCLK_PCHCTRL(GCLK_CHAN_EIC);
regval = GCLK_PCHCTRL_GEN(BOARD_GLCK_EIC) | GCLK_PCHCTRL_CHEN; regval = GCLK_PCHCTRL_GEN(BOARD_GCLK_EIC) | GCLK_PCHCTRL_CHEN;
putreg32(regval, regaddr); putreg32(regval, regaddr);
/* Enable the EIC, selecting clocking via the GLCK_EIC */ /* Enable the EIC, selecting clocking via the GCLK_EIC */
putreg8(EIC_CTRLA_ENABLE | EIC_CTRLA_ENABLE, SAM_EIC_CTRLA); putreg8(EIC_CTRLA_ENABLE | EIC_CTRLA_ENABLE, SAM_EIC_CTRLA);
sam_eic_syncwait(); sam_eic_syncwait();

View File

@ -1,5 +1,5 @@
/**************************************************************************** /****************************************************************************
* arch/arm/src/samd5e5/sam_glck.c * arch/arm/src/samd5e5/sam_gclk.c
* *
* Copyright (C) 2018 Gregory Nutt. All rights reserved. * Copyright (C) 2018 Gregory Nutt. All rights reserved.
* Author: Gregory Nutt <gnutt@nuttx.org> * Author: Gregory Nutt <gnutt@nuttx.org>
@ -61,7 +61,7 @@
* the clock domains is complete. * the clock domains is complete.
* *
* Input Parameters: * Input Parameters:
* glck - GCLK clock index * gclk - GCLK clock index
* *
* Returned Value: * Returned Value:
* None * None
@ -233,7 +233,7 @@ void sam_gclk_chan_enable(uint8_t channel, uint8_t srcgen, bool wrlock)
/* Configure the peripheral channel */ /* Configure the peripheral channel */
regval = GCLK_PCHCTRL_GEN(srcgen); regval = GCLK_PCHCTRL_GEN(srcgen);
putreg32(regval, regaddr); putreg32(regval, regaddr);
/* Enable the peripheral channel, setting the writelock if so requested. */ /* Enable the peripheral channel, setting the writelock if so requested. */

View File

@ -45,6 +45,7 @@
#include <stdint.h> #include <stdint.h>
#include <stdbool.h> #include <stdbool.h>
#include "up_arch.h"
#include "sam_config.h" #include "sam_config.h"
#include "chip/sam_gclk.h" #include "chip/sam_gclk.h"
@ -141,6 +142,39 @@ void sam_gclk_chan_enable(uint8_t channel, uint8_t srcgen, bool wrlock);
void sam_gclk_chan_disable(uint8_t channel); void sam_gclk_chan_disable(uint8_t channel);
/****************************************************************************
* Name: sam_gclk_chan_locked
*
* Description:
* Return true if the GCLK cannot be configured because the wrtlock is set
* int the PCHCTRL register.
*
* Input Parameters:
* channel - Index of the GCLK channel to be checked
*
* Returned Value:
* True if the the wrtlock bit is set in the channel's PCHCTRL register.
*
****************************************************************************/
static inline bool sam_gclk_chan_locked(uint8_t channel)
{
uint32_t regaddr;
uint32_t regval;
/* Get the address of the peripheral channel control register */
regaddr = SAM_GCLK_PCHCTRL(channel);
/* Get content of the peripheral channel control register */
regval = getreg32(regaddr);
/* Return true if the WRTLOCK bit is set in the register */
return (regval & GCLK_PCHCTRL_WRTLOCK) != 0;
}
#undef EXTERN #undef EXTERN
#if defined(__cplusplus) #if defined(__cplusplus)
} }

View File

@ -36,18 +36,21 @@ STATUS
There is a placeholder from the SAML21, but it is currently stubbed out There is a placeholder from the SAML21, but it is currently stubbed out
in the Make.defs file. Configuration options in the board.h header in the Make.defs file. Configuration options in the board.h header
file are bogus and also just cloned from the SAML21. file are bogus and also just cloned from the SAML21.
2018-07-29: Clock configuration logic now complete. board.h 2018-07-29: Clock configuration logic now complete. board.h
configuration options still need to be verified. Unverified SERCOM configuration options still need to be verified. Unverified SERCOM
USART, SPI, I2C, Port configuration, and DMA support have been added. USART, SPI, I2C, Port configuration, and DMA support have been added.
I still have no hardware in hand to test. I still have no hardware in hand to test.
2018-07-20: Brought in the USB driver from the SAML21. It is the same 2018-07-20: Brought in the USB driver from the SAML21. It is the same
USB IP with only small differences. There a a few, small open issues USB IP with only small differences. There a a few, small open issues
still to be resolved. still to be resolved.
2018-08-01: Hardware in hand. Initial attempts to program the board 2018-08-01: Hardware in hand. Initial attempts to program the board
using a Segger J-Link connected via SWD were unsuccessful. I believe using a Segger J-Link connected via SWD were unsuccessful because the
that the FLASH is locked. See "Unlocking FLASH with J-Link Commander" Metro M4 comes with an application in FLASH and the FLASH locked. See
below. After unlocking the FLASH, I was able to successfully write "Unlocking FLASH with J-Link Commander" below. After unlocking the
the NuttX image. FLASH, I was able to successfully write the NuttX image.
Unfortunately, the board seems to have become unusable after the first Unfortunately, the board seems to have become unusable after the first
NuttX image was written to FLASH. I am unable to connect the JTAG NuttX image was written to FLASH. I am unable to connect the JTAG
@ -56,17 +59,23 @@ STATUS
to halt the CPU. to halt the CPU.
This is most likely a consequence of something happening in the NuttX This is most likely a consequence of something happening in the NuttX
boot-up sequence that interferes with JTAG operation. When I continue boot-up sequence that interferes with JTAG operation.
debugging in the future, I will put an infinite loop, branch-on-self
at the code startup up (__start) so that I can attached the debugger Future me: This boot-up failure was do to bad clock initialization
and step through the initial configuration. logic that caused infinite loops during clock configuration. Unlocking
and erasing the FLASH is innocuous, but the JTAG will apparently not
work if the clocks are not in a good state.
2018-08-03: Added a configuration option to run out of SRAM vs FLASH. 2018-08-03: Added a configuration option to run out of SRAM vs FLASH.
This should be a safer way to do the initial board bring-up since This should be a safer way to do the initial board bring-up since
it does not modify the FLASH image nor does it require unlocking it does not modify the FLASH image nor does it require unlocking
the FLASH pages. the FLASH pages.
2018-08-31: I finally have a new Metro M4 and have been successfully 2018-08-31: I finally have a new Metro M4 and have been successfully
debugging from SRAM. Several errors in clock configuration logic debugging from SRAM (with FLASH unlocked and erased). Several
have been corrected but it still hangs in the clock configuration. errors in clock configuration logic have been corrected and it now
gets through clock configuration okay. It now hangs in the low-level
USART initialzation.
Unlocking FLASH Unlocking FLASH
=============== ===============
@ -167,6 +176,15 @@ Unlocking FLASH
You will, of course, have to change the path as appropriate for your system. You will, of course, have to change the path as appropriate for your system.
4. Erase FLASH (optional)
J-Link>erase
Erasing device (ATSAMD51P19)...
J-Link: Flash download: Total time needed: 2.596s (Prepare: 0.031s, Compare: 0.000s, Erase: 2.553s, Program: 0.000s, Verify: 0.000s, Restore: 0.012s)
J-Link: Flash download: Total time needed: 0.066s (Prepare: 0.038s, Compare: 0.000s, Erase: 0.016s, Program: 0.000s, Verify: 0.000s, Restore: 0.010s)
Erasing done.
J-Link>
Serial Console Serial Console
============== ==============

View File

@ -141,8 +141,8 @@
/* GCLK */ /* GCLK */
#define BOARD_GCLK_SET1 0x0000 /* The empty set */ #define BOARD_GCLK_SET1 0x0020 /* Pre-configure: GCLK5 needed by DPLL0 */
#define BOARD_GCLK_SET2 0x0fff /* All GCLKs */ #define BOARD_GCLK_SET2 0x0fdf /* Post-configure: All GCLKs except GCLK5 */
#define BOARD_GCLK0_ENABLE true /* Enable GCLK0 */ #define BOARD_GCLK0_ENABLE true /* Enable GCLK0 */
#define BOARD_GCLK0_IDC false /* Don't improve duty cycle */ #define BOARD_GCLK0_IDC false /* Don't improve duty cycle */
@ -150,7 +150,7 @@
#define BOARD_GCLK0_OE true /* Generate output on GCLK_IO */ #define BOARD_GCLK0_OE true /* Generate output on GCLK_IO */
#define BOARD_GCLK0_DIVSEL 0 /* GCLK frequency is source/DIV */ #define BOARD_GCLK0_DIVSEL 0 /* GCLK frequency is source/DIV */
#define BOARD_GCLK0_RUNSTDBY false /* Don't run in standby */ #define BOARD_GCLK0_RUNSTDBY false /* Don't run in standby */
#define BOARD_GCLK0_SOURCE 7 /* Select DPLL0 output as GLCK0 source */ #define BOARD_GCLK0_SOURCE 7 /* Select DPLL0 output as GCLK0 source */
#define BOARD_GCLK0_DIV 1 /* Division factor */ #define BOARD_GCLK0_DIV 1 /* Division factor */
#define BOARD_GCLK1_ENABLE true /* Enable GCLK1 */ #define BOARD_GCLK1_ENABLE true /* Enable GCLK1 */
@ -159,7 +159,7 @@
#define BOARD_GCLK1_OE true /* Generate output on GCLK_IO */ #define BOARD_GCLK1_OE true /* Generate output on GCLK_IO */
#define BOARD_GCLK1_DIVSEL 0 /* GCLK frequency is source/DIV */ #define BOARD_GCLK1_DIVSEL 0 /* GCLK frequency is source/DIV */
#define BOARD_GCLK1_RUNSTDBY false /* Don't run in standby */ #define BOARD_GCLK1_RUNSTDBY false /* Don't run in standby */
#define BOARD_GCLK1_SOURCE 6 /* Select DFLL output as GLCK1 source */ #define BOARD_GCLK1_SOURCE 6 /* Select DFLL output as GCLK1 source */
#define BOARD_GCLK1_DIV 1 /* Division factor */ #define BOARD_GCLK1_DIV 1 /* Division factor */
#define BOARD_GCLK2_ENABLE false /* Don't enable GCLK2 */ #define BOARD_GCLK2_ENABLE false /* Don't enable GCLK2 */
@ -168,7 +168,7 @@
#define BOARD_GCLK2_OE false /* No generator output of GCLK_IO */ #define BOARD_GCLK2_OE false /* No generator output of GCLK_IO */
#define BOARD_GCLK2_DIVSEL 1 /* GCLK frequency is source/(2^(N+1) */ #define BOARD_GCLK2_DIVSEL 1 /* GCLK frequency is source/(2^(N+1) */
#define BOARD_GCLK2_RUNSTDBY false /* Don't run in standby */ #define BOARD_GCLK2_RUNSTDBY false /* Don't run in standby */
#define BOARD_GCLK2_SOURCE 5 /* Select XOSC32K as GLCK2 source */ #define BOARD_GCLK2_SOURCE 5 /* Select XOSC32K as GCLK2 source */
#define BOARD_GCLK2_DIV 1 /* Division factor */ #define BOARD_GCLK2_DIV 1 /* Division factor */
#define BOARD_GCLK3_ENABLE false /* Don't enable GCLK3 */ #define BOARD_GCLK3_ENABLE false /* Don't enable GCLK3 */
@ -177,7 +177,7 @@
#define BOARD_GCLK3_OE false /* No generator output of GCLK_IO */ #define BOARD_GCLK3_OE false /* No generator output of GCLK_IO */
#define BOARD_GCLK3_DIVSEL 0 /* GCLK frequency is source/DIV */ #define BOARD_GCLK3_DIVSEL 0 /* GCLK frequency is source/DIV */
#define BOARD_GCLK3_RUNSTDBY false /* Don't run in standby */ #define BOARD_GCLK3_RUNSTDBY false /* Don't run in standby */
#define BOARD_GCLK3_SOURCE 5 /* Select XOSC32K as GLCK3 source */ #define BOARD_GCLK3_SOURCE 5 /* Select XOSC32K as GCLK3 source */
#define BOARD_GCLK3_DIV 1 /* Division factor */ #define BOARD_GCLK3_DIV 1 /* Division factor */
#define BOARD_GCLK4_ENABLE true /* Enable GCLK4 */ #define BOARD_GCLK4_ENABLE true /* Enable GCLK4 */
@ -186,7 +186,7 @@
#define BOARD_GCLK4_OE true /* Generate output on GCLK_IO */ #define BOARD_GCLK4_OE true /* Generate output on GCLK_IO */
#define BOARD_GCLK4_DIVSEL 0 /* GCLK frequency is source/DIV */ #define BOARD_GCLK4_DIVSEL 0 /* GCLK frequency is source/DIV */
#define BOARD_GCLK4_RUNSTDBY false /* Don't run in standby */ #define BOARD_GCLK4_RUNSTDBY false /* Don't run in standby */
#define BOARD_GCLK4_SOURCE 7 /* Select DPLL0 output as GLCK4 source */ #define BOARD_GCLK4_SOURCE 7 /* Select DPLL0 output as GCLK4 source */
#define BOARD_GCLK4_DIV 1 /* Division factor */ #define BOARD_GCLK4_DIV 1 /* Division factor */
#define BOARD_GCLK5_ENABLE true /* Enable GCLK5 */ #define BOARD_GCLK5_ENABLE true /* Enable GCLK5 */
@ -195,7 +195,7 @@
#define BOARD_GCLK5_OE true /* Generate output on GCLK_IO */ #define BOARD_GCLK5_OE true /* Generate output on GCLK_IO */
#define BOARD_GCLK5_DIVSEL 0 /* GCLK frequency is source/DIV */ #define BOARD_GCLK5_DIVSEL 0 /* GCLK frequency is source/DIV */
#define BOARD_GCLK5_RUNSTDBY false /* Don't run in standby */ #define BOARD_GCLK5_RUNSTDBY false /* Don't run in standby */
#define BOARD_GCLK5_SOURCE 6 /* Select DFLL output as GLCK5 source */ #define BOARD_GCLK5_SOURCE 6 /* Select DFLL output as GCLK5 source */
#define BOARD_GCLK5_DIV 24 /* Division factor */ #define BOARD_GCLK5_DIV 24 /* Division factor */
#define BOARD_GCLK6_ENABLE false /* Don't enable GCLK6 */ #define BOARD_GCLK6_ENABLE false /* Don't enable GCLK6 */
@ -204,7 +204,7 @@
#define BOARD_GCLK6_OE false /* No generator output of GCLK_IO */ #define BOARD_GCLK6_OE false /* No generator output of GCLK_IO */
#define BOARD_GCLK6_DIVSEL 0 /* GCLK frequency is source/DIV */ #define BOARD_GCLK6_DIVSEL 0 /* GCLK frequency is source/DIV */
#define BOARD_GCLK6_RUNSTDBY false /* Don't run in standby */ #define BOARD_GCLK6_RUNSTDBY false /* Don't run in standby */
#define BOARD_GCLK6_SOURCE 1 /* Select XOSC1 as GLCK5 source */ #define BOARD_GCLK6_SOURCE 1 /* Select XOSC1 as GCLK6 source */
#define BOARD_GCLK6_DIV 1 /* Division factor */ #define BOARD_GCLK6_DIV 1 /* Division factor */
#define BOARD_GCLK7_ENABLE false /* Don't enable GCLK7 */ #define BOARD_GCLK7_ENABLE false /* Don't enable GCLK7 */
@ -213,7 +213,7 @@
#define BOARD_GCLK7_OE false /* No generator output of GCLK_IO */ #define BOARD_GCLK7_OE false /* No generator output of GCLK_IO */
#define BOARD_GCLK7_DIVSEL 0 /* GCLK frequency is source/DIV */ #define BOARD_GCLK7_DIVSEL 0 /* GCLK frequency is source/DIV */
#define BOARD_GCLK7_RUNSTDBY false /* Don't run in standby */ #define BOARD_GCLK7_RUNSTDBY false /* Don't run in standby */
#define BOARD_GCLK7_SOURCE 1 /* Select XOSC1 as GLCK5 source */ #define BOARD_GCLK7_SOURCE 1 /* Select XOSC1 as GCLK7 source */
#define BOARD_GCLK7_DIV 1 /* Division factor */ #define BOARD_GCLK7_DIV 1 /* Division factor */
#define BOARD_GCLK8_ENABLE false /* Don't enable GCLK8 */ #define BOARD_GCLK8_ENABLE false /* Don't enable GCLK8 */
@ -222,7 +222,7 @@
#define BOARD_GCLK8_OE false /* No generator output of GCLK_IO */ #define BOARD_GCLK8_OE false /* No generator output of GCLK_IO */
#define BOARD_GCLK8_DIVSEL 0 /* GCLK frequency is source/DIV */ #define BOARD_GCLK8_DIVSEL 0 /* GCLK frequency is source/DIV */
#define BOARD_GCLK8_RUNSTDBY false /* Don't run in standby */ #define BOARD_GCLK8_RUNSTDBY false /* Don't run in standby */
#define BOARD_GCLK8_SOURCE 1 /* Select XOSC1 as GLCK5 source */ #define BOARD_GCLK8_SOURCE 1 /* Select XOSC1 as GCLK8 source */
#define BOARD_GCLK8_DIV 1 /* Division factor */ #define BOARD_GCLK8_DIV 1 /* Division factor */
#define BOARD_GCLK9_ENABLE false /* Don't enable GCLK9 */ #define BOARD_GCLK9_ENABLE false /* Don't enable GCLK9 */
@ -231,7 +231,7 @@
#define BOARD_GCLK9_OE false /* No generator output of GCLK_IO */ #define BOARD_GCLK9_OE false /* No generator output of GCLK_IO */
#define BOARD_GCLK9_DIVSEL 0 /* GCLK frequency is source/DIV */ #define BOARD_GCLK9_DIVSEL 0 /* GCLK frequency is source/DIV */
#define BOARD_GCLK9_RUNSTDBY false /* Don't run in standby */ #define BOARD_GCLK9_RUNSTDBY false /* Don't run in standby */
#define BOARD_GCLK9_SOURCE 1 /* Select XOSC1 as GLCK5 source */ #define BOARD_GCLK9_SOURCE 1 /* Select XOSC1 as GCLK9 source */
#define BOARD_GCLK9_DIV 1 /* Division factor */ #define BOARD_GCLK9_DIV 1 /* Division factor */
#define BOARD_GCLK10_ENABLE false /* Don't enable GCLK10 */ #define BOARD_GCLK10_ENABLE false /* Don't enable GCLK10 */
@ -240,7 +240,7 @@
#define BOARD_GCLK10_OE false /* No generator output of GCLK_IO */ #define BOARD_GCLK10_OE false /* No generator output of GCLK_IO */
#define BOARD_GCLK10_DIVSEL 0 /* GCLK frequency is source/DIV */ #define BOARD_GCLK10_DIVSEL 0 /* GCLK frequency is source/DIV */
#define BOARD_GCLK10_RUNSTDBY false /* Don't run in standby */ #define BOARD_GCLK10_RUNSTDBY false /* Don't run in standby */
#define BOARD_GCLK10_SOURCE 1 /* Select XOSC1 as GLCK5 source */ #define BOARD_GCLK10_SOURCE 1 /* Select XOSC1 as GCLK10 source */
#define BOARD_GCLK10_DIV 1 /* Division factor */ #define BOARD_GCLK10_DIV 1 /* Division factor */
#define BOARD_GCLK11_ENABLE false /* Don't enable GCLK11 */ #define BOARD_GCLK11_ENABLE false /* Don't enable GCLK11 */
@ -249,7 +249,7 @@
#define BOARD_GCLK11_OE false /* No generator output of GCLK_IO */ #define BOARD_GCLK11_OE false /* No generator output of GCLK_IO */
#define BOARD_GCLK11_DIVSEL 0 /* GCLK frequency is source/DIV */ #define BOARD_GCLK11_DIVSEL 0 /* GCLK frequency is source/DIV */
#define BOARD_GCLK11_RUNSTDBY false /* Don't run in standby */ #define BOARD_GCLK11_RUNSTDBY false /* Don't run in standby */
#define BOARD_GCLK11_SOURCE 1 /* Select XOSC1 as GLCK5 source */ #define BOARD_GCLK11_SOURCE 1 /* Select XOSC1 as GCLK11 source */
#define BOARD_GCLK11_DIV 1 /* Division factor */ #define BOARD_GCLK11_DIV 1 /* Division factor */
#define BOARD_GCLK11_FREQUENCY BOARD_XOSC1_FREQUENCY #define BOARD_GCLK11_FREQUENCY BOARD_XOSC1_FREQUENCY
@ -267,6 +267,7 @@
#define BOARD_DFLL_BPLCKC false /* No ypass coarse clock */ #define BOARD_DFLL_BPLCKC false /* No ypass coarse clock */
#define BOARD_DFLL_WAITLOCK true /* Wait lock */ #define BOARD_DFLL_WAITLOCK true /* Wait lock */
#define BOARD_DFLL_CALIBEN false /* Don't verwrite factory calibration */ #define BOARD_DFLL_CALIBEN false /* Don't verwrite factory calibration */
#define BOARD_DFLL_GCLKLOCK false /* Don't lock the GCLK source */
#define BOARD_DFLL_FCALIB 128 /* Coarse calibration value (if caliben) */ #define BOARD_DFLL_FCALIB 128 /* Coarse calibration value (if caliben) */
#define BOARD_DFLL_CCALIB (31 / 4) /* Fine calibration value (if caliben) */ #define BOARD_DFLL_CCALIB (31 / 4) /* Fine calibration value (if caliben) */
#define BOARD_DFLL_FSTEP 1 /* Fine maximum step */ #define BOARD_DFLL_FSTEP 1 /* Fine maximum step */
@ -301,11 +302,13 @@
#define BOARD_DPLL0_WUF false /* Wake up fast */ #define BOARD_DPLL0_WUF false /* Wake up fast */
#define BOARD_DPLL0_RUNSTDBY false /* Run in standby */ #define BOARD_DPLL0_RUNSTDBY false /* Run in standby */
#define BOARD_DPLL0_ONDEMAND false /* On demand clock activation */ #define BOARD_DPLL0_ONDEMAND false /* On demand clock activation */
#define BOARD_DPLL0_REFLOCK false /* Do not lock reference clock section */
#define BOARD_DPLL0_REFCLK 0 /* Reference clock selection */ #define BOARD_DPLL0_REFCLK 0 /* Reference clock selection */
#define BOARD_DPLL0_LTIME 0 /* Lock time */ #define BOARD_DPLL0_LTIME 0 /* Lock time */
#define BOARD_DPLL0_FILTER 0 /* Proportional integer filter selection */ #define BOARD_DPLL0_FILTER 0 /* Proportional integer filter selection */
#define BOARD_DPLL0_DCOFILTER 0 /* Sigma-delta DCO filter selection */ #define BOARD_DPLL0_DCOFILTER 0 /* Sigma-delta DCO filter selection */
#define BOARD_DPLL0_GCLK 5 /* GCLK5 source (if refclock == 0) */ #define BOARD_DPLL0_GCLK 5 /* GCLK source (if refclock == 0) */
#define BOARD_DPLL0_GCLKLOCK 0 /* Don't lock GCLK source clock configuration */
#define BOARD_DPLL0_LDRFRAC 0 /* Loop divider fractional part */ #define BOARD_DPLL0_LDRFRAC 0 /* Loop divider fractional part */
#define BOARD_DPLL0_LDRINT 59 /* Loop divider ratio */ #define BOARD_DPLL0_LDRINT 59 /* Loop divider ratio */
#define BOARD_DPLL0_DIV 0 /* Clock divider */ #define BOARD_DPLL0_DIV 0 /* Clock divider */
@ -316,11 +319,13 @@
#define BOARD_DPLL1_WUF false /* Wake up fast */ #define BOARD_DPLL1_WUF false /* Wake up fast */
#define BOARD_DPLL1_RUNSTDBY false /* Run in standby */ #define BOARD_DPLL1_RUNSTDBY false /* Run in standby */
#define BOARD_DPLL1_ONDEMAND false /* On demand clock activation */ #define BOARD_DPLL1_ONDEMAND false /* On demand clock activation */
#define BOARD_DPLL1_REFLOCK false /* Do not lock reference clock section */
#define BOARD_DPLL1_REFCLK 1 /* Reference clock = XOSCK32 */ #define BOARD_DPLL1_REFCLK 1 /* Reference clock = XOSCK32 */
#define BOARD_DPLL1_LTIME 0 /* Lock time */ #define BOARD_DPLL1_LTIME 0 /* Lock time */
#define BOARD_DPLL1_FILTER 0 /* Sigma-delta DCO filter selection */ #define BOARD_DPLL1_FILTER 0 /* Sigma-delta DCO filter selection */
#define BOARD_DPLL1_DCOFILTER 0 /* Sigma-delta DCO filter selection */ #define BOARD_DPLL1_DCOFILTER 0 /* Sigma-delta DCO filter selection */
#define BOARD_DPLL1_GCLK 0 /* GCLK source (if refclock == 0) */ #define BOARD_DPLL1_GCLK 0 /* GCLK source (if refclock == 0) */
#define BOARD_DPLL1_GCLKLOCK 0 /* Don't lock GCLK source clock configuration */
#define BOARD_DPLL1_LDRFRAC 13 /* Loop divider fractional part */ #define BOARD_DPLL1_LDRFRAC 13 /* Loop divider fractional part */
#define BOARD_DPLL1_LDRINT 1463 /* Loop divider ratio */ #define BOARD_DPLL1_LDRINT 1463 /* Loop divider ratio */
#define BOARD_DPLL1_DIV 0 /* Clock divider */ #define BOARD_DPLL1_DIV 0 /* Clock divider */
@ -335,7 +340,7 @@
/* Peripheral clocking */ /* Peripheral clocking */
#define BOARD_GLCK_EIC 4 /* EIC GLCK index */ #define BOARD_GCLK_EIC 4 /* EIC GCLK index */
/* FLASH wait states /* FLASH wait states
* *