sam4e8e: Rename gpio_set_peripheral() to gpio_peripheral()

Use the same definition for gpio_peripheral() that the sam3x8e code
uses.

Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
Kevin O'Connor 2018-12-25 11:19:30 -05:00
parent f0715de004
commit 7707d5a74e
5 changed files with 24 additions and 27 deletions

View File

@ -8,7 +8,7 @@
#include "board/irq.h" // irq_save
#include "command.h" // shutdown
#include "gpio.h" // gpio_out_setup
#include "internal.h" // gpio_set_peripheral
#include "internal.h" // gpio_peripheral
#include "sam4e.h" // Pio
#include "sched.h" // sched_shutdown
@ -22,9 +22,10 @@ static Pio * const digital_regs[] = {
****************************************************************/
void
gpio_set_peripheral(char bank, const uint32_t bit, char ptype, uint32_t pull_up) {
Pio *regs = digital_regs[bank - 'A'];
gpio_peripheral(uint32_t gpio, char ptype, int32_t pull_up)
{
uint32_t bank = GPIO2PORT(gpio), bit = GPIO2BIT(gpio);
Pio *regs = digital_regs[bank];
regs ->PIO_IDR = bit;
// Enable peripheral for pin
@ -61,7 +62,7 @@ gpio_set_peripheral(char bank, const uint32_t bit, char ptype, uint32_t pull_up)
regs->PIO_PDR = bit;
// Set pullup
if (pull_up) {
if (pull_up > 0) {
regs->PIO_PUER = bit;
} else {
regs->PIO_PUDR = bit;

View File

@ -14,20 +14,16 @@
#include "sched.h" // sched_shutdown
// I2C pin definitions
#define TWI0_SCL_BANK 'A'
#define TWI0_SCL_PIN PIO_PA4A_TWCK0
#define TWI0_SCL_GPIO GPIO('A', 4)
#define TWI0_SCL_PERIPH 'A'
#define TWI0_SDA_BANK 'A'
#define TWI0_SDA_PIN PIO_PA3A_TWD0
#define TWI0_SDA_GPIO GPIO('A', 3)
#define TWI0_SDA_PERIPH 'A'
#define TWI1_SCL_BANK 'B'
#define TWI1_SCL_PIN PIO_PB5A_TWCK1
#define TWI1_SCL_GPIO GPIO('B', 5)
#define TWI1_SCL_PERIPH 'A'
#define TWI1_SDA_BANK 'B'
#define TWI1_SDA_PIN PIO_PB4A_TWD1
#define TWI1_SDA_GPIO GPIO('B', 4)
#define TWI1_SDA_PERIPH 'A'
void
@ -38,11 +34,11 @@ i2c_init(Twi *p_twi, uint32_t rate)
PMC->PMC_PCER0 = 1 << twi_id;
}
if (p_twi == TWI0) {
gpio_set_peripheral(TWI0_SCL_BANK, TWI0_SCL_PIN, TWI0_SCL_PERIPH, 0);
gpio_set_peripheral(TWI0_SDA_BANK, TWI0_SDA_PIN, TWI0_SDA_PERIPH, 0);
gpio_peripheral(TWI0_SCL_GPIO, TWI0_SCL_PERIPH, 0);
gpio_peripheral(TWI0_SDA_GPIO, TWI0_SDA_PERIPH, 0);
} else {
gpio_set_peripheral(TWI1_SCL_BANK, TWI1_SCL_PIN, TWI1_SCL_PERIPH, 0);
gpio_set_peripheral(TWI1_SDA_BANK, TWI1_SDA_PIN, TWI1_SDA_PERIPH, 0);
gpio_peripheral(TWI1_SCL_GPIO, TWI1_SCL_PERIPH, 0);
gpio_peripheral(TWI1_SDA_GPIO, TWI1_SDA_PERIPH, 0);
}
p_twi->TWI_IDR = 0xFFFFFFFF;
(void)p_twi->TWI_SR;

View File

@ -8,6 +8,6 @@
#define GPIO2PORT(PIN) ((PIN) / 32)
#define GPIO2BIT(PIN) (1<<((PIN) % 32))
void gpio_set_peripheral(char bank, uint32_t bit, char ptype, uint32_t pull_up);
void gpio_peripheral(uint32_t gpio, char ptype, int32_t pull_up);
#endif // internal.h

View File

@ -13,8 +13,8 @@
void
serial_init(void)
{
gpio_set_peripheral('A', PIO_PA9A_URXD0, 'A', 1);
gpio_set_peripheral('A', PIO_PA10A_UTXD0, 'A', 0);
gpio_peripheral(GPIO('A', 9), 'A', 1);
gpio_peripheral(GPIO('A', 10), 'A', 0);
// Reset uart
PMC->PMC_PCER0 = 1 << ID_UART0;

View File

@ -7,7 +7,7 @@
#include "autoconf.h" // CONFIG_CLOCK_FREQ
#include "command.h" // shutdown
#include "gpio.h" // spi_setup
#include "internal.h" // gpio_set_peripheral
#include "internal.h" // gpio_peripheral
#include "sam4e.h" // USART0
#include "sched.h" // sched_shutdown
@ -25,11 +25,11 @@ spi_setup(uint32_t bus, uint8_t mode, uint32_t rate)
if (bus == SSPI_USART0) {
// DUET_USART0_SCK as per dc42 CoreNG
gpio_set_peripheral('B', PIO_PB13C_SCK0, 'C', 0);
gpio_peripheral(GPIO('B', 13), 'C', 0);
// DUET_USART0_MOSI as per dc42 CoreNG
gpio_set_peripheral('B', PIO_PB1C_TXD0, 'C', 0);
gpio_peripheral(GPIO('B', 1), 'C', 0);
// DUET_USART0_MISO as per dc42 CoreNG
gpio_set_peripheral('B', PIO_PB0C_RXD0, 'C', 1);
gpio_peripheral(GPIO('B', 0), 'C', 1);
if ((PMC->PMC_PCSR0 & (1u << ID_USART0)) == 0) {
PMC->PMC_PCER0 = 1 << ID_USART0;
@ -37,11 +37,11 @@ spi_setup(uint32_t bus, uint8_t mode, uint32_t rate)
p_usart = USART0;
} else if (bus == SSPI_USART1) {
// DUET_USART1_SCK as per dc42 CoreNG
gpio_set_peripheral('A', PIO_PA23A_SCK1, 'A', 0);
gpio_peripheral(GPIO('A', 23), 'A', 0);
// DUET_USART1_MOSI as per dc42 CoreNG
gpio_set_peripheral('A', PIO_PA22A_TXD1, 'A', 0);
gpio_peripheral(GPIO('A', 22), 'A', 0);
// DUET_USART1_MISO as per dc42 CoreNG
gpio_set_peripheral('A', PIO_PA21A_RXD1, 'A', 1);
gpio_peripheral(GPIO('A', 21), 'A', 1);
if ((PMC->PMC_PCSR0 & (1u << ID_USART1)) == 0) {
PMC->PMC_PCER0 = 1 << ID_USART1;