aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKevin O'Connor <kevin@koconnor.net>2018-08-20 16:52:43 -0400
committerKevin O'Connor <kevin@koconnor.net>2018-08-27 12:44:59 -0400
commiteec58b99fe46f5886a91039e0e7ca515a4154f40 (patch)
treeee8c1cdecc696ae9599e418cee537d032e648674
parent109eff0191fef3b4e939b3d506d6c31fcbd6ab0c (diff)
downloadkutter-eec58b99fe46f5886a91039e0e7ca515a4154f40.tar.gz
kutter-eec58b99fe46f5886a91039e0e7ca515a4154f40.tar.xz
kutter-eec58b99fe46f5886a91039e0e7ca515a4154f40.zip
sam4e8e: Add support for gpio_x_reset()
Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
-rw-r--r--src/sam4e8e/gpio.c60
-rw-r--r--src/sam4e8e/gpio.h8
2 files changed, 38 insertions, 30 deletions
diff --git a/src/sam4e8e/gpio.c b/src/sam4e8e/gpio.c
index d08e92a6..6f736b65 100644
--- a/src/sam4e8e/gpio.c
+++ b/src/sam4e8e/gpio.c
@@ -74,27 +74,31 @@ gpio_out_setup(uint8_t pin, uint8_t val)
goto fail;
uint32_t port = GPIO2PORT(pin);
Pio *regs = digital_regs[port];
- uint32_t bit = GPIO2BIT(pin);
uint32_t bank_id = ID_PIOA + port;
-
- irqstatus_t flag = irq_save();
-
if ((PMC->PMC_PCSR0 & (1u << bank_id)) == 0) {
PMC->PMC_PCER0 = 1 << bank_id;
}
+ struct gpio_out g = { .regs=regs, .bit=GPIO2BIT(pin) };
+ gpio_out_reset(g, val);
+ return g;
+fail:
+ shutdown("Not an output pin");
+}
+void
+gpio_out_reset(struct gpio_out g, uint8_t val)
+{
+ Pio *regs = g.regs;
+ irqstatus_t flag = irq_save();
if (val)
- regs->PIO_SODR = bit;
+ regs->PIO_SODR = g.bit;
else
- regs->PIO_CODR = bit;
- regs->PIO_OER = bit;
- regs->PIO_OWER = bit;
- regs->PIO_PER = bit;
-
+ regs->PIO_CODR = g.bit;
+ regs->PIO_OER = g.bit;
+ regs->PIO_OWER = g.bit;
+ regs->PIO_PER = g.bit;
+ regs->PIO_PUDR = g.bit;
irq_restore(flag);
- return (struct gpio_out){ .pin=pin, .regs=regs, .bit=bit };
-fail:
- shutdown("Not an output pin");
}
void
@@ -129,28 +133,30 @@ gpio_in_setup(uint8_t pin, int8_t pull_up)
goto fail;
uint32_t port = GPIO2PORT(pin);
Pio *regs = digital_regs[port];
- uint32_t bit = GPIO2BIT(pin);
uint32_t bank_id = ID_PIOA + port;
-
- regs->PIO_IDR = bit;
- irqstatus_t flag = irq_save();
-
if ((PMC->PMC_PCSR0 & (1u << bank_id)) == 0) {
PMC->PMC_PCER0 = 1 << bank_id;
}
+ struct gpio_in g = { .regs=regs, .bit=GPIO2BIT(pin) };
+ gpio_in_reset(g, pull_up);
+ return g;
+fail:
+ shutdown("Not an input pin");
+}
+void
+gpio_in_reset(struct gpio_in g, int8_t pull_up)
+{
+ Pio *regs = g.regs;
+ irqstatus_t flag = irq_save();
+ regs->PIO_IDR = g.bit;
if (pull_up)
- regs->PIO_PUER = bit;
+ regs->PIO_PUER = g.bit;
else
- regs->PIO_PUDR = bit;
-
- regs->PIO_ODR = bit;
- regs->PIO_PER = bit;
-
+ regs->PIO_PUDR = g.bit;
+ regs->PIO_ODR = g.bit;
+ regs->PIO_PER = g.bit;
irq_restore(flag);
- return (struct gpio_in){ .pin=pin, .regs=regs, .bit=bit };
-fail:
- shutdown("Not an input pin");
}
uint8_t
diff --git a/src/sam4e8e/gpio.h b/src/sam4e8e/gpio.h
index 9855d30d..2ac13008 100644
--- a/src/sam4e8e/gpio.h
+++ b/src/sam4e8e/gpio.h
@@ -11,6 +11,7 @@ struct gpio_out {
void gpio_set_peripheral(char bank, uint32_t bit, char ptype, uint32_t pull_up);
struct gpio_out gpio_out_setup(uint8_t pin, uint8_t val);
+void gpio_out_reset(struct gpio_out g, uint8_t val);
void gpio_out_toggle_noirq(struct gpio_out g);
void gpio_out_toggle(struct gpio_out g);
void gpio_out_write(struct gpio_out g, uint8_t val);
@@ -21,15 +22,16 @@ struct gpio_in {
uint32_t bit;
};
+struct gpio_in gpio_in_setup(uint8_t pin, int8_t pull_up);
+void gpio_in_reset(struct gpio_in g, int8_t pull_up);
+uint8_t gpio_in_read(struct gpio_in g);
+
struct gpio_adc {
uint8_t pin;
void *afec;
uint32_t chan;
};
-struct gpio_in gpio_in_setup(uint8_t pin, int8_t pull_up);
-uint8_t gpio_in_read(struct gpio_in g);
-
struct gpio_adc gpio_pin_to_afec(uint8_t pin);
struct gpio_adc gpio_adc_setup(uint8_t pin);
uint32_t gpio_adc_sample(struct gpio_adc g);