mirror of
https://github.com/DCC-EX/CommandStation-EX.git
synced 2025-01-25 19:58:53 +01:00
Maybe fix?
This commit is contained in:
parent
6551ce7b50
commit
367b86cd09
@ -317,7 +317,7 @@ ModbusRTUMasterError Modbus::writeMultipleCoils(uint8_t id, uint16_t startAddres
|
|||||||
adu.setDataRegister(2, quantity);
|
adu.setDataRegister(2, quantity);
|
||||||
adu.data[4] = byteCount;
|
adu.data[4] = byteCount;
|
||||||
for (uint16_t i = 0; i < quantity; i++) {
|
for (uint16_t i = 0; i < quantity; i++) {
|
||||||
bitWrite(adu.data[5 + (i >> 3)], i & 7, (bool) buf[i]);
|
bitWrite(adu.data[5 + (i >> 3)], i & 7, buf[i]);
|
||||||
}
|
}
|
||||||
for (uint16_t i = quantity; i < (byteCount * 8); i++) {
|
for (uint16_t i = quantity; i < (byteCount * 8); i++) {
|
||||||
bitClear(adu.data[5 + (i >> 3)], i & 7);
|
bitClear(adu.data[5 + (i >> 3)], i & 7);
|
||||||
|
21
IO_Modbus.h
21
IO_Modbus.h
@ -208,41 +208,26 @@ public:
|
|||||||
int _read(VPIN vpin) override {
|
int _read(VPIN vpin) override {
|
||||||
// Return current state from this device
|
// Return current state from this device
|
||||||
uint16_t pin = vpin - _firstVpin;
|
uint16_t pin = vpin - _firstVpin;
|
||||||
if (pin < _numDiscreteInputs) {
|
|
||||||
return (int) discreteInputs[pin];
|
return (int) discreteInputs[pin];
|
||||||
} else
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void _write(VPIN vpin, int value) override {
|
void _write(VPIN vpin, int value) override {
|
||||||
// Update current state for this device, in preparation the bus transmission
|
// Update current state for this device, in preparation the bus transmission
|
||||||
uint16_t pin = vpin - _firstVpin - _numDiscreteInputs;
|
uint16_t pin = vpin - _firstVpin - _numDiscreteInputs;
|
||||||
if (pin < _numCoils) {
|
|
||||||
if (value){
|
|
||||||
if (value == 1) coils[pin] = (char*) 0x1;
|
if (value == 1) coils[pin] = (char*) 0x1;
|
||||||
if (value == 0) coils[pin] = (char*) 0x0;
|
if (value == 0) coils[pin] = (char*) 0x0;
|
||||||
//coils[pin] = value;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
coils[pin];
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int _readAnalogue(VPIN vpin) override {
|
int _readAnalogue(VPIN vpin) {
|
||||||
// Return acquired data value, e.g.
|
// Return acquired data value, e.g.
|
||||||
int pin = vpin - _firstVpin - _numDiscreteInputs - _numCoils;
|
int pin = vpin - _firstVpin - _numDiscreteInputs - _numCoils;
|
||||||
return (int) inputRegisters[pin-1];
|
return (int) inputRegisters[pin];
|
||||||
}
|
}
|
||||||
|
|
||||||
void _writeAnalogue(VPIN vpin, int value, uint8_t param1=0, uint16_t param2=0) override {
|
void _writeAnalogue(VPIN vpin, int value, uint8_t param1=0, uint16_t param2=0) override {
|
||||||
uint16_t pin = vpin - _firstVpin - _numDiscreteInputs - _numCoils - _numInputRegisters;
|
uint16_t pin = vpin - _firstVpin - _numDiscreteInputs - _numCoils - _numInputRegisters;
|
||||||
if (pin < _numHoldingRegisters) {
|
holdingRegisters[pin] = (uint16_t*) value;
|
||||||
if (value)
|
|
||||||
holdingRegisters[pin-1] = (uint16_t*) value;
|
|
||||||
else
|
|
||||||
holdingRegisters[pin-1];
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t getBusNumber() {
|
uint8_t getBusNumber() {
|
||||||
|
Loading…
Reference in New Issue
Block a user