1
0
mirror of https://github.com/DCC-EX/CommandStation-EX.git synced 2024-11-26 17:46:14 +01:00

input working

This commit is contained in:
Asbelos 2022-12-25 20:52:07 +00:00
parent 6c1c681a26
commit 9240e7c6ba
3 changed files with 65 additions and 32 deletions

View File

@ -161,6 +161,8 @@ public:
// once the GPIO port concerned has been read. // once the GPIO port concerned has been read.
void setGPIOInterruptPin(int16_t pinNumber); void setGPIOInterruptPin(int16_t pinNumber);
// Method to check if pins will overlap before creating new device.
static bool checkNoOverlap(VPIN firstPin, uint8_t nPins=1, uint8_t i2cAddress=0);
protected: protected:
@ -234,9 +236,6 @@ protected:
// pin low if an input changes state. // pin low if an input changes state.
int16_t _gpioInterruptPin = -1; int16_t _gpioInterruptPin = -1;
// Method to check if pins will overlap before creating new device.
static bool checkNoOverlap(VPIN firstPin, uint8_t nPins=1, uint8_t i2cAddress=0);
// Static support function for subclass creation // Static support function for subclass creation
static void addDevice(IODevice *newDevice); static void addDevice(IODevice *newDevice);

View File

@ -16,13 +16,16 @@
* You should have received a copy of the GNU General Public License * You should have received a copy of the GNU General Public License
* along with CommandStation. If not, see <https://www.gnu.org/licenses/>. * along with CommandStation. If not, see <https://www.gnu.org/licenses/>.
*/ */
#ifndef IO_DNIN8_h #ifndef IO_LEWDUINO_h
#define IO_DNIN8_h #define IO_LEWDUINO_h
#include <Arduino.h> #include <Arduino.h>
#include "defines.h"
#include "IODevice.h"
#define PIN_MASK(bit) (0x80>>(bit%8)) #define PIN_MASK(bit) (0x80>>(bit%8))
#define GET_BIT(bit) (_pinValues[bit/8] & PIN_MASK(bit) ) #define GET_BIT(x) (_pinValues[(x)/8] & PIN_MASK((x)) )
#define SET_BIT(bit) _pinValues[bit/8] |= PIN_MASK(bit) #define SET_BIT(x) _pinValues[(x)/8] |= PIN_MASK((x))
#define CLR_BIT(bit) _pinValues[bit/8] &= ~PIN_MASK(bit) #define CLR_BIT(x) _pinValues[(x)/8] &= ~PIN_MASK((x))
#define DIAG_IO #define DIAG_IO
@ -50,7 +53,7 @@ public:
_deviceState = DEVSTATE_NORMAL; _deviceState = DEVSTATE_NORMAL;
pinMode(_latchPin,OUTPUT); pinMode(_latchPin,OUTPUT);
pinMode(_clockPin,OUTPUT); pinMode(_clockPin,OUTPUT);
pinMode(_dataPin,INPUT_PULLUP); pinMode(_dataPin,_pinMap?INPUT_PULLUP:OUTPUT);
_display(); _display();
} }
@ -67,22 +70,27 @@ void _loopInput(unsigned long currentMicros) {
//set latch to HIGH to freeze & store parallel data //set latch to HIGH to freeze & store parallel data
ArduinoPins::fastWriteDigital(_latchPin, HIGH); ArduinoPins::fastWriteDigital(_latchPin, HIGH);
delayMicroseconds(20); delayMicroseconds(50);
//set latch to LOW to enable the data to be transmitted serially //set latch to LOW to enable the data to be transmitted serially
ArduinoPins::fastWriteDigital(_latchPin, LOW); ArduinoPins::fastWriteDigital(_latchPin, LOW);
delayMicroseconds(50);
// stream in the bitmap useing mapping order provided at constructor // stream in the bitmap useing mapping order provided at constructor
for (int xmitBit=0;xmitBit<_nShiftBytes*8; xmitBit++) { for (int xmitByte=0;xmitByte<_nShiftBytes; xmitByte++) {
ArduinoPins::fastWriteDigital(_clockPin, LOW); byte newByte=0;
delayMicroseconds(4); for (int xmitBit=0;xmitBit<8; xmitBit++) {
bool data = ArduinoPins::fastReadDigital(_dataPin); ArduinoPins::fastWriteDigital(_clockPin, LOW);
byte map=_pinMap[xmitBit%8]; delayMicroseconds(20);
//DIAG(F("DIN x=%d,d=%d m=%x"),xmitBit,data,map); bool data = ArduinoPins::fastReadDigital(_dataPin);
if (data) _pinValues[xmitBit/8] |= map; byte map=_pinMap[xmitBit];
else _pinValues[xmitBit/8] &= ~map; if (data) newByte |= map;
ArduinoPins::fastWriteDigital(_clockPin, HIGH); else newByte &= ~map;
} ArduinoPins::fastWriteDigital(_clockPin, HIGH);
// DIAG(F("DIN %x"),_pinValues[0]); delayMicroseconds(20);
}
_pinValues[xmitByte]=newByte;
DIAG(F("DIN %x=%x"),xmitByte, newByte);
}
} }
void _loopOutput() { void _loopOutput() {
@ -98,7 +106,9 @@ void _loopOutput() {
} }
int _read(VPIN vpin) override { int _read(VPIN vpin) override {
return GET_BIT(vpin - _firstVpin); int pin=vpin - _firstVpin;
bool b=GET_BIT(pin);
return b?1:0;
} }
void _write(VPIN vpin, int value) override { void _write(VPIN vpin, int value) override {
@ -112,14 +122,14 @@ void _loopOutput() {
} }
void _display() override { void _display() override {
DIAG(F("IO_LEWDUINO %SPUT Configured on VPins:%d-%d"), DIAG(F("IO_LEWDUINO %SPUT Configured on VPins:%d-%d shift=%d"),
_pinMap?F("IN"):F("OUT"), _pinMap?F("IN"):F("OUT"),
(int)_firstVpin, (int)_firstVpin,
(int)_firstVpin+_nPins-1); (int)_firstVpin+_nPins-1, _nShiftBytes*8);
} }
private: private:
static const unsigned long POLL_MICROS=100000; // 10 / S static const unsigned long POLL_MICROS=1000000; // 10 / S
unsigned long _prevMicros; unsigned long _prevMicros;
int _nShiftBytes=0; int _nShiftBytes=0;
VPIN _latchPin,_clockPin,_dataPin; VPIN _latchPin,_clockPin,_dataPin;
@ -128,23 +138,26 @@ private:
const byte* _pinMap; // NULL in output mode const byte* _pinMap; // NULL in output mode
}; };
class IO_DNIN8 { class IO_DNIN8 {
public: public:
static void create(VPIN firstVpin, int nPins, byte latchPin, byte clockPin, byte dataPin ) static void create(VPIN firstVpin, int nPins, byte clockPin, byte latchPin, byte dataPin )
{ {
// input arrives as board pin 0,7,6,5,1,2,3,4 // input arrives as board pin 0,7,6,5,1,2,3,4
static const byte pinmap[8]={0x80,0x01,0x02,0x04,0x40,0x20,0x10,0x08}; static const byte pinmap[8]={0x80,0x01,0x02,0x04,0x40,0x20,0x10,0x08};
new IO_LEWDUINO( firstVpin, nPins, latchPin, clockPin, dataPin,pinmap); if (IODevice::checkNoOverlap(firstVpin,nPins))
new IO_LEWDUINO( firstVpin, nPins, clockPin, latchPin, dataPin,pinmap);
} }
}; };
class IO_DNIN8K { class IO_DNIN8K {
public: public:
static void create(VPIN firstVpin, int nPins, byte clockPin, byte latchPin, byte dataPin ) static void create(VPIN firstVpin, int nPins, byte clockPin, byte latchPin, byte dataPin )
{ {
static const byte pinmap[8]={0x80,0x01,0x02,0x04,0x40,0x20,0x10,0x08}; // TODO // input arrives as board pin 0, 1, 2, 3, 4, 5, 6, 7
new IO_LEWDUINO( firstVpin, nPins, clockPin, latchPin, dataPin,pinmap); static const byte pinmap[8]={0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80};
if (IODevice::checkNoOverlap(firstVpin,nPins))
new IO_LEWDUINO( firstVpin, nPins, clockPin, latchPin, dataPin,pinmap);
} }
}; };
@ -152,7 +165,8 @@ class IO_DNOUT8 {
public: public:
static void create(VPIN firstVpin, int nPins, byte clockPin, byte latchPin, byte dataPin ) static void create(VPIN firstVpin, int nPins, byte clockPin, byte latchPin, byte dataPin )
{ {
new IO_LEWDUINO( firstVpin, nPins, clockPin, latchPin, dataPin,NULL); if (IODevice::checkNoOverlap(firstVpin,nPins))
new IO_LEWDUINO( firstVpin, nPins, clockPin, latchPin, dataPin,NULL);
} }
}; };

View File

@ -0,0 +1,20 @@
Using Lew's Duino Gear boards:
1. DNIN8 Input
This is a shift-register implementation of a digital input collector.
Multiple DNIN8 may be connected in sequence but it is IMPORTANT that the software
configuratuion correctly represents the number of boards connected otherwise the results will be meaningless.
Use in myAnimation.h
HAL(IO_DNIN8, firstVpin, numPins, clockPin, latchPin, dataPin)
e.g.
HAL(IO_DNIN8, 400, 16, 40, 42, 44)
This will create virtaul pins 400-415 using two DNIN8 boards connected in sequence.
Vpins 400-407 will be on the first board (closest to the CS) and 408-415 on the second.
Note: 16 pins uses two boards. You may specify a non-multiple-of-8 pins but this will be rounded up to a multiple of 8 and you must connect ONLY the number of boards that this takes.
This example uses Arduino GPIO pins 40,42,44 as these are conveniently side-by-side on a Mega which is easier when you are using a 3 strand cable.