#include <WiFi.h>
#include <OneWire.h>
#include <DallasTemperature.h>
#include <esp_system.h>
#include <Ticker.h>
const int ONE_WIRE_BUS = 14; // GPIO2
OneWire oneWire(ONE_WIRE_BUS); // Installeer OneWire bus
DallasTemperature sensors(&oneWire); // Installeer temperatuur sensor
// Addresses of 3 DS18B20s this can be more in the project below you can find way the get the adress
//https://wokwi.com/projects/405224123858814977
uint8_t sensor1[8] = { 0x28, 0xEE, 0xD5, 0x64, 0x1A, 0x16, 0x02, 0xEC };
uint8_t sensor2[8] = { 0x28, 0x61, 0x64, 0x12, 0x3C, 0x7C, 0x2F, 0x27 };
uint8_t sensor3[8] = { 0x28, 0x61, 0x64, 0x12, 0x3F, 0xFD, 0x80, 0xC6 };
const char* ssid = "Wokwi-GUEST"; // SSID
const char* password = ""; // SSID wachtwoord
int ModbusTCP_port = 502;
#define maxInputRegister 20
#define maxHoldingRegister 20
#define MB_FC_NONE 0
#define MB_FC_READ_REGISTERS 3 // Implemented
#define MB_FC_WRITE_REGISTER 6 // Implemented
#define MB_FC_WRITE_MULTIPLE_REGISTERS 16 // Implemented
#define MB_EC_NONE 0
#define MB_EC_ILLEGAL_FUNCTION 1
#define MB_EC_ILLEGAL_DATA_ADDRESS 2
#define MB_EC_ILLEGAL_DATA_VALUE 3
#define MB_EC_SLAVE_DEVICE_FAILURE 4
#define MB_TCP_TID 0
#define MB_TCP_PID 2
#define MB_TCP_LEN 4
#define MB_TCP_UID 6
#define MB_TCP_FUNC 7
#define MB_TCP_REGISTER_START 8
#define MB_TCP_REGISTER_NUMBER 10
byte ByteArray[260];
int MBHoldingRegister[maxHoldingRegister];
float temp1;
float temp2;
float temp3;
WiFiServer MBServer(ModbusTCP_port);
// Statische IP-instellingen
IPAddress local_IP(192, 168, 1, 50);
IPAddress gateway(192, 168, 1, 1);
IPAddress subnet(255, 255, 255, 0);
IPAddress primaryDNS(8, 8, 8, 8);
IPAddress secondaryDNS(8, 8, 4, 4);
Ticker resetTimer; // Ticker object voor reset bij geen verbinding
void restartESP() {
Serial.println("Geen verbinding gedurende 5 minuten, herstarten...");
esp_restart(); // Herstart de ESP32
}
void setup() {
pinMode(13, OUTPUT);
// Seriële monitor starten
Serial.begin(9600);
// Verbinding maken met WiFi
WiFi.begin(ssid, password);
// Wachten tot WiFi is verbonden
while (WiFi.status() != WL_CONNECTED) {
delay(1000);
Serial.println("Verbinden met WiFi...");
}
// Statische IP-configuratie toepassen
if (!WiFi.config(local_IP, gateway, subnet, primaryDNS, secondaryDNS)) {
Serial.println("Fout bij het configureren van een statisch IP-adres.");
}
// Verbinding opnieuw tot stand brengen met de nieuwe configuratie
WiFi.disconnect();
WiFi.begin(ssid, password);
// Wachten tot WiFi opnieuw is verbonden
while (WiFi.status() != WL_CONNECTED) {
delay(1000);
Serial.println("Opnieuw verbinden met WiFi...");
}
// Verbinding geslaagd
Serial.println("Verbonden met WiFi");
Serial.print("IP-adres: ");
Serial.println(WiFi.localIP());
MBServer.begin();
Serial.println("Connected ");
Serial.print("ESP32 Slave Modbus TCP/IP ");
Serial.print(WiFi.localIP());
Serial.print(":");
Serial.println(String(ModbusTCP_port));
Serial.println("Modbus TCP/IP Online");
// Start de reset timer voor 5 minuten
resetTimer.attach(900, restartESP); // 300 seconden = 5 minuten 900= 15min
}
void loop() {
WiFiClient client = MBServer.available();
if (client) {
resetTimer.detach(); // Stop de reset timer als er een client verbonden is
boolean flagClientConnected = 0;
byte byteFN = MB_FC_NONE;
int Start;
int WordDataLength;
int ByteDataLength;
int MessageLength;
while (client.connected()) {
if (client.available()) {
flagClientConnected = 1;
int i = 0;
while (client.available()) {
ByteArray[i] = client.read();
i++;
yield(); // Voeg hier yield() toe om te voorkomen dat de loop vastloopt
}
client.flush();
sensors.requestTemperatures(); //vraagt de temperatuur voor alles op
temp1 = sensors.getTempC(sensor1); //opslaan van sensor temperatuur in de variable
temp2 = sensors.getTempC(sensor2);
temp3 = sensors.getTempC(sensor3);
int temp1m = (temp1 * 100);
int temp2m = (temp2 * 100);
int temp3m = (temp3 * 100);
MBHoldingRegister[0] = random(0, 99);
MBHoldingRegister[1] = temp1m;
MBHoldingRegister[2] = temp2m;
MBHoldingRegister[3] = temp3m;
MBHoldingRegister[4] = random(0, 12);
MBHoldingRegister[5] = random(0, 12);
MBHoldingRegister[6] = random(0, 12);
MBHoldingRegister[7] = random(0, 12);
MBHoldingRegister[8] = random(0, 12);
MBHoldingRegister[9] = random(0, 12);
int Temporal[10];
Temporal[0] = MBHoldingRegister[10];
Temporal[1] = MBHoldingRegister[11];
Temporal[2] = MBHoldingRegister[12];
Temporal[3] = MBHoldingRegister[13];
Temporal[4] = MBHoldingRegister[14];
Temporal[5] = MBHoldingRegister[15];
Temporal[6] = MBHoldingRegister[16];
Temporal[7] = MBHoldingRegister[17];
Temporal[8] = MBHoldingRegister[18];
Temporal[9] = MBHoldingRegister[19];
digitalWrite(14, MBHoldingRegister[14]);
Serial.println("R/W:ok");
byteFN = ByteArray[MB_TCP_FUNC];
Start = word(ByteArray[MB_TCP_REGISTER_START], ByteArray[MB_TCP_REGISTER_START + 1]);
WordDataLength = word(ByteArray[MB_TCP_REGISTER_NUMBER], ByteArray[MB_TCP_REGISTER_NUMBER + 1]);
}
switch (byteFN) {
case MB_FC_NONE:
break;
case MB_FC_READ_REGISTERS:
ByteDataLength = WordDataLength * 2;
ByteArray[5] = ByteDataLength + 3;
ByteArray[8] = ByteDataLength;
for (int i = 0; i < WordDataLength; i++) {
ByteArray[9 + i * 2] = highByte(MBHoldingRegister[Start + i]);
ByteArray[10 + i * 2] = lowByte(MBHoldingRegister[Start + i]);
yield();
}
MessageLength = ByteDataLength + 9;
client.write((const uint8_t *)ByteArray, MessageLength);
byteFN = MB_FC_NONE;
yield();
break;
case MB_FC_WRITE_REGISTER:
MBHoldingRegister[Start] = word(ByteArray[MB_TCP_REGISTER_NUMBER], ByteArray[MB_TCP_REGISTER_NUMBER + 1]);
ByteArray[5] = 6;
MessageLength = 12;
client.write((const uint8_t *)ByteArray, MessageLength);
byteFN = MB_FC_NONE;
yield();
break;
case MB_FC_WRITE_MULTIPLE_REGISTERS:
ByteDataLength = WordDataLength * 2;
ByteArray[5] = ByteDataLength + 3;
for (int i = 0; i < WordDataLength; i++) {
MBHoldingRegister[Start + i] = word(ByteArray[13 + i * 2], ByteArray[14 + i * 2]);
yield();
}
MessageLength = 12;
client.write((const uint8_t *)ByteArray, MessageLength);
byteFN = MB_FC_NONE;
yield();
break;
}
}
if (!client.connected()) {
Serial.println("Client disconnected, ESP herstarten...");
esp_restart(); // Herstart de ESP32 direct na verbreken van de verbinding
}
} else {
if (!resetTimer.active()) {
resetTimer.attach(900, restartESP); // Start de reset timer als er geen client verbonden is
}
}
delay(500);
}