diff options
author | lucwastiaux <luc.wastiaux@airpost.net> | 2016-12-10 12:49:47 +0800 |
---|---|---|
committer | lucwastiaux <luc.wastiaux@airpost.net> | 2016-12-10 12:49:47 +0800 |
commit | 9240f27ba909aece233bda59e4ec15f7666fdece (patch) | |
tree | 7b6e2b05a0722734e4739dd7b52817d82fae51c6 /quantum/pincontrol.h | |
parent | dc4c8875ba2b961deb5d9712f422b00ce7c90979 (diff) | |
parent | 985a091a739c99736d5b17de5161831488dbc219 (diff) |
Merge remote-tracking branch 'upstream/master'
Diffstat (limited to 'quantum/pincontrol.h')
-rw-r--r-- | quantum/pincontrol.h | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/quantum/pincontrol.h b/quantum/pincontrol.h new file mode 100644 index 0000000000..36ce29ef22 --- /dev/null +++ b/quantum/pincontrol.h @@ -0,0 +1,37 @@ +#pragma once +// Some helpers for controlling gpio pins +#include <avr/io.h> + +enum { + PinDirectionInput = 0, + PinDirectionOutput = 1, + PinLevelHigh = 1, + PinLevelLow = 0, +}; + +// ex: pinMode(B0, PinDirectionOutput); +static inline void pinMode(uint8_t pin, int mode) { + uint8_t bv = _BV(pin & 0xf); + if (mode == PinDirectionOutput) { + _SFR_IO8((pin >> 4) + 1) |= bv; + } else { + _SFR_IO8((pin >> 4) + 1) &= ~bv; + _SFR_IO8((pin >> 4) + 2) &= ~bv; + } +} + +// ex: digitalWrite(B0, PinLevelHigh); +static inline void digitalWrite(uint8_t pin, int mode) { + uint8_t bv = _BV(pin & 0xf); + if (mode == PinLevelHigh) { + _SFR_IO8((pin >> 4) + 2) |= bv; + } else { + _SFR_IO8((pin >> 4) + 2) &= ~bv; + } +} + +// Return true if the pin is HIGH +// digitalRead(B0) +static inline bool digitalRead(uint8_t pin) { + return _SFR_IO8(pin >> 4) & _BV(pin & 0xf); +} |