mirror of
https://github.com/esp8266/Arduino.git
synced 2025-04-19 23:22:16 +03:00
parent
22f063b913
commit
727c61efe2
@ -33,6 +33,7 @@ flush KEYWORD2
|
|||||||
stop KEYWORD2
|
stop KEYWORD2
|
||||||
connected KEYWORD2
|
connected KEYWORD2
|
||||||
begin KEYWORD2
|
begin KEYWORD2
|
||||||
|
beginMulticast KEYWORD2
|
||||||
disconnect KEYWORD2
|
disconnect KEYWORD2
|
||||||
macAddress KEYWORD2
|
macAddress KEYWORD2
|
||||||
localIP KEYWORD2
|
localIP KEYWORD2
|
||||||
@ -43,6 +44,7 @@ BSSID KEYWORD2
|
|||||||
RSSI KEYWORD2
|
RSSI KEYWORD2
|
||||||
encryptionType KEYWORD2
|
encryptionType KEYWORD2
|
||||||
beginPacket KEYWORD2
|
beginPacket KEYWORD2
|
||||||
|
beginPacketMulticast KEYWORD2
|
||||||
endPacket KEYWORD2
|
endPacket KEYWORD2
|
||||||
parsePacket KEYWORD2
|
parsePacket KEYWORD2
|
||||||
remoteIP KEYWORD2
|
remoteIP KEYWORD2
|
||||||
|
@ -142,22 +142,33 @@ int WiFiUDP::beginPacket(IPAddress ip, uint16_t port)
|
|||||||
return (_ctx->connect(addr, port)) ? 1 : 0;
|
return (_ctx->connect(addr, port)) ? 1 : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int WiFiUDP::beginPacketMulticast(IPAddress multicastAddress, uint16_t port,
|
||||||
|
IPAddress interfaceAddress, int ttl)
|
||||||
|
{
|
||||||
|
ip_addr_t mcastAddr;
|
||||||
|
mcastAddr.addr = multicastAddress;
|
||||||
|
ip_addr_t ifaceAddr;
|
||||||
|
ifaceAddr.addr = interfaceAddress;
|
||||||
|
|
||||||
|
if (!_ctx) {
|
||||||
|
_ctx = new UdpContext;
|
||||||
|
_ctx->ref();
|
||||||
|
}
|
||||||
|
if (!_ctx->connect(mcastAddr, port)) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
_ctx->setMulticastInterface(ifaceAddr);
|
||||||
|
_ctx->setMulticastTTL(ttl);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
int WiFiUDP::endPacket()
|
int WiFiUDP::endPacket()
|
||||||
{
|
{
|
||||||
if (!_ctx)
|
if (!_ctx)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
_ctx->send();
|
_ctx->send();
|
||||||
return 1;
|
_ctx->disconnect();
|
||||||
}
|
|
||||||
|
|
||||||
int WiFiUDP::endPacketMulticast(IPAddress ip, uint16_t port)
|
|
||||||
{
|
|
||||||
if (!_ctx)
|
|
||||||
return 0;
|
|
||||||
ip_addr_t addr;
|
|
||||||
addr.addr = (uint32_t) ip;
|
|
||||||
_ctx->send(&addr, port);
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -40,9 +40,13 @@ public:
|
|||||||
|
|
||||||
operator bool() const { return _ctx != 0; }
|
operator bool() const { return _ctx != 0; }
|
||||||
|
|
||||||
virtual uint8_t begin(uint16_t port); // initialize, start listening on specified port. Returns 1 if successful, 0 if there are no sockets available to use
|
// initialize, start listening on specified port.
|
||||||
virtual void stop(); // Finish with the UDP socket
|
// Returns 1 if successful, 0 if there are no sockets available to use
|
||||||
uint8_t beginMulticast(IPAddress interfaceAddr, IPAddress multicast, uint16_t port); // connect to a multicast group and listen on the given port
|
virtual uint8_t begin(uint16_t port);
|
||||||
|
// Finish with the UDP connetion
|
||||||
|
virtual void stop();
|
||||||
|
// join a multicast group and listen on the given port
|
||||||
|
uint8_t beginMulticast(IPAddress interfaceAddr, IPAddress multicast, uint16_t port);
|
||||||
|
|
||||||
// Sending UDP packets
|
// Sending UDP packets
|
||||||
|
|
||||||
@ -52,12 +56,19 @@ public:
|
|||||||
// Start building up a packet to send to the remote host specific in host and port
|
// Start building up a packet to send to the remote host specific in host and port
|
||||||
// Returns 1 if successful, 0 if there was a problem resolving the hostname or port
|
// Returns 1 if successful, 0 if there was a problem resolving the hostname or port
|
||||||
virtual int beginPacket(const char *host, uint16_t port);
|
virtual int beginPacket(const char *host, uint16_t port);
|
||||||
|
// Start building up a packet to send to the multicast address
|
||||||
|
// multicastAddress - muticast address to send to
|
||||||
|
// interfaceAddress - the local IP address of the interface that should be used
|
||||||
|
// use WiFi.localIP() or WiFi.softAPIP() depending on the interface you need
|
||||||
|
// ttl - multicast packet TTL (default is 1)
|
||||||
|
// Returns 1 if successful, 0 if there was a problem with the supplied IP address or port
|
||||||
|
virtual int beginPacketMulticast(IPAddress multicastAddress,
|
||||||
|
uint16_t port,
|
||||||
|
IPAddress interfaceAddress,
|
||||||
|
int ttl = 1);
|
||||||
// Finish off this packet and send it
|
// Finish off this packet and send it
|
||||||
// Returns 1 if the packet was sent successfully, 0 if there was an error
|
// Returns 1 if the packet was sent successfully, 0 if there was an error
|
||||||
virtual int endPacket();
|
virtual int endPacket();
|
||||||
// Send the packet to a multicast address
|
|
||||||
// Returns 1 if the packet was sent successfully, 0 if there was an error
|
|
||||||
int endPacketMulticast(IPAddress ip, uint16_t port);
|
|
||||||
// Write a single byte into the packet
|
// Write a single byte into the packet
|
||||||
virtual size_t write(uint8_t);
|
virtual size_t write(uint8_t);
|
||||||
// Write size bytes from buffer into the packet
|
// Write size bytes from buffer into the packet
|
||||||
|
@ -94,6 +94,21 @@ public:
|
|||||||
udp_disconnect(_pcb);
|
udp_disconnect(_pcb);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void setMulticastInterface(ip_addr_t addr)
|
||||||
|
{
|
||||||
|
// newer versions of lwip have a macro to set the multicast ip
|
||||||
|
// udp_set_multicast_netif_addr(_pcb, addr);
|
||||||
|
_pcb->multicast_ip = addr;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setMulticastTTL(int ttl)
|
||||||
|
{
|
||||||
|
// newer versions of lwip have an additional field (mcast_ttl) for this purpose
|
||||||
|
// and a macro to set it instead of direct field access
|
||||||
|
// udp_set_multicast_ttl(_pcb, ttl);
|
||||||
|
_pcb->ttl = ttl;
|
||||||
|
}
|
||||||
|
|
||||||
size_t getSize() const
|
size_t getSize() const
|
||||||
{
|
{
|
||||||
if (!_rx_buf)
|
if (!_rx_buf)
|
||||||
|
@ -62,6 +62,7 @@ MDNSResponder::~MDNSResponder() {
|
|||||||
|
|
||||||
bool MDNSResponder::begin(const char* domain, IPAddress addr, uint32_t ttlSeconds)
|
bool MDNSResponder::begin(const char* domain, IPAddress addr, uint32_t ttlSeconds)
|
||||||
{
|
{
|
||||||
|
_localAddr = addr;
|
||||||
// Construct DNS request/response fully qualified domain name of form:
|
// Construct DNS request/response fully qualified domain name of form:
|
||||||
// <domain length>, <domain characters>, 5, "local"
|
// <domain length>, <domain characters>, 5, "local"
|
||||||
size_t n = strlen(domain);
|
size_t n = strlen(domain);
|
||||||
@ -190,8 +191,9 @@ void MDNSResponder::update() {
|
|||||||
Serial.print("responding, i=");
|
Serial.print("responding, i=");
|
||||||
Serial.println(i);
|
Serial.println(i);
|
||||||
#endif
|
#endif
|
||||||
|
_mdnsConn.beginPacketMulticast(IPAddress(224, 0, 0, 251), 5353, _localAddr);
|
||||||
_mdnsConn.write(_response, _responseLen);
|
_mdnsConn.write(_response, _responseLen);
|
||||||
_mdnsConn.endPacketMulticast(IPAddress(224, 0, 0, 251), 5353);
|
_mdnsConn.endPacket();
|
||||||
_index = 0;
|
_index = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -64,6 +64,8 @@ private:
|
|||||||
int _responseLen;
|
int _responseLen;
|
||||||
// Socket for MDNS communication
|
// Socket for MDNS communication
|
||||||
WiFiUDP _mdnsConn;
|
WiFiUDP _mdnsConn;
|
||||||
|
// local IP Address
|
||||||
|
IPAddress _localAddr;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif //ESP8266MDNS_H
|
#endif //ESP8266MDNS_H
|
||||||
|
@ -53,7 +53,6 @@ void setup(void)
|
|||||||
// the fully-qualified domain name is "esp8266.local"
|
// the fully-qualified domain name is "esp8266.local"
|
||||||
// - second argument is the IP address to advertise
|
// - second argument is the IP address to advertise
|
||||||
// we send our IP address on the WiFi network
|
// we send our IP address on the WiFi network
|
||||||
// Note: for AP mode we would use WiFi.softAPIP()!
|
|
||||||
if (!mdns.begin("esp8266", WiFi.localIP())) {
|
if (!mdns.begin("esp8266", WiFi.localIP())) {
|
||||||
Serial.println("Error setting up MDNS responder!");
|
Serial.println("Error setting up MDNS responder!");
|
||||||
while(1) {
|
while(1) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user