mirror of
https://github.com/thelsing/knx.git
synced 2025-04-14 01:16:35 +02:00
Added functionality for W5500
Initialisation works. Compiling fails on "htonl" expansion. If commented out it compiles fine.
This commit is contained in:
parent
b0238cfe7e
commit
cf44c4efe9
3
.vscode/extensions.json
vendored
3
.vscode/extensions.json
vendored
@ -3,5 +3,8 @@
|
|||||||
// for the documentation about the extensions.json format
|
// for the documentation about the extensions.json format
|
||||||
"recommendations": [
|
"recommendations": [
|
||||||
"platformio.platformio-ide"
|
"platformio.platformio-ide"
|
||||||
|
],
|
||||||
|
"unwantedRecommendations": [
|
||||||
|
"ms-vscode.cpptools-extension-pack"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
@ -1,23 +1,32 @@
|
|||||||
#include <Arduino.h>
|
#include <Arduino.h>
|
||||||
#include <knx.h>
|
|
||||||
|
|
||||||
#if MASK_VERSION != 0x07B0 && (defined ARDUINO_ARCH_ESP8266 || defined ARDUINO_ARCH_ESP32)
|
#define USE_KNX
|
||||||
#include <WiFiManager.h>
|
|
||||||
|
#ifdef USE_KNX
|
||||||
|
#include <knx.h>
|
||||||
|
|
||||||
|
#if (MASK_VERSION != 0x07B0) && (defined ARDUINO_ARCH_ESP8266 || defined ARDUINO_ARCH_ESP32)
|
||||||
|
#include <WiFiManager.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if USE_W5X00 == 1
|
||||||
|
#include <SPI.h>
|
||||||
|
#include <Ethernet.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// create named references for easy access to group objects
|
// create named references for easy access to group objects
|
||||||
#define goCurrent knx.getGroupObject(1)
|
#define goCurrent knx.getGroupObject(1)
|
||||||
#define goMax knx.getGroupObject(2)
|
#define goMax knx.getGroupObject(2)
|
||||||
#define goMin knx.getGroupObject(3)
|
#define goMin knx.getGroupObject(3)
|
||||||
#define goReset knx.getGroupObject(4)
|
#define goReset knx.getGroupObject(4)
|
||||||
|
|
||||||
float currentValue = 0;
|
float currentValue = 0;
|
||||||
float maxValue = 0;
|
float maxValue = 0;
|
||||||
float minValue = RAND_MAX;
|
float minValue = RAND_MAX;
|
||||||
long lastsend = 0;
|
long lastsend = 0;
|
||||||
|
|
||||||
void measureTemp()
|
void measureTemp()
|
||||||
{
|
{
|
||||||
long now = millis();
|
long now = millis();
|
||||||
if ((now - lastsend) < 2000)
|
if ((now - lastsend) < 2000)
|
||||||
return;
|
return;
|
||||||
@ -41,36 +50,92 @@ void measureTemp()
|
|||||||
minValue = currentValue;
|
minValue = currentValue;
|
||||||
goMin.value(minValue);
|
goMin.value(minValue);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// callback from reset-GO
|
// callback from reset-GO
|
||||||
void resetCallback(GroupObject& go)
|
void resetCallback(GroupObject& go)
|
||||||
{
|
{
|
||||||
if (go.value())
|
if (go.value())
|
||||||
{
|
{
|
||||||
maxValue = 0;
|
maxValue = 0;
|
||||||
minValue = 10000;
|
minValue = 10000;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
void setup()
|
void setup()
|
||||||
{
|
{
|
||||||
Serial.begin(115200);
|
Serial.begin(115200);
|
||||||
|
while (!Serial) {
|
||||||
|
delay(1000); // wait for serial port to connect. Needed for native USB port only, long for vscode stupid text
|
||||||
|
}
|
||||||
|
|
||||||
|
// IP stuff
|
||||||
|
#if USE_W5X00 == 1
|
||||||
|
println("****** Set SS to pin 4 ******");
|
||||||
|
Ethernet.init(4);
|
||||||
|
byte _ma[6] = {0xC0, 0xFF, 0xEE, 0xC0, 0xDE, 0x00};
|
||||||
|
println("****** Bring up ethernet connection ******");
|
||||||
|
Ethernet.begin(_ma);
|
||||||
|
if (Ethernet.hardwareStatus() == EthernetNoHardware) {
|
||||||
|
println("****** No Ethernet shield found ******.");
|
||||||
|
println("****** Ideling forever... ******");
|
||||||
|
while (true) {
|
||||||
|
delay(1); // do nothing, no point running without Ethernet hardware or link
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (Ethernet.hardwareStatus() != EthernetW5500) {
|
||||||
|
println("****** Currently only working on W5500 controller ******");
|
||||||
|
println("****** Ideling forever... ******");
|
||||||
|
while (true) {
|
||||||
|
delay(1); // do nothing, no point running without Ethernet hardware or link
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (Ethernet.linkStatus() == LinkOFF) {
|
||||||
|
println("Link status: Off (No network cable connected or port on switch down)");
|
||||||
|
println("****** Ideling forever... ******");
|
||||||
|
while (true) {
|
||||||
|
delay(1); // do nothing, no point running without Ethernet hardware or link
|
||||||
|
}
|
||||||
|
}
|
||||||
|
println("****** Ethernet shield connected ******");
|
||||||
|
println("****** W5500 Ethernet controller detected ******");
|
||||||
|
println("****** Link status: On ******");
|
||||||
|
char ar[50];
|
||||||
|
sprintf(ar, "****** Mac address used: %02X:%02X:%02X:%02X:%02X:%02X ******", _ma[0], _ma[1], _ma[2], _ma[3], _ma[4], _ma[5]);
|
||||||
|
println(ar);
|
||||||
|
println("****** Ethernet connection up ******");
|
||||||
|
println("****** Connected with DHCP ******");
|
||||||
|
IPAddress _ip = Ethernet.localIP();
|
||||||
|
sprintf(ar, "****** IP address: %d.%d.%d.%d ******", _ip[0], _ip[1], _ip[2], _ip[3]);
|
||||||
|
println(ar);
|
||||||
|
_ip = Ethernet.subnetMask();
|
||||||
|
sprintf(ar, "****** Subnet mask: %d.%d.%d.%d ******", _ip[0], _ip[1], _ip[2], _ip[3]);
|
||||||
|
println(ar);
|
||||||
|
_ip = Ethernet.gatewayIP();
|
||||||
|
sprintf(ar, "****** Gateway: %d.%d.%d.%d ******", _ip[0], _ip[1], _ip[2], _ip[3]);
|
||||||
|
println(ar);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef USE_KNX
|
||||||
ArduinoPlatform::SerialDebug = &Serial;
|
ArduinoPlatform::SerialDebug = &Serial;
|
||||||
|
println("****** Serial debug running ******");
|
||||||
|
|
||||||
randomSeed(millis());
|
randomSeed(millis());
|
||||||
|
|
||||||
#if MASK_VERSION != 0x07B0 && (defined ARDUINO_ARCH_ESP8266 || defined ARDUINO_ARCH_ESP32)
|
#if ((MASK_VERSION != 0x07B0) && (defined ARDUINO_ARCH_ESP8266 || defined ARDUINO_ARCH_ESP32))
|
||||||
WiFiManager wifiManager;
|
WiFiManager wifiManager;
|
||||||
wifiManager.autoConnect("knx-demo");
|
wifiManager.autoConnect("knx-demo");
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
println("****** Start reading configuration ******");
|
||||||
// read adress table, association table, groupobject table and parameters from eeprom
|
// read adress table, association table, groupobject table and parameters from eeprom
|
||||||
knx.readMemory();
|
knx.readMemory();
|
||||||
|
|
||||||
// print values of parameters if device is already configured
|
// print values of parameters if device is already configured
|
||||||
if (knx.configured())
|
if (knx.configured())
|
||||||
{
|
{
|
||||||
|
println("****** Configuration found ******");
|
||||||
// register callback for reset GO
|
// register callback for reset GO
|
||||||
goReset.callback(resetCallback);
|
goReset.callback(resetCallback);
|
||||||
goReset.dataPointType(DPT_Trigger);
|
goReset.dataPointType(DPT_Trigger);
|
||||||
@ -89,20 +154,27 @@ void setup()
|
|||||||
Serial.print("Abgleich: ");
|
Serial.print("Abgleich: ");
|
||||||
Serial.println(knx.paramByte(4));
|
Serial.println(knx.paramByte(4));
|
||||||
}
|
}
|
||||||
|
else{
|
||||||
|
println("****** No stored configuration found ******");
|
||||||
|
}
|
||||||
|
|
||||||
// pin or GPIO the programming led is connected to. Default is LED_BUILTIN
|
// pin or GPIO the programming led is connected to. Default is LED_BUILTIN
|
||||||
// knx.ledPin(LED_BUILTIN);
|
// knx.ledPin(LED_BUILTIN);
|
||||||
// is the led active on HIGH or low? Default is LOW
|
// is the led active on HIGH or low? Default is LOW
|
||||||
// knx.ledPinActiveOn(HIGH);
|
// knx.ledPinActiveOn(HIGH);
|
||||||
// pin or GPIO programming button is connected to. Default is 0
|
// pin or GPIO programming button is connected to. Default is 0
|
||||||
// knx.buttonPin(0);
|
println("****** Set KNX reset button to pin 1 ******");
|
||||||
|
knx.buttonPin(1);
|
||||||
|
println("****** Starting knx framework ******");
|
||||||
// start the framework.
|
// start the framework.
|
||||||
knx.start();
|
knx.start();
|
||||||
|
println("****** Knx framework started ******");
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void loop()
|
void loop()
|
||||||
{
|
{
|
||||||
|
#ifdef USE_KNX
|
||||||
// don't delay here to much. Otherwise you might lose packages or mess up the timing with ETS
|
// don't delay here to much. Otherwise you might lose packages or mess up the timing with ETS
|
||||||
knx.loop();
|
knx.loop();
|
||||||
|
|
||||||
@ -110,5 +182,7 @@ void loop()
|
|||||||
if (!knx.configured())
|
if (!knx.configured())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
measureTemp();
|
// measureTemp();
|
||||||
|
#endif
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -11,17 +11,40 @@
|
|||||||
[platformio]
|
[platformio]
|
||||||
src_dir = examples/knx-demo
|
src_dir = examples/knx-demo
|
||||||
|
|
||||||
|
[env:feather_m4_w5500]
|
||||||
[env]
|
|
||||||
platform = atmelsam
|
platform = atmelsam
|
||||||
board = zeroUSB
|
board = adafruit_feather_m4
|
||||||
framework = arduino
|
framework = arduino
|
||||||
build_type = debug
|
build_type = debug
|
||||||
monitor_speed = 115200
|
monitor_speed = 115200
|
||||||
lib_ldf_mode = deep+
|
; lib_ldf_mode = deep+
|
||||||
lib_extra_dirs =
|
lib_extra_dirs =
|
||||||
${sysenv.USERPROFILE}/Documents/PlatformIO/Projects
|
${sysenv.USERPROFILE}/Documents/Arduino/libraries
|
||||||
|
lib_compat_mode = strict
|
||||||
|
lib_deps =
|
||||||
|
|
||||||
build_flags =
|
build_flags =
|
||||||
|
; -DMASK_VERSION=0x07B0
|
||||||
|
-DMASK_VERSION=0x57B0
|
||||||
|
-DUSE_W5X00=1
|
||||||
|
-DKNX_NO_SPI=1
|
||||||
|
; -DKNX_NO_DEFAULT_UART=1
|
||||||
-Wno-unknown-pragmas
|
-Wno-unknown-pragmas
|
||||||
|
|
||||||
|
; [env:feather_esspresif32]
|
||||||
|
; platform = espressif32
|
||||||
|
; board = esp32dev
|
||||||
|
; framework = arduino
|
||||||
|
; build_type = debug
|
||||||
|
; monitor_speed = 115200
|
||||||
|
; ; lib_ldf_mode = deep+
|
||||||
|
; lib_extra_dirs =
|
||||||
|
; ${sysenv.USERPROFILE}/Documents/Arduino/libraries
|
||||||
|
; lib_compat_mode = strict
|
||||||
|
; lib_deps =
|
||||||
|
|
||||||
|
; build_flags =
|
||||||
|
; -DMASK_VERSION=0x57B0,
|
||||||
|
; -Wno-unknown-pragmas
|
||||||
|
|
||||||
[env:build]
|
[env:build]
|
||||||
|
@ -42,8 +42,8 @@
|
|||||||
KnxFacade<Samd51Platform, Bau07B0> knx(buttonEvent);
|
KnxFacade<Samd51Platform, Bau07B0> knx(buttonEvent);
|
||||||
#elif MASK_VERSION == 0x27B0
|
#elif MASK_VERSION == 0x27B0
|
||||||
KnxFacade<Samd51Platform, Bau2920> knx(buttonEvent);
|
KnxFacade<Samd51Platform, Bau2920> knx(buttonEvent);
|
||||||
// #elif MASK_VERSION == 0x57B0
|
#elif MASK_VERSION == 0x57B0
|
||||||
// KnxFacade<Samd51Platform, Bau57B0> knx(buttonEvent);
|
KnxFacade<Samd51Platform, Bau57B0> knx(buttonEvent);
|
||||||
#else
|
#else
|
||||||
#error "Mask version not supported on SAMD51"
|
#error "Mask version not supported on SAMD51"
|
||||||
#endif
|
#endif
|
||||||
|
@ -479,8 +479,8 @@ template <class P, class B> class KnxFacade : private SaveRestore
|
|||||||
extern KnxFacade<Samd51Platform, Bau07B0> knx;
|
extern KnxFacade<Samd51Platform, Bau07B0> knx;
|
||||||
#elif MASK_VERSION == 0x27B0
|
#elif MASK_VERSION == 0x27B0
|
||||||
extern KnxFacade<Samd51Platform, Bau27B0> knx;
|
extern KnxFacade<Samd51Platform, Bau27B0> knx;
|
||||||
// #elif MASK_VERSION == 0x57B0
|
#elif MASK_VERSION == 0x57B0
|
||||||
// extern KnxFacade<Samd51Platform, Bau57B0> knx;
|
extern KnxFacade<Samd51Platform, Bau57B0> knx;
|
||||||
#else
|
#else
|
||||||
#error "Mask version not supported on SAMD51"
|
#error "Mask version not supported on SAMD51"
|
||||||
#endif
|
#endif
|
||||||
|
@ -43,6 +43,110 @@ void Samd51Platform::restart()
|
|||||||
NVIC_SystemReset();
|
NVIC_SystemReset();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if USE_W5X00 == 1
|
||||||
|
|
||||||
|
uint32_t Samd51Platform::currentIpAddress()
|
||||||
|
{
|
||||||
|
// IPAddress _ip = Ethernet.localIP();
|
||||||
|
// _ipAddress = htonl(_ip);
|
||||||
|
// return _ipAddress;
|
||||||
|
|
||||||
|
return Ethernet.localIP();
|
||||||
|
|
||||||
|
// _ipAddress = 0x0A063232;
|
||||||
|
// return _ipAddress;
|
||||||
|
|
||||||
|
// return 0x0A063232;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint32_t Samd51Platform::currentSubnetMask()
|
||||||
|
{
|
||||||
|
// IPAddress _nm = Ethernet.subnetMask();
|
||||||
|
// _netmask = htonl(_nm);
|
||||||
|
// return _netmask;
|
||||||
|
|
||||||
|
return Ethernet.subnetMask();
|
||||||
|
|
||||||
|
// _netmask = 0xFFFFFF00;
|
||||||
|
// return _netmask;
|
||||||
|
|
||||||
|
// return 0xFFFFFF00;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint32_t Samd51Platform::currentDefaultGateway()
|
||||||
|
{
|
||||||
|
// IPAddress _gw = Ethernet.gatewayIP();
|
||||||
|
// _defaultGateway = htonl(_gw);
|
||||||
|
// return _defaultGateway;
|
||||||
|
|
||||||
|
return Ethernet.gatewayIP();
|
||||||
|
|
||||||
|
// _defaultGateway = 0x0A063201;
|
||||||
|
// return _defaultGateway;
|
||||||
|
|
||||||
|
// return 0x0A063201;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Samd51Platform::macAddress(uint8_t * mac_address)
|
||||||
|
{
|
||||||
|
//Ethernet.macAddress(mac_address); //try this first, not sure if this will work, is for ethernet3 lib
|
||||||
|
memcpy(mac_address, _macAddress, sizeof(_macAddress) / sizeof(_macAddress[0])); //sizeof should resolve to be just 6
|
||||||
|
}
|
||||||
|
|
||||||
|
void Samd51Platform::setupMultiCast(uint32_t addr, uint16_t port)
|
||||||
|
{
|
||||||
|
IPAddress _mcastaddr(htonl(addr));
|
||||||
|
|
||||||
|
KNX_DEBUG_SERIAL.printf("setup multicast on %d.%d.%d.%d:%d\n", _mcastaddr[0], _mcastaddr[1], _mcastaddr[2], _mcastaddr[3], port);
|
||||||
|
uint8_t result = _udp.beginMulticast(_multicastAddr, _multicastPort);
|
||||||
|
KNX_DEBUG_SERIAL.printf("result %d\n", result);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Samd51Platform::closeMultiCast()
|
||||||
|
{
|
||||||
|
_udp.stop();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Samd51Platform::sendBytesMultiCast(uint8_t * buffer, uint16_t len)
|
||||||
|
{
|
||||||
|
//printHex("<- ",buffer, len);
|
||||||
|
_udp.beginPacket(_multicastAddr, _multicastPort);
|
||||||
|
_udp.write(buffer, len);
|
||||||
|
_udp.endPacket();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
int Samd51Platform::readBytesMultiCast(uint8_t * buffer, uint16_t maxLen)
|
||||||
|
{
|
||||||
|
int len = _udp.parsePacket();
|
||||||
|
if (len == 0)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
if (len > maxLen)
|
||||||
|
{
|
||||||
|
KNX_DEBUG_SERIAL.printf("udp buffer to small. was %d, needed %d\n", maxLen, len);
|
||||||
|
fatalError();
|
||||||
|
}
|
||||||
|
|
||||||
|
_udp.read(buffer, len);
|
||||||
|
printHex("-> ", buffer, len);
|
||||||
|
return len;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Samd51Platform::sendBytesUniCast(uint32_t addr, uint16_t port, uint8_t* buffer, uint16_t len)
|
||||||
|
{
|
||||||
|
IPAddress ucastaddr(htonl(addr));
|
||||||
|
println("sendBytesUniCast endPacket fail");
|
||||||
|
if(_udp.beginPacket(ucastaddr, port) == 1) {
|
||||||
|
_udp.write(buffer, len);
|
||||||
|
if(_udp.endPacket() == 0) println("sendBytesUniCast endPacket fail");
|
||||||
|
}
|
||||||
|
else println("sendBytesUniCast beginPacket fail");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
extern uint32_t __etext;
|
extern uint32_t __etext;
|
||||||
extern uint32_t __data_start__;
|
extern uint32_t __data_start__;
|
||||||
extern uint32_t __data_end__;
|
extern uint32_t __data_end__;
|
||||||
@ -51,6 +155,17 @@ static const uint32_t pageSizes[] = {8, 16, 32, 64, 128, 256, 512, 1024};
|
|||||||
|
|
||||||
void Samd51Platform::init()
|
void Samd51Platform::init()
|
||||||
{
|
{
|
||||||
|
// println("Entered Init .h variables active, rest and .cpp commented");
|
||||||
|
|
||||||
|
// #if USE_W5X00 == 1
|
||||||
|
// IPAddress _ip = Ethernet.localIP();
|
||||||
|
// _ipAddress = htonl(_ip);
|
||||||
|
// _ip = Ethernet.subnetMask();
|
||||||
|
// _netmask = htonl(_ip);
|
||||||
|
// _ip = Ethernet.gatewayIP();
|
||||||
|
// _defaultGateway = htonl(_ip);
|
||||||
|
// #endif
|
||||||
|
|
||||||
_memoryType = Flash;
|
_memoryType = Flash;
|
||||||
_pageSize = pageSizes[NVMCTRL->PARAM.bit.PSZ];
|
_pageSize = pageSizes[NVMCTRL->PARAM.bit.PSZ];
|
||||||
_pageCnt = NVMCTRL->PARAM.bit.NVMP;
|
_pageCnt = NVMCTRL->PARAM.bit.NVMP;
|
||||||
|
@ -1,5 +1,8 @@
|
|||||||
#include "Arduino.h"
|
#include <Arduino.h>
|
||||||
#include "arduino_platform.h"
|
#include "arduino_platform.h"
|
||||||
|
#include <SPI.h>
|
||||||
|
#include <Ethernet.h>
|
||||||
|
#include <EthernetUdp.h>
|
||||||
|
|
||||||
#ifdef __SAMD51__
|
#ifdef __SAMD51__
|
||||||
|
|
||||||
@ -14,6 +17,22 @@ public:
|
|||||||
|
|
||||||
void restart();
|
void restart();
|
||||||
|
|
||||||
|
#if USE_W5X00 == 1
|
||||||
|
// ip config
|
||||||
|
uint32_t currentIpAddress() override;
|
||||||
|
uint32_t currentSubnetMask() override;
|
||||||
|
uint32_t currentDefaultGateway() override;
|
||||||
|
void macAddress(uint8_t* data) override;
|
||||||
|
|
||||||
|
//multicast
|
||||||
|
void setupMultiCast(uint32_t addr, uint16_t port) override;
|
||||||
|
void closeMultiCast() override;
|
||||||
|
bool sendBytesMultiCast(uint8_t* buffer, uint16_t len) override;
|
||||||
|
int readBytesMultiCast(uint8_t* buffer, uint16_t maxLen) override;
|
||||||
|
|
||||||
|
bool sendBytesUniCast(uint32_t addr, uint16_t port, uint8_t* buffer, uint16_t len) override;
|
||||||
|
#endif
|
||||||
|
|
||||||
// size of one EraseBlock in pages
|
// size of one EraseBlock in pages
|
||||||
virtual size_t flashEraseBlockSize();
|
virtual size_t flashEraseBlockSize();
|
||||||
// size of one flash page in bytes
|
// size of one flash page in bytes
|
||||||
@ -42,6 +61,17 @@ private:
|
|||||||
void write(const volatile void* flash_ptr, const void* data, uint32_t size);
|
void write(const volatile void* flash_ptr, const void* data, uint32_t size);
|
||||||
void erase(const volatile void* flash_ptr, uint32_t size);
|
void erase(const volatile void* flash_ptr, uint32_t size);
|
||||||
void eraseRow(const volatile void* flash_ptr);
|
void eraseRow(const volatile void* flash_ptr);
|
||||||
|
|
||||||
|
#if USE_W5X00 == 1
|
||||||
|
uint8_t _macAddress[6] = {0xC0, 0xFF, 0xEE, 0xC0, 0xDE, 0x00};
|
||||||
|
uint32_t _ipAddress = 0;
|
||||||
|
uint32_t _netmask = 0;
|
||||||
|
uint32_t _defaultGateway = 0;
|
||||||
|
|
||||||
|
uint32_t _multicastAddr = -1;
|
||||||
|
uint16_t _multicastPort = -1;
|
||||||
|
EthernetUDP _udp;
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user