XMC4xxx: Fix for early bringup problems
This commit is contained in:
parent
e1f86f407f
commit
4ba091933e
@ -50,7 +50,10 @@
|
|||||||
|
|
||||||
#if defined(CONFIG_ARCH_CHIP_XMC4500)
|
#if defined(CONFIG_ARCH_CHIP_XMC4500)
|
||||||
# define XMC4_NUSIC 3 /* Three USIC modules: USCI0-2 */
|
# define XMC4_NUSIC 3 /* Three USIC modules: USCI0-2 */
|
||||||
|
# undef XMC4_SCU_GATING /* No clock gating registers */
|
||||||
|
#elif defined(CONFIG_ARCH_CHIP_XMC4700)
|
||||||
|
# define XMC4_NUSIC 3 /* Three USIC modules: USCI0-2 */
|
||||||
|
# define XMC4_SCU_GATING 1 /* Has clock gating registers */
|
||||||
#else
|
#else
|
||||||
# error "Unsupported XMC4xxx chip"
|
# error "Unsupported XMC4xxx chip"
|
||||||
#endif
|
#endif
|
||||||
|
@ -13,6 +13,9 @@ choice
|
|||||||
config ARCH_CHIP_XMC4500
|
config ARCH_CHIP_XMC4500
|
||||||
bool "XMC4500"
|
bool "XMC4500"
|
||||||
|
|
||||||
|
config ARCH_CHIP_XMC4700
|
||||||
|
bool "XMC4700"
|
||||||
|
|
||||||
endchoice
|
endchoice
|
||||||
|
|
||||||
# These "hidden" settings determine is a peripheral option is available for
|
# These "hidden" settings determine is a peripheral option is available for
|
||||||
|
@ -163,6 +163,7 @@
|
|||||||
#define XMC4_SCU_EXTCLKCR_OFFSET 0x0028 /* External clock Control Register */
|
#define XMC4_SCU_EXTCLKCR_OFFSET 0x0028 /* External clock Control Register */
|
||||||
#define XMC4_SCU_SLEEPCR_OFFSET 0x0030 /* Sleep Control Register */
|
#define XMC4_SCU_SLEEPCR_OFFSET 0x0030 /* Sleep Control Register */
|
||||||
#define XMC4_SCU_DSLEEPCR_OFFSET 0x0034 /* Deep Sleep Control Register */
|
#define XMC4_SCU_DSLEEPCR_OFFSET 0x0034 /* Deep Sleep Control Register */
|
||||||
|
#ifdef XMC4_SCU_GATING
|
||||||
# define XMC4_SCU_CGATSTAT0_OFFSET 0x0040 /* Peripheral 0 Clock Gating Status */
|
# define XMC4_SCU_CGATSTAT0_OFFSET 0x0040 /* Peripheral 0 Clock Gating Status */
|
||||||
# define XMC4_SCU_CGATSET0_OFFSET 0x0044 /* Peripheral 0 Clock Gating Set */
|
# define XMC4_SCU_CGATSET0_OFFSET 0x0044 /* Peripheral 0 Clock Gating Set */
|
||||||
# define XMC4_SCU_CGATCLR0_OFFSET 0x0048 /* Peripheral 0 Clock Gating Clear */
|
# define XMC4_SCU_CGATCLR0_OFFSET 0x0048 /* Peripheral 0 Clock Gating Clear */
|
||||||
@ -175,6 +176,7 @@
|
|||||||
# define XMC4_SCU_CGATSTAT3_OFFSET 0x0064 /* Peripheral 3 Clock Gating Status */
|
# define XMC4_SCU_CGATSTAT3_OFFSET 0x0064 /* Peripheral 3 Clock Gating Status */
|
||||||
# define XMC4_SCU_CGATSET3_OFFSET 0x0068 /* Peripheral 3 Clock Gating Set */
|
# define XMC4_SCU_CGATSET3_OFFSET 0x0068 /* Peripheral 3 Clock Gating Set */
|
||||||
# define XMC4_SCU_CGATCLR3_OFFSET 0x006c /* Peripheral 3 Clock Gating Clear */
|
# define XMC4_SCU_CGATCLR3_OFFSET 0x006c /* Peripheral 3 Clock Gating Clear */
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Oscillator Control SCU Registers */
|
/* Oscillator Control SCU Registers */
|
||||||
|
|
||||||
@ -292,6 +294,7 @@
|
|||||||
#define XMC4_SCU_EXTCLKCR (XMC4_SCU_CLK_BASE+XMC4_SCU_EXTCLKCR_OFFSET)
|
#define XMC4_SCU_EXTCLKCR (XMC4_SCU_CLK_BASE+XMC4_SCU_EXTCLKCR_OFFSET)
|
||||||
#define XMC4_SCU_SLEEPCR (XMC4_SCU_CLK_BASE+XMC4_SCU_SLEEPCR_OFFSET)
|
#define XMC4_SCU_SLEEPCR (XMC4_SCU_CLK_BASE+XMC4_SCU_SLEEPCR_OFFSET)
|
||||||
#define XMC4_SCU_DSLEEPCR (XMC4_SCU_CLK_BASE+XMC4_SCU_DSLEEPCR_OFFSET)
|
#define XMC4_SCU_DSLEEPCR (XMC4_SCU_CLK_BASE+XMC4_SCU_DSLEEPCR_OFFSET)
|
||||||
|
#ifdef XMC4_SCU_GATING
|
||||||
# define XMC4_SCU_CGATSTAT0 (XMC4_SCU_CLK_BASE+XMC4_SCU_CGATSTAT0_OFFSET)
|
# define XMC4_SCU_CGATSTAT0 (XMC4_SCU_CLK_BASE+XMC4_SCU_CGATSTAT0_OFFSET)
|
||||||
# define XMC4_SCU_CGATSET0 (XMC4_SCU_CLK_BASE+XMC4_SCU_CGATSET0_OFFSET)
|
# define XMC4_SCU_CGATSET0 (XMC4_SCU_CLK_BASE+XMC4_SCU_CGATSET0_OFFSET)
|
||||||
# define XMC4_SCU_CGATCLR0 (XMC4_SCU_CLK_BASE+XMC4_SCU_CGATCLR0_OFFSET)
|
# define XMC4_SCU_CGATCLR0 (XMC4_SCU_CLK_BASE+XMC4_SCU_CGATCLR0_OFFSET)
|
||||||
@ -304,6 +307,7 @@
|
|||||||
# define XMC4_SCU_CGATSTAT3 (XMC4_SCU_CLK_BASE+XMC4_SCU_CGATSTAT3_OFFSET)
|
# define XMC4_SCU_CGATSTAT3 (XMC4_SCU_CLK_BASE+XMC4_SCU_CGATSTAT3_OFFSET)
|
||||||
# define XMC4_SCU_CGATSET3 (XMC4_SCU_CLK_BASE+XMC4_SCU_CGATSET3_OFFSET)
|
# define XMC4_SCU_CGATSET3 (XMC4_SCU_CLK_BASE+XMC4_SCU_CGATSET3_OFFSET)
|
||||||
# define XMC4_SCU_CGATCLR3 (XMC4_SCU_CLK_BASE+XMC4_SCU_CGATCLR3_OFFSET)
|
# define XMC4_SCU_CGATCLR3 (XMC4_SCU_CLK_BASE+XMC4_SCU_CGATCLR3_OFFSET)
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Oscillator Control SCU Registers */
|
/* Oscillator Control SCU Registers */
|
||||||
|
|
||||||
@ -959,6 +963,7 @@
|
|||||||
|
|
||||||
/* Peripheral 0 Clock Gating Status, Peripheral 0 Clock Gating Set, Peripheral 0 Clock Gating Clear */
|
/* Peripheral 0 Clock Gating Status, Peripheral 0 Clock Gating Set, Peripheral 0 Clock Gating Clear */
|
||||||
|
|
||||||
|
#ifdef XMC4_SCU_GATING
|
||||||
# define SCU_CGAT0_VADC (1 << 0) /* Bit 0: VADC Gating Status */
|
# define SCU_CGAT0_VADC (1 << 0) /* Bit 0: VADC Gating Status */
|
||||||
# define SCU_CGAT0_DSD (1 << 1) /* Bit 1: DSD Gating Status */
|
# define SCU_CGAT0_DSD (1 << 1) /* Bit 1: DSD Gating Status */
|
||||||
# define SCU_CGAT0_CCU40 (1 << 2) /* Bit 2: CCU40 Gating Status */
|
# define SCU_CGAT0_CCU40 (1 << 2) /* Bit 2: CCU40 Gating Status */
|
||||||
@ -970,9 +975,11 @@
|
|||||||
# define SCU_CGAT0_POSIF1 (1 << 10) /* Bit 10: POSIF1 Gating Status */
|
# define SCU_CGAT0_POSIF1 (1 << 10) /* Bit 10: POSIF1 Gating Status */
|
||||||
# define SCU_CGAT0_USIC0 (1 << 11) /* Bit 11: USIC0 Gating Status */
|
# define SCU_CGAT0_USIC0 (1 << 11) /* Bit 11: USIC0 Gating Status */
|
||||||
# define SCU_CGAT0_ERU1 (1 << 16) /* Bit 16: ERU1 Gating Status */
|
# define SCU_CGAT0_ERU1 (1 << 16) /* Bit 16: ERU1 Gating Status */
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Peripheral 1 Clock Gating Status, Peripheral 1 Clock Gating Set, Peripheral 1 Clock Gating Clear */
|
/* Peripheral 1 Clock Gating Status, Peripheral 1 Clock Gating Set, Peripheral 1 Clock Gating Clear */
|
||||||
|
|
||||||
|
#ifdef XMC4_SCU_GATING
|
||||||
# define SCU_CGAT1_CCU43 (1 << 0) /* Bit 0: CCU43 Gating Status */
|
# define SCU_CGAT1_CCU43 (1 << 0) /* Bit 0: CCU43 Gating Status */
|
||||||
# define SCU_CGAT1_LEDTSCU0 (1 << 3) /* Bit 3: LEDTS Gating Status */
|
# define SCU_CGAT1_LEDTSCU0 (1 << 3) /* Bit 3: LEDTS Gating Status */
|
||||||
# define SCU_CGAT1_MCAN0 (1 << 4) /* Bit 4: MultiCAN Gating Status */
|
# define SCU_CGAT1_MCAN0 (1 << 4) /* Bit 4: MultiCAN Gating Status */
|
||||||
@ -981,9 +988,11 @@
|
|||||||
# define SCU_CGAT1_USIC1 (1 << 7) /* Bit 7: USIC1 Gating Status */
|
# define SCU_CGAT1_USIC1 (1 << 7) /* Bit 7: USIC1 Gating Status */
|
||||||
# define SCU_CGAT1_USIC2 (1 << 8) /* Bit 8: USIC1 Gating Status */
|
# define SCU_CGAT1_USIC2 (1 << 8) /* Bit 8: USIC1 Gating Status */
|
||||||
# define SCU_CGAT1_PPORTS (1 << 9) /* Bit 9: PORTS Gating Status */
|
# define SCU_CGAT1_PPORTS (1 << 9) /* Bit 9: PORTS Gating Status */
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Peripheral 2 Clock Gating Status, Peripheral 2 Clock Gating Set, Peripheral 2 Clock Gating Clear */
|
/* Peripheral 2 Clock Gating Status, Peripheral 2 Clock Gating Set, Peripheral 2 Clock Gating Clear */
|
||||||
|
|
||||||
|
#ifdef XMC4_SCU_GATING
|
||||||
# define SCU_CGAT2_WDT (1 << 1) /* Bit 1: WDT Gating Status */
|
# define SCU_CGAT2_WDT (1 << 1) /* Bit 1: WDT Gating Status */
|
||||||
# define SCU_CGAT2_ETH0 (1 << 2) /* Bit 2: ETH0 Gating Status */
|
# define SCU_CGAT2_ETH0 (1 << 2) /* Bit 2: ETH0 Gating Status */
|
||||||
# define SCU_CGAT2_DMA0 (1 << 4) /* Bit 4: DMA0 Gating Status */
|
# define SCU_CGAT2_DMA0 (1 << 4) /* Bit 4: DMA0 Gating Status */
|
||||||
@ -991,10 +1000,13 @@
|
|||||||
# define SCU_CGAT2_FCE (1 << 6) /* Bit 6: FCE Gating Status */
|
# define SCU_CGAT2_FCE (1 << 6) /* Bit 6: FCE Gating Status */
|
||||||
# define SCU_CGAT2_USB (1 << 7) /* Bit 7: USB Gating Status */
|
# define SCU_CGAT2_USB (1 << 7) /* Bit 7: USB Gating Status */
|
||||||
# define SCU_CGAT2_ECAT (1 << 10) /* Bit 10: ECAT Gating Status */
|
# define SCU_CGAT2_ECAT (1 << 10) /* Bit 10: ECAT Gating Status */
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Peripheral 3 Clock Gating Status, Peripheral 3 Clock Gating Set, Peripheral 3 Clock Gating Clear */
|
/* Peripheral 3 Clock Gating Status, Peripheral 3 Clock Gating Set, Peripheral 3 Clock Gating Clear */
|
||||||
|
|
||||||
|
#ifdef XMC4_SCU_GATING
|
||||||
# define SCU_CGAT3_EBU (1 << 2) /* Bit 2: EBU Gating Status */
|
# define SCU_CGAT3_EBU (1 << 2) /* Bit 2: EBU Gating Status */
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Oscillator Control SCU Registers */
|
/* Oscillator Control SCU Registers */
|
||||||
|
|
||||||
|
@ -313,9 +313,9 @@ void xmc4_clock_configure(void)
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
regval = getreg32(SCU_TRAP_SOSCWDGT);
|
regval = getreg32(XMC4_SCU_TRAPDIS);
|
||||||
regval &= ~bitset;
|
regval &= ~SCU_TRAP_SOSCWDGT;
|
||||||
putreg32(regval, SCU_TRAP_SOSCWDGT);
|
putreg32(regval, XMC4_SCU_TRAPDIS);
|
||||||
}
|
}
|
||||||
#else /* BOARD_PLL_CLOCKSRC_XTAL */
|
#else /* BOARD_PLL_CLOCKSRC_XTAL */
|
||||||
|
|
||||||
|
@ -112,6 +112,7 @@ int xmc4_enable_usic(enum usic_e usic)
|
|||||||
switch (usic)
|
switch (usic)
|
||||||
{
|
{
|
||||||
case USIC0:
|
case USIC0:
|
||||||
|
#ifdef XMC4_SCU_GATING
|
||||||
/* Check if USIC0 is already ungated */
|
/* Check if USIC0 is already ungated */
|
||||||
|
|
||||||
if ((getreg32(XMC4_SCU_CGATSTAT0) & SCU_CGAT0_USIC0) == 0)
|
if ((getreg32(XMC4_SCU_CGATSTAT0) & SCU_CGAT0_USIC0) == 0)
|
||||||
@ -124,11 +125,16 @@ int xmc4_enable_usic(enum usic_e usic)
|
|||||||
|
|
||||||
putreg32(SCU_PR0_USIC0RS, XMC4_SCU_PRCLR0);
|
putreg32(SCU_PR0_USIC0RS, XMC4_SCU_PRCLR0);
|
||||||
}
|
}
|
||||||
|
#else
|
||||||
|
/* De-assert peripheral reset USIC0 */
|
||||||
|
|
||||||
|
putreg32(SCU_PR0_USIC0RS, XMC4_SCU_PRCLR0);
|
||||||
|
#endif
|
||||||
break;
|
break;
|
||||||
|
|
||||||
#if XMC4_NUSIC > 1
|
#if XMC4_NUSIC > 1
|
||||||
case USIC1:
|
case USIC1:
|
||||||
|
#ifdef XMC4_SCU_GATING
|
||||||
/* Check if USIC1 is already ungated */
|
/* Check if USIC1 is already ungated */
|
||||||
|
|
||||||
if ((getreg32(XMC4_SCU_CGATSTAT1) & SCU_CGAT1_USIC1) == 0)
|
if ((getreg32(XMC4_SCU_CGATSTAT1) & SCU_CGAT1_USIC1) == 0)
|
||||||
@ -141,11 +147,16 @@ int xmc4_enable_usic(enum usic_e usic)
|
|||||||
|
|
||||||
putreg32(SCU_PR1_USIC1RS, XMC4_SCU_PRCLR1);
|
putreg32(SCU_PR1_USIC1RS, XMC4_SCU_PRCLR1);
|
||||||
}
|
}
|
||||||
|
#else
|
||||||
|
/* De-assert peripheral reset USIC1 */
|
||||||
|
|
||||||
|
putreg32(SCU_PR1_USIC1RS, XMC4_SCU_PRCLR1);
|
||||||
|
#endif
|
||||||
break;
|
break;
|
||||||
|
|
||||||
#if XMC4_NUSIC > 2
|
#if XMC4_NUSIC > 2
|
||||||
case USIC2:
|
case USIC2:
|
||||||
|
#ifdef XMC4_SCU_GATING
|
||||||
/* Check if USIC2 is already ungated */
|
/* Check if USIC2 is already ungated */
|
||||||
|
|
||||||
if ((getreg32(XMC4_SCU_CGATSTAT1) & SCU_CGAT1_USIC2) == 0)
|
if ((getreg32(XMC4_SCU_CGATSTAT1) & SCU_CGAT1_USIC2) == 0)
|
||||||
@ -158,10 +169,15 @@ int xmc4_enable_usic(enum usic_e usic)
|
|||||||
|
|
||||||
putreg32(SCU_PR1_USIC2RS, XMC4_SCU_PRCLR1);
|
putreg32(SCU_PR1_USIC2RS, XMC4_SCU_PRCLR1);
|
||||||
}
|
}
|
||||||
|
#else
|
||||||
|
/* De-assert peripheral reset USIC2 */
|
||||||
|
|
||||||
|
putreg32(SCU_PR1_USIC2RS, XMC4_SCU_PRCLR1);
|
||||||
|
#endif
|
||||||
break;
|
break;
|
||||||
#endif
|
|
||||||
#endif
|
#endif /* XMC4_NUSIC > 2 */
|
||||||
|
#endif /* XMC4_NUSIC > 1 */
|
||||||
|
|
||||||
default:
|
default:
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
@ -191,9 +207,11 @@ int xmc4_disable_usic(enum usic_e usic)
|
|||||||
|
|
||||||
putreg32(SCU_PR0_USIC0RS, XMC4_SCU_PRSET0);
|
putreg32(SCU_PR0_USIC0RS, XMC4_SCU_PRSET0);
|
||||||
|
|
||||||
|
#ifdef XMC4_SCU_GATING
|
||||||
/* Gate USIC0 clocking */
|
/* Gate USIC0 clocking */
|
||||||
|
|
||||||
putreg32(SCU_CGAT0_USIC0, XMC4_SCU_CGATSET0);
|
putreg32(SCU_CGAT0_USIC0, XMC4_SCU_CGATSET0);
|
||||||
|
#endif
|
||||||
break;
|
break;
|
||||||
|
|
||||||
#if XMC4_NUSIC > 1
|
#if XMC4_NUSIC > 1
|
||||||
@ -202,9 +220,11 @@ int xmc4_disable_usic(enum usic_e usic)
|
|||||||
|
|
||||||
putreg32(SCU_PR1_USIC1RS, XMC4_SCU_PRSET1);
|
putreg32(SCU_PR1_USIC1RS, XMC4_SCU_PRSET1);
|
||||||
|
|
||||||
|
#ifdef XMC4_SCU_GATING
|
||||||
/* Gate USIC0 clocking */
|
/* Gate USIC0 clocking */
|
||||||
|
|
||||||
putreg32(SCU_CGAT1_USIC1, XMC4_SCU_CGATSET1);
|
putreg32(SCU_CGAT1_USIC1, XMC4_SCU_CGATSET1);
|
||||||
|
#endif
|
||||||
break;
|
break;
|
||||||
|
|
||||||
#if XMC4_NUSIC > 2
|
#if XMC4_NUSIC > 2
|
||||||
@ -213,12 +233,15 @@ int xmc4_disable_usic(enum usic_e usic)
|
|||||||
|
|
||||||
putreg32(SCU_PR1_USIC2RS, XMC4_SCU_PRSET1);
|
putreg32(SCU_PR1_USIC2RS, XMC4_SCU_PRSET1);
|
||||||
|
|
||||||
|
#ifdef XMC4_SCU_GATING
|
||||||
/* Gate USIC0 clocking */
|
/* Gate USIC0 clocking */
|
||||||
|
|
||||||
putreg32(SCU_CGAT1_USIC2, XMC4_SCU_CGATSET1);
|
putreg32(SCU_CGAT1_USIC2, XMC4_SCU_CGATSET1);
|
||||||
|
#endif
|
||||||
break;
|
break;
|
||||||
#endif
|
|
||||||
#endif
|
#endif /* XMC4_NUSIC > 2 */
|
||||||
|
#endif /* XMC4_NUSIC > 1 */
|
||||||
|
|
||||||
default:
|
default:
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
@ -250,8 +250,8 @@ CONFIG_BOOT_RUNFROMFLASH=y
|
|||||||
#
|
#
|
||||||
# Boot Memory Configuration
|
# Boot Memory Configuration
|
||||||
#
|
#
|
||||||
CONFIG_RAM_START=0x20400000
|
CONFIG_RAM_START=0x20000000
|
||||||
CONFIG_RAM_SIZE=393216
|
CONFIG_RAM_SIZE=65536
|
||||||
# CONFIG_ARCH_HAVE_SDRAM is not set
|
# CONFIG_ARCH_HAVE_SDRAM is not set
|
||||||
|
|
||||||
#
|
#
|
||||||
|
Loading…
Reference in New Issue
Block a user