#include "esp_platform.h" #ifdef ARDUINO_ARCH_ESP8266 #include #include #include #include "knx/bits.h" EspPlatform::EspPlatform() { } uint32_t EspPlatform::currentIpAddress() { return WiFi.localIP(); } uint32_t EspPlatform::currentSubnetMask() { return WiFi.subnetMask(); } uint32_t EspPlatform::currentDefaultGateway() { return WiFi.gatewayIP(); } void EspPlatform::macAddress(uint8_t * addr) { wifi_get_macaddr(STATION_IF, addr); } uint32_t EspPlatform::millis() { return ::millis(); } void EspPlatform::mdelay(uint32_t millis) { delay(millis); } void EspPlatform::restart() { Serial.println("restart"); ESP.reset(); } void EspPlatform::fatalError() { const int period = 200; while (true) { if ((millis() % period) > (period / 2)) digitalWrite(LED_BUILTIN, HIGH); else digitalWrite(LED_BUILTIN, LOW); } } void EspPlatform::setupMultiCast(uint32_t addr, uint16_t port) { _mulitcastAddr = htonl(addr); _mulitcastPort = port; IPAddress mcastaddr(_mulitcastAddr); Serial.printf("setup multicast addr: %s port: %d ip: %s\n", mcastaddr.toString().c_str(), port, WiFi.localIP().toString().c_str()); uint8 result = _udp.beginMulticast(WiFi.localIP(), mcastaddr, port); Serial.printf("result %d\n", result); } void EspPlatform::closeMultiCast() { _udp.stop(); } bool EspPlatform::sendBytes(uint8_t * buffer, uint16_t len) { //printHex("<- ",buffer, len); int result = 0; result = _udp.beginPacketMulticast(_mulitcastAddr, _mulitcastPort, WiFi.localIP()); result = _udp.write(buffer, len); result = _udp.endPacket(); return true; } int EspPlatform::readBytes(uint8_t * buffer, uint16_t maxLen) { int len = _udp.parsePacket(); if (len == 0) return 0; if (len > maxLen) { Serial.printf("udp buffer to small. was %d, needed %d\n", maxLen, len); fatalError(); } _udp.read(buffer, len); //printHex("-> ", buffer, len); return len; } uint8_t * EspPlatform::getEepromBuffer(uint16_t size) { EEPROM.begin(size); return EEPROM.getDataPtr(); } void EspPlatform::commitToEeprom() { EEPROM.commit(); } void EspPlatform::setupUart() { Serial.begin(19200, SERIAL_8E1); while (!Serial) ; } void EspPlatform::closeUart() { Serial.end(); } int EspPlatform::uartAvailable() { return Serial.available(); } size_t EspPlatform::writeUart(const uint8_t data) { printHex(" 0) printHex("p>", (uint8_t*)&val, 1); return val; } size_t EspPlatform::readBytesUart(uint8_t *buffer, size_t length) { size_t toRead = length; uint8_t* pos = buffer; while (toRead > 0) { size_t val = Serial.readBytes(pos, toRead); pos += val; toRead -= val; } printHex("p>", buffer, length); return length; } #endif