diff --git a/src/sam4e8e/gpio.c b/src/sam4e8e/gpio.c index 48695fc9..11516e44 100644 --- a/src/sam4e8e/gpio.c +++ b/src/sam4e8e/gpio.c @@ -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; diff --git a/src/sam4e8e/i2c.c b/src/sam4e8e/i2c.c index 454de61b..caf05f0a 100644 --- a/src/sam4e8e/i2c.c +++ b/src/sam4e8e/i2c.c @@ -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; diff --git a/src/sam4e8e/internal.h b/src/sam4e8e/internal.h index 2cd3f78f..cf0e0f81 100644 --- a/src/sam4e8e/internal.h +++ b/src/sam4e8e/internal.h @@ -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 diff --git a/src/sam4e8e/serial.c b/src/sam4e8e/serial.c index 12ae8de9..c75623bc 100644 --- a/src/sam4e8e/serial.c +++ b/src/sam4e8e/serial.c @@ -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; diff --git a/src/sam4e8e/spi.c b/src/sam4e8e/spi.c index dc65118d..0fa9d3ca 100644 --- a/src/sam4e8e/spi.c +++ b/src/sam4e8e/spi.c @@ -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;