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:
parent
f0715de004
commit
7707d5a74e
|
@ -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;
|
||||
|
|
|
@ -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;
|
||||
|
|
|
@ -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
|
||||
|
|
|
@ -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;
|
||||
|
|
|
@ -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;
|
||||
|
|
Loading…
Reference in New Issue