From 4683036f98b319d1c36853c1a200d63c36b470ff Mon Sep 17 00:00:00 2001 From: Kevin O'Connor Date: Fri, 28 Dec 2018 19:00:29 -0500 Subject: [PATCH] sam3: Add enable_pclock() helper function Add a helper function to enable peripheral clocks. Signed-off-by: Kevin O'Connor --- src/sam3/adc.c | 4 ++-- src/sam3/gpio.c | 2 +- src/sam3/i2c.c | 5 +---- src/sam3/internal.h | 2 ++ src/sam3/main.c | 20 ++++++++++++++++++++ src/sam3/sam4e_afec.c | 5 +---- src/sam3/sam4e_spi.c | 8 ++------ src/sam3/serial.c | 2 +- src/sam3/spi.c | 4 +--- src/sam3/timer.c | 2 +- 10 files changed, 32 insertions(+), 22 deletions(-) diff --git a/src/sam3/adc.c b/src/sam3/adc.c index b9c5fb12..0baf9118 100644 --- a/src/sam3/adc.c +++ b/src/sam3/adc.c @@ -34,9 +34,9 @@ gpio_adc_setup(uint8_t pin) break; } - if (!(PMC->PMC_PCSR1 & (1 << (ID_ADC-32)))) { + if (!is_enabled_pclock(ID_ADC)) { // Setup ADC - PMC->PMC_PCER1 = 1 << (ID_ADC-32); + enable_pclock(ID_ADC); uint32_t prescal = SystemCoreClock / (2 * ADC_FREQ_MAX) - 1; ADC->ADC_MR = (ADC_MR_PRESCAL(prescal) | ADC_MR_STARTUP_SUT768 diff --git a/src/sam3/gpio.c b/src/sam3/gpio.c index a0dfa0a4..065663f9 100644 --- a/src/sam3/gpio.c +++ b/src/sam3/gpio.c @@ -110,7 +110,7 @@ gpio_in_setup(uint8_t pin, int8_t pull_up) if (GPIO2PORT(pin) >= ARRAY_SIZE(digital_regs)) goto fail; uint32_t port = GPIO2PORT(pin); - PMC->PMC_PCER0 = 1 << (ID_PIOA + port); + enable_pclock(ID_PIOA + port); struct gpio_in g = { .regs=digital_regs[port], .bit=GPIO2BIT(pin) }; gpio_in_reset(g, pull_up); return g; diff --git a/src/sam3/i2c.c b/src/sam3/i2c.c index ed9e4a03..27a04738 100644 --- a/src/sam3/i2c.c +++ b/src/sam3/i2c.c @@ -28,10 +28,7 @@ static void i2c_init(Twi *p_twi, uint32_t rate) { - uint32_t twi_id = (p_twi == TWI0) ? ID_TWI0 : ID_TWI1; - if ((PMC->PMC_PCSR0 & (1u << twi_id)) == 0) { - PMC->PMC_PCER0 = 1 << twi_id; - } + enable_pclock(p_twi == TWI0 ? ID_TWI0 : ID_TWI1); if (p_twi == TWI0) { gpio_peripheral(TWI0_SCL_GPIO, 'A', 0); gpio_peripheral(TWI0_SDA_GPIO, 'A', 0); diff --git a/src/sam3/internal.h b/src/sam3/internal.h index d90dda0b..e9457ed2 100644 --- a/src/sam3/internal.h +++ b/src/sam3/internal.h @@ -16,5 +16,7 @@ #define GPIO2BIT(PIN) (1<<((PIN) % 32)) void gpio_peripheral(uint32_t gpio, char ptype, int32_t pull_up); +int is_enabled_pclock(uint32_t id); +void enable_pclock(uint32_t id); #endif // internal.h diff --git a/src/sam3/main.c b/src/sam3/main.c index 3908fddb..68949ce7 100644 --- a/src/sam3/main.c +++ b/src/sam3/main.c @@ -35,6 +35,26 @@ DECL_INIT(watchdog_init); * misc functions ****************************************************************/ +// Check if a peripheral clock has been enabled +int +is_enabled_pclock(uint32_t id) +{ + if (id < 32) + return !!(PMC->PMC_PCSR0 & (1 << id)); + else + return !!(PMC->PMC_PCSR1 & (1 << (id - 32))); +} + +// Enable a peripheral clock +void +enable_pclock(uint32_t id) +{ + if (id < 32) + PMC->PMC_PCER0 = 1 << id; + else + PMC->PMC_PCER1 = 1 << (id - 32); +} + void command_reset(uint32_t *args) { diff --git a/src/sam3/sam4e_afec.c b/src/sam3/sam4e_afec.c index 69205c50..0e1c60ac 100644 --- a/src/sam3/sam4e_afec.c +++ b/src/sam3/sam4e_afec.c @@ -57,10 +57,7 @@ static int init_afec(Afec* afec) { // Enable PMC - if (afec == AFEC0) - PMC->PMC_PCER0 = 1 << ID_AFEC0; - else - PMC->PMC_PCER0 = 1 << ID_AFEC1; + enable_pclock(afec == AFEC0 ? ID_AFEC0 : ID_AFEC1); // If busy, return busy if ((afec->AFE_ISR & AFE_ISR_DRDY) == AFE_ISR_DRDY) { diff --git a/src/sam3/sam4e_spi.c b/src/sam3/sam4e_spi.c index 0fa9d3ca..2648eeff 100644 --- a/src/sam3/sam4e_spi.c +++ b/src/sam3/sam4e_spi.c @@ -31,9 +31,7 @@ spi_setup(uint32_t bus, uint8_t mode, uint32_t rate) // DUET_USART0_MISO as per dc42 CoreNG gpio_peripheral(GPIO('B', 0), 'C', 1); - if ((PMC->PMC_PCSR0 & (1u << ID_USART0)) == 0) { - PMC->PMC_PCER0 = 1 << ID_USART0; - } + enable_pclock(ID_USART0); p_usart = USART0; } else if (bus == SSPI_USART1) { // DUET_USART1_SCK as per dc42 CoreNG @@ -43,9 +41,7 @@ spi_setup(uint32_t bus, uint8_t mode, uint32_t rate) // DUET_USART1_MISO as per dc42 CoreNG gpio_peripheral(GPIO('A', 21), 'A', 1); - if ((PMC->PMC_PCSR0 & (1u << ID_USART1)) == 0) { - PMC->PMC_PCER0 = 1 << ID_USART1; - } + enable_pclock(ID_USART1); p_usart = USART1; } diff --git a/src/sam3/serial.c b/src/sam3/serial.c index e0249448..b7df5680 100644 --- a/src/sam3/serial.c +++ b/src/sam3/serial.c @@ -31,7 +31,7 @@ serial_init(void) gpio_peripheral(tx_pin, 'A', 0); // Reset uart - PMC->PMC_PCER0 = 1 << Pmc_id; + enable_pclock(Pmc_id); Port->UART_PTCR = UART_PTCR_RXTDIS | UART_PTCR_TXTDIS; Port->UART_CR = (UART_CR_RSTRX | UART_CR_RSTTX | UART_CR_RXDIS | UART_CR_TXDIS); diff --git a/src/sam3/spi.c b/src/sam3/spi.c index b6b832e5..a92a766b 100644 --- a/src/sam3/spi.c +++ b/src/sam3/spi.c @@ -23,9 +23,7 @@ spi_init(void) gpio_peripheral(GPIO('A', 27), 'A', 0); // Arduino 76 // Enable SPI clocks - if (!(PMC->PMC_PCSR0 & (1u << PERIPH_ID))) { - PMC->PMC_PCER0 = (1 << PERIPH_ID); - } + enable_pclock(PERIPH_ID); /* Disable SPI */ REGPTR->SPI_CR = SPI_CR_SPIDIS; diff --git a/src/sam3/timer.c b/src/sam3/timer.c index d5bc8c6a..987a76e8 100644 --- a/src/sam3/timer.c +++ b/src/sam3/timer.c @@ -41,7 +41,7 @@ timer_init(void) tc->TC_CCR = TC_CCR_CLKDIS; tc->TC_IDR = 0xFFFFFFFF; // Enable it - PMC->PMC_PCER0 = 1 << ID_TC0; + enable_pclock(ID_TC0); tc->TC_CMR = TC_CMR_WAVE | TC_CMR_WAVSEL_UP | TC_CMR_TCCLKS_TIMER_CLOCK1; tc->TC_IER = TC_IER_CPAS; NVIC_SetPriority(TC0_IRQn, 1);