#include "esp_platform.h" #include #include #include 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.restart(); } 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 = addr; _mulitcastPort = port; IPAddress mcastaddr(htonl(addr)); 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(); } void printHex(const char* suffix, uint8_t *data, uint8_t length) { Serial.print(suffix); for (int i = 0; i ",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(); }