Merge pull request #1834 from mdlemay/gpio-refactor
galileo: Simplify GPIO APIs and add support for gen. 1
This commit is contained in:
commit
61c9c21c5c
13 changed files with 868 additions and 81 deletions
|
@ -33,10 +33,11 @@
|
|||
#include "contiki.h"
|
||||
#include "sys/ctimer.h"
|
||||
|
||||
#include "galileo-gpio.h"
|
||||
#include "gpio.h"
|
||||
|
||||
#define PIN_OUTPUT 5
|
||||
#define PIN_INPUT 6
|
||||
#define PIN_OUTPUT 2
|
||||
#define PIN_INPUT 3
|
||||
|
||||
static uint32_t value;
|
||||
static struct ctimer timer;
|
||||
|
@ -51,9 +52,9 @@ timeout(void *data)
|
|||
|
||||
/* toggle pin state */
|
||||
value = !value;
|
||||
quarkX1000_gpio_write(PIN_OUTPUT, value);
|
||||
galileo_gpio_write(PIN_OUTPUT, value);
|
||||
|
||||
quarkX1000_gpio_read(PIN_INPUT, &value_in);
|
||||
galileo_gpio_read(PIN_INPUT, &value_in);
|
||||
|
||||
if (value == value_in)
|
||||
printf("GPIO pin value match!\n");
|
||||
|
@ -67,9 +68,6 @@ PROCESS_THREAD(gpio_input_process, ev, data)
|
|||
{
|
||||
PROCESS_BEGIN();
|
||||
|
||||
quarkX1000_gpio_config(PIN_OUTPUT, QUARKX1000_GPIO_OUT);
|
||||
quarkX1000_gpio_config(PIN_INPUT, QUARKX1000_GPIO_IN);
|
||||
|
||||
quarkX1000_gpio_clock_enable();
|
||||
|
||||
ctimer_set(&timer, CLOCK_SECOND / 2, timeout, NULL);
|
||||
|
|
|
@ -33,10 +33,11 @@
|
|||
#include "contiki.h"
|
||||
#include "sys/ctimer.h"
|
||||
|
||||
#include "galileo-gpio.h"
|
||||
#include "gpio.h"
|
||||
|
||||
#define PIN_OUTPUT 5
|
||||
#define PIN_INTR 6
|
||||
#define PIN_OUTPUT 2
|
||||
#define PIN_INTR 3
|
||||
|
||||
static struct ctimer timer;
|
||||
|
||||
|
@ -47,8 +48,8 @@ static void
|
|||
timeout(void *data)
|
||||
{
|
||||
/* emulate an interrupt */
|
||||
quarkX1000_gpio_write(PIN_OUTPUT, 0);
|
||||
quarkX1000_gpio_write(PIN_OUTPUT, 1);
|
||||
galileo_gpio_write(PIN_OUTPUT, 0);
|
||||
galileo_gpio_write(PIN_OUTPUT, 1);
|
||||
|
||||
ctimer_reset(&timer);
|
||||
}
|
||||
|
@ -63,8 +64,7 @@ PROCESS_THREAD(gpio_interrupt_process, ev, data)
|
|||
{
|
||||
PROCESS_BEGIN();
|
||||
|
||||
quarkX1000_gpio_config(PIN_OUTPUT, QUARKX1000_GPIO_OUT);
|
||||
quarkX1000_gpio_config(PIN_INTR, QUARKX1000_GPIO_INT | QUARKX1000_GPIO_ACTIVE_HIGH | QUARKX1000_GPIO_EDGE);
|
||||
galileo_gpio_config(PIN_INTR, QUARKX1000_GPIO_INT | QUARKX1000_GPIO_ACTIVE_HIGH | QUARKX1000_GPIO_EDGE);
|
||||
|
||||
quarkX1000_gpio_set_callback(callback);
|
||||
|
||||
|
|
|
@ -33,9 +33,10 @@
|
|||
#include "contiki.h"
|
||||
#include "sys/ctimer.h"
|
||||
|
||||
#include "galileo-gpio.h"
|
||||
#include "gpio.h"
|
||||
|
||||
#define PIN 5 /* IO2 */
|
||||
#define PIN 2
|
||||
|
||||
static uint32_t value;
|
||||
static struct ctimer timer;
|
||||
|
@ -48,7 +49,7 @@ timeout(void *data)
|
|||
{
|
||||
/* toggle pin state */
|
||||
value = !value;
|
||||
quarkX1000_gpio_write(PIN, value);
|
||||
galileo_gpio_write(PIN, value);
|
||||
|
||||
ctimer_reset(&timer);
|
||||
}
|
||||
|
@ -57,8 +58,6 @@ PROCESS_THREAD(gpio_output_process, ev, data)
|
|||
{
|
||||
PROCESS_BEGIN();
|
||||
|
||||
quarkX1000_gpio_config(PIN, QUARKX1000_GPIO_OUT);
|
||||
|
||||
quarkX1000_gpio_clock_enable();
|
||||
|
||||
ctimer_set(&timer, CLOCK_SECOND / 2, timeout, NULL);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue