Skip to content

Commit

Permalink
feat(CMSIS,PeriphDrivers): Enable external clock selection on MAX32657 (
Browse files Browse the repository at this point in the history
#1297)

Signed-off-by: Tahsin Mutlugun <[email protected]>
  • Loading branch information
ttmut authored Dec 16, 2024
1 parent 0b47602 commit d9efd38
Show file tree
Hide file tree
Showing 6 changed files with 39 additions and 39 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ extern "C" {
Update if use of this oscillator requires precise timing.*/
/* NOTE: INRO was previously named NANORING */
#ifndef INRO_FREQ
#define INRO_FREQ 100000
#define INRO_FREQ 131000
#endif

#ifndef IPO_FREQ
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -80,10 +80,9 @@ __weak void SystemCoreClockUpdate(void)
case MXC_S_GCR_CLKCTRL_SYSCLK_SEL_ERTCO:
base_freq = ERTCO_FREQ;
break;
// case MXC_S_GCR_CLKCTRL_SYSCLK_SEL_EXTCLK:
// base_freq = EXTCLK_FREQ;
// break;
// TODO(JC): ^^^ Uncomment when EXTCLK register definition is added
case MXC_S_GCR_CLKCTRL_SYSCLK_SEL_EXTCLK:
base_freq = EXTCLK_FREQ;
break;
default:
// Codes 001 and 111 are reserved.
// This code should never execute, however, initialize to safe value.
Expand Down
1 change: 1 addition & 0 deletions Libraries/PeriphDrivers/Include/MAX32657/mxc_pins.h
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@

/***** Global Variables *****/
// Predefined GPIO Configurations
extern const mxc_gpio_cfg_t gpio_cfg_extclk;
extern const mxc_gpio_cfg_t gpio_cfg_i3c;

extern const mxc_gpio_cfg_t gpio_cfg_uart;
Expand Down
5 changes: 2 additions & 3 deletions Libraries/PeriphDrivers/Include/MAX32657/mxc_sys.h
Original file line number Diff line number Diff line change
Expand Up @@ -99,9 +99,8 @@ typedef enum {
MXC_V_GCR_CLKCTRL_SYSCLK_SEL_INRO, /**< Select the Internal Nanoring Oscillator (INRO) */
MXC_SYS_CLOCK_ERTCO =
MXC_V_GCR_CLKCTRL_SYSCLK_SEL_ERTCO, /**< Select the External RTC Crystal Oscillator */
// MXC_SYS_CLOCK_EXTCLK =
// MXC_V_GCR_CLKCTRL_SYSCLK_SEL_EXTCLK /**< Use the external system clock input */
// TODO(JC): ^^^ EXTCLK select is missing from gcr_regs.h (should be 0x7)
MXC_SYS_CLOCK_EXTCLK =
MXC_V_GCR_CLKCTRL_SYSCLK_SEL_EXTCLK /**< Use the external system clock input */
} mxc_sys_system_clock_t;

/** @brief Enumeration to set the System Clock divider */
Expand Down
3 changes: 3 additions & 0 deletions Libraries/PeriphDrivers/Source/SYS/pins_me30.c
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,9 @@
/***** Global Variables *****/

// clang-format off
const mxc_gpio_cfg_t gpio_cfg_extclk = { MXC_GPIO0, (MXC_GPIO_PIN_7), MXC_GPIO_FUNC_IN,
MXC_GPIO_PAD_NONE, MXC_GPIO_VSSEL_VDDIO, MXC_GPIO_DRVSTR_0 };

// P0.0 - I3C SCL
// P0.1 - I3C SDA
const mxc_gpio_cfg_t gpio_cfg_i3c = { MXC_GPIO0, (MXC_GPIO_PIN_0 | MXC_GPIO_PIN_1), MXC_GPIO_FUNC_ALT1,
Expand Down
60 changes: 29 additions & 31 deletions Libraries/PeriphDrivers/Source/SYS/sys_me30.c
Original file line number Diff line number Diff line change
Expand Up @@ -226,11 +226,10 @@ int MXC_SYS_ClockSourceEnable(mxc_sys_system_clock_t clock)
return MXC_SYS_Clock_Timeout(MXC_F_GCR_CLKCTRL_IBRO_RDY);
break;

// TODO(ME30): EXTCLK is missing from register definitions
// case MXC_SYS_CLOCK_EXTCLK:
// // No "RDY" bit to monitor, so just configure the GPIO
// return MXC_GPIO_Config(&gpio_cfg_extclk);
// break;
case MXC_SYS_CLOCK_EXTCLK:
// No "RDY" bit to monitor, so just configure the GPIO
return MXC_GPIO_Config(&gpio_cfg_extclk);
break;

case MXC_SYS_CLOCK_INRO:
// The 80k clock is always enabled
Expand Down Expand Up @@ -291,19 +290,18 @@ int MXC_SYS_ClockSourceDisable(mxc_sys_system_clock_t clock)
MXC_GCR->clkctrl &= ~MXC_F_GCR_CLKCTRL_IBRO_EN;
break;

// TODO(ME30): Missing EXTCLK register definition
// case MXC_SYS_CLOCK_EXTCLK:
// /*
// There's not a great way to disable the external clock.
// Deinitializing the GPIO here may have unintended consequences
// for application code.
// Selecting a different system clock source is sufficient
// to "disable" the EXT_CLK source.
// */
// break;
case MXC_SYS_CLOCK_EXTCLK:
/*
There's not a great way to disable the external clock.
Deinitializing the GPIO here may have unintended consequences
for application code.
Selecting a different system clock source is sufficient
to "disable" the EXT_CLK source.
*/
break;

case MXC_SYS_CLOCK_INRO:
// The 80k clock is always enabled
// The 131k clock is always enabled
break;

case MXC_SYS_CLOCK_ERFO:
Expand Down Expand Up @@ -353,6 +351,7 @@ int MXC_SYS_Clock_Timeout(uint32_t ready)
int MXC_SYS_Clock_Select(mxc_sys_system_clock_t clock)
{
uint32_t current_clock;
int err = E_NO_ERROR;

// Save the current system clock
current_clock = MXC_GCR->clkctrl & MXC_F_GCR_CLKCTRL_SYSCLK_SEL;
Expand Down Expand Up @@ -394,21 +393,20 @@ int MXC_SYS_Clock_Select(mxc_sys_system_clock_t clock)

break;

// TODO(ME30): Missing EXTCLK register definition
// case MXC_SYS_CLOCK_EXTCLK:
// /*
// There's not "EXT_CLK RDY" bit for the ME17, so we'll
// blindly enable (configure GPIO) the external clock every time.
// */
// err = MXC_SYS_ClockSourceEnable(MXC_SYS_CLOCK_EXTCLK);
// if (err)
// return err;

// // Set EXT clock as System Clock
// MXC_SETFIELD(MXC_GCR->clkctrl, MXC_F_GCR_CLKCTRL_SYSCLK_SEL,
// MXC_S_GCR_CLKCTRL_SYSCLK_SEL_EXTCLK);

// break;
case MXC_SYS_CLOCK_EXTCLK:
/*
There's not "EXT_CLK RDY" bit for the ME17, so we'll
blindly enable (configure GPIO) the external clock every time.
*/
err = MXC_SYS_ClockSourceEnable(MXC_SYS_CLOCK_EXTCLK);
if (err)
return err;

// Set EXT clock as System Clock
MXC_SETFIELD(MXC_GCR->clkctrl, MXC_F_GCR_CLKCTRL_SYSCLK_SEL,
MXC_S_GCR_CLKCTRL_SYSCLK_SEL_EXTCLK);

break;

case MXC_SYS_CLOCK_ERFO:

Expand Down

0 comments on commit d9efd38

Please sign in to comment.