Updated hal_lld.c files to use the new TivaWare macros.
This commit is contained in:
parent
99a7c1518c
commit
220619763e
|
@ -76,8 +76,8 @@ void tiva_clock_init(void)
|
|||
* PLL. */
|
||||
/* read */
|
||||
|
||||
rcc = SYSCTL->RCC;
|
||||
rcc2 = SYSCTL->RCC2;
|
||||
rcc = HWREG(SYSCTL_RCC);
|
||||
rcc2 = HWREG(SYSCTL_RCC2);
|
||||
|
||||
/* modify */
|
||||
rcc |= TIVA_RCC_BYPASS;
|
||||
|
@ -85,8 +85,8 @@ void tiva_clock_init(void)
|
|||
rcc2 |= TIVA_RCC2_BYPASS2 | TIVA_RCC2_USERCC2;
|
||||
|
||||
/* write */
|
||||
SYSCTL->RCC = rcc;
|
||||
SYSCTL->RCC2 = rcc2;
|
||||
HWREG(SYSCTL_RCC) = rcc;
|
||||
HWREG(SYSCTL_RCC2) = rcc2;
|
||||
|
||||
/* 2 Select the crystal value (XTAL) and oscillator source (OSCSRC), and
|
||||
* clear the PWRDN bit in RCC and RCC2. Setting the XTAL field automatically
|
||||
|
@ -99,8 +99,8 @@ void tiva_clock_init(void)
|
|||
rcc2 |= ((TIVA_OSCSRC | TIVA_DIV400) & (TIVA_RCC2_OSCSRC2_MASK | TIVA_RCC2_DIV400));
|
||||
|
||||
/* write */
|
||||
SYSCTL->RCC = rcc;
|
||||
SYSCTL->RCC2 = rcc2;
|
||||
HWREG(SYSCTL_RCC) = rcc;
|
||||
HWREG(SYSCTL_RCC2) = rcc2;
|
||||
for(i = 100000; i; i--);
|
||||
|
||||
/* 3. Select the desired system divider (SYSDIV) in RCC and RCC2 and set the
|
||||
|
@ -113,23 +113,23 @@ void tiva_clock_init(void)
|
|||
rcc2 |= ((TIVA_SYSDIV2 | TIVA_SYSDIV2LSB) & (TIVA_RCC2_SYSDIV2_MASK | TIVA_RCC2_SYSDIV2LSB));
|
||||
|
||||
/* write */
|
||||
SYSCTL->RCC = rcc;
|
||||
SYSCTL->RCC2 = rcc2;
|
||||
HWREG(SYSCTL_RCC) = rcc;
|
||||
HWREG(SYSCTL_RCC2) = rcc2;
|
||||
|
||||
/* 4. Wait for the PLL to lock by polling the PLLLRIS bit in the Raw
|
||||
* Interrupt Status (RIS) register. */
|
||||
while ((SYSCTL->RIS & SYSCTL_RIS_PLLLRIS) == 0);
|
||||
while ((HWREG(SYSCTL_RIS) & SYSCTL_RIS_PLLLRIS) == 0);
|
||||
|
||||
/* 5. Enable use of the PLL by clearing the BYPASS bit in RCC and RCC2. */
|
||||
rcc &= ~TIVA_RCC_BYPASS;
|
||||
rcc2 &= ~TIVA_RCC2_BYPASS2;
|
||||
rcc |= (TIVA_BYPASS_VALUE << 11);
|
||||
rcc2 |= (TIVA_BYPASS_VALUE << 11);
|
||||
SYSCTL->RCC = rcc;
|
||||
SYSCTL->RCC2 = rcc2;
|
||||
HWREG(SYSCTL_RCC) = rcc;
|
||||
HWREG(SYSCTL_RCC2) = rcc2;
|
||||
|
||||
#if HAL_USE_PWM
|
||||
SYSCTL->RCC |= TIVA_PWM_FIELDS;
|
||||
HWREG(SYSCTL_RCC) |= TIVA_PWM_FIELDS;
|
||||
#endif
|
||||
|
||||
#if defined(TIVA_UDMA_REQUIRED)
|
||||
|
|
|
@ -76,8 +76,8 @@ void tiva_clock_init(void)
|
|||
/*
|
||||
* 2. Power up the MOSC by clearing the NOXTAL bit in the MOSCCTL register.
|
||||
*/
|
||||
moscctl = SYSCTL->MOSCCTL;
|
||||
moscctl &= ~MOSCCTL_NOXTAL;
|
||||
moscctl = HWREG(SYSCTL_MOSCCTL);
|
||||
moscctl &= ~SYSCTL_MOSCCTL_NOXTAL;
|
||||
|
||||
/*
|
||||
* 3. If single-ended MOSC mode is required, the MOSC is ready to use. If crystal mode is required,
|
||||
|
@ -85,18 +85,18 @@ void tiva_clock_init(void)
|
|||
* (RIS), indicating MOSC crystal mode is ready.
|
||||
*/
|
||||
#if TIVA_MOSC_SINGLE_ENDED
|
||||
SYSCTL->MOSCCTL = moscctl;
|
||||
HWREG(SYSCTL_MOSCCTL) = moscctl;
|
||||
#else
|
||||
moscctl &= ~MOSCCTL_PWRDN;
|
||||
SYSCTL->MOSCCTL = moscctl;
|
||||
moscctl &= ~SYSCTL_MOSCCTL_PWRDN;
|
||||
HWREG(SYSCTL_MOSCCTL) = moscctl;
|
||||
|
||||
while (!(SYSCTL->RIS & SYSCTL_RIS_MOSCPUPRIS));
|
||||
while (!(HWREG(SYSCTL_RIS) & SYSCTL_RIS_MOSCPUPRIS));
|
||||
#endif
|
||||
|
||||
/*
|
||||
* 4. Set the OSCSRC field to 0x3 in the RSCLKCFG register at offset 0x0B0.
|
||||
*/
|
||||
rsclkcfg = SYSCTL->RSCLKCFG;
|
||||
rsclkcfg = HWREG(SYSCTL_RSCLKCFG);
|
||||
|
||||
rsclkcfg |= TIVA_RSCLKCFG_OSCSRC;
|
||||
|
||||
|
@ -109,44 +109,42 @@ void tiva_clock_init(void)
|
|||
* 6. Write the PLLFREQ0 and PLLFREQ1 registers with the values of Q, N, MINT, and MFRAC to
|
||||
* the configure the desired VCO frequency setting.
|
||||
*/
|
||||
SYSCTL->PLLFREQ1 = (0x04 << 0); // 5 - 1
|
||||
SYSCTL->PLLFREQ0 = (0x60 << 0) | PLLFREQ0_PLLPWR;
|
||||
HWREG(SYSCTL_PLLFREQ1) = (0x04 << 0); // 5 - 1
|
||||
HWREG(SYSCTL_PLLFREQ0) = (0x60 << 0) | SYSCTL_PLLFREQ0_PLLPWR;
|
||||
|
||||
/*
|
||||
* 7. Write the MEMTIM0 register to correspond to the new system clock setting.
|
||||
*/
|
||||
SYSCTL->MEMTIM0 = (MEMTIM0_FBCHT_3_5 | MEMTIM0_FWS_5 | MEMTIM0_EBCHT_3_5 | MEMTIM0_EWS_5 | MEMTIM0_MB1);
|
||||
HWREG(SYSCTL_MEMTIM0) = (MEMTIM0_FBCHT_3_5 | MEMTIM0_FWS_5 | MEMTIM0_EBCHT_3_5 | MEMTIM0_EWS_5 | MEMTIM0_MB1);
|
||||
|
||||
/*
|
||||
* Wait for the PLLSTAT register to indicate the PLL has reached lock at the new operating point
|
||||
* (or that a timeout period has passed and lock has failed, in which case an error condition exists
|
||||
* and this sequence is abandoned and error processing is initiated).
|
||||
*/
|
||||
while (!SYSCTL->PLLSTAT & PLLSTAT_LOCK);
|
||||
while (!HWREG(SYSCTL_PLLSTAT) & SYSCTL_PLLSTAT_LOCK);
|
||||
|
||||
/*
|
||||
* 9. Write the RSCLKCFG register's PSYSDIV value, set the USEPLL bit to enabled, and MEMTIMU
|
||||
* bit.
|
||||
*/
|
||||
|
||||
rsclkcfg = SYSCTL->RSCLKCFG;
|
||||
rsclkcfg = HWREG(SYSCTL_RSCLKCFG);
|
||||
|
||||
rsclkcfg |= (RSCLKCFG_USEPLL | (0x03 << 0) | (0x03 << 20) | (0x03 << 24));
|
||||
rsclkcfg |= (SYSCTL_RSCLKCFG_USEPLL | (0x03 << 0) | (0x03 << 20) | (0x03 << 24));
|
||||
|
||||
//rsclkcfg |= ((0x03 << 0) | (1 << 28) | (0x03 << 20));
|
||||
|
||||
rsclkcfg |= RSCLKCFG_MEMTIMU;
|
||||
rsclkcfg |= SYSCTL_RSCLKCFG_MEMTIMU;
|
||||
|
||||
// set new configuration
|
||||
SYSCTL->RSCLKCFG = rsclkcfg;
|
||||
HWREG(SYSCTL_RSCLKCFG) = rsclkcfg;
|
||||
|
||||
#if HAL_USE_PWM
|
||||
#if TIVA_PWM_USE_PWM0
|
||||
PWM0->CC = TIVA_PWM_FIELDS;
|
||||
HWREG(PWM0_CC) = TIVA_PWM_FIELDS;
|
||||
#endif
|
||||
#endif
|
||||
}
|
||||
|
||||
/**
|
||||
* @}
|
||||
*/
|
||||
/** @} */
|
||||
|
|
Loading…
Reference in New Issue