|
|
@ -1,4 +1,5 @@
|
|
|
|
/* Copyright 2016 Wez Furlong
|
|
|
|
/* Copyright 2016 Wez Furlong
|
|
|
|
|
|
|
|
* 2017 Jack Humbert
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
@ -14,23 +15,35 @@
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
|
|
|
|
// Some helpers for controlling gpio pins
|
|
|
|
// Some helpers for controlling gpio pins
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#if defined(PROTOCOL_CHIBIOS)
|
|
|
|
|
|
|
|
#include "hal.h"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#define PIN_VALUE(p) palReadPad(p & 0xFFFFFFF0, p & 0xF)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#define DDR_OUTPUT(p) palSetPadMode(p & 0xFFFFFFF0, p & 0xF, PAL_MODE_OUTPUT_PUSHPULL)
|
|
|
|
|
|
|
|
#define DDR_INPUT(p) palSetPadMode(p & 0xFFFFFFF0, p & 0xF, PAL_MODE_INPUT_PULLDOWN)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#define PORT_HIGH(p) palSetPad(p & 0xFFFFFFF0, p & 0xF)
|
|
|
|
|
|
|
|
#define PORT_LOW(p) palClearPad(p & 0xFFFFFFF0, p & 0xF)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#if defined(__AVR__)
|
|
|
|
#if defined(__AVR__)
|
|
|
|
#include <avr/io.h>
|
|
|
|
#include <avr/io.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
static inline volatile uint8_t* helper(pin_t p, uint8_t offset) {
|
|
|
|
#define PIN_ADDRESS(p, offset) _SFR_IO8(ADDRESS_BASE + (p >> PORT_SHIFTER) + offset)
|
|
|
|
return (volatile uint8_t*)((p >> 4) + offset + __SFR_OFFSET);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#define PIN(p) *helper(p, 0)
|
|
|
|
#define PIN(p) PIN_ADDRESS(p, 0)
|
|
|
|
#define PIN_VALUE(p) (PIN(p) & _BV(p & 0xF))
|
|
|
|
#define PIN_VALUE(p) (PIN(p) & _BV(p & 0xF))
|
|
|
|
|
|
|
|
|
|
|
|
#define DDR(p) *helper(p, 1)
|
|
|
|
#define DDR(p) PIN_ADDRESS(p, 1)
|
|
|
|
#define DDR_OUTPUT(p) (DDR(p) |= _BV(p & 0xF))
|
|
|
|
#define DDR_OUTPUT(p) (DDR(p) |= _BV(p & 0xF))
|
|
|
|
#define DDR_INPUT(p) (DDR(p) &= ~_BV(p & 0xF))
|
|
|
|
#define DDR_INPUT(p) (DDR(p) &= ~_BV(p & 0xF))
|
|
|
|
|
|
|
|
|
|
|
|
#define PORT(p) *helper(p, 2)
|
|
|
|
#define PORT(p) PIN_ADDRESS(p, 2)
|
|
|
|
#define PORT_HIGH(p) (PORT(p) |= _BV(p & 0xF))
|
|
|
|
#define PORT_HIGH(p) (PORT(p) |= _BV(p & 0xF))
|
|
|
|
#define PORT_LOW(p) (PORT(p) &= ~_BV(p & 0xF))
|
|
|
|
#define PORT_LOW(p) (PORT(p) &= ~_BV(p & 0xF))
|
|
|
|
|
|
|
|
|
|
|
@ -69,3 +82,5 @@ static inline void digitalWrite(uint8_t pin, int mode) {
|
|
|
|
static inline bool digitalRead(uint8_t pin) {
|
|
|
|
static inline bool digitalRead(uint8_t pin) {
|
|
|
|
return _SFR_IO8(pin >> 4) & _BV(pin & 0xf);
|
|
|
|
return _SFR_IO8(pin >> 4) & _BV(pin & 0xf);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#endif
|