mirror of
				https://github.com/esp8266/Arduino.git
				synced 2025-10-24 07:13:45 +03:00 
			
		
		
		
	* fix #1002 ::Flush() wait for empty send buffer * WiFiClient::Flush() guarantees that the data has been delivered option 1 of https://github.com/esp8266/Arduino/pull/3967#discussion_r156901071 10ms max wait according to loaded tcp echo/reply scheme
This commit is contained in:
		| @@ -259,7 +259,7 @@ size_t WiFiClient::peekBytes(uint8_t *buffer, size_t length) { | |||||||
| void WiFiClient::flush() | void WiFiClient::flush() | ||||||
| { | { | ||||||
|     if (_client) |     if (_client) | ||||||
|         _client->flush(); |         _client->wait_until_sent(); | ||||||
| } | } | ||||||
|  |  | ||||||
| void WiFiClient::stop() | void WiFiClient::stop() | ||||||
|   | |||||||
| @@ -243,8 +243,7 @@ int WiFiUDP::peek() | |||||||
|  |  | ||||||
| void WiFiUDP::flush() | void WiFiUDP::flush() | ||||||
| { | { | ||||||
|     if (_ctx) |     endPacket(); | ||||||
|         _ctx->flush(); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| IPAddress WiFiUDP::remoteIP() | IPAddress WiFiUDP::remoteIP() | ||||||
|   | |||||||
| @@ -107,7 +107,7 @@ public: | |||||||
|         if(this != 0) { |         if(this != 0) { | ||||||
|             DEBUGV(":ur %d\r\n", _refcnt); |             DEBUGV(":ur %d\r\n", _refcnt); | ||||||
|             if(--_refcnt == 0) { |             if(--_refcnt == 0) { | ||||||
|                 flush(); |                 discard_received(); | ||||||
|                 close(); |                 close(); | ||||||
|                 if(_discard_cb) { |                 if(_discard_cb) { | ||||||
|                     _discard_cb(_discard_cb_arg, this); |                     _discard_cb(_discard_cb_arg, this); | ||||||
| @@ -277,7 +277,7 @@ public: | |||||||
|         return copy_size; |         return copy_size; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     void flush() |     void discard_received() | ||||||
|     { |     { | ||||||
|         if(!_rx_buf) { |         if(!_rx_buf) { | ||||||
|             return; |             return; | ||||||
| @@ -290,6 +290,22 @@ public: | |||||||
|         _rx_buf_offset = 0; |         _rx_buf_offset = 0; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     void wait_until_sent() | ||||||
|  |     { | ||||||
|  |         // fix option 1 in | ||||||
|  |         // https://github.com/esp8266/Arduino/pull/3967#pullrequestreview-83451496 | ||||||
|  |         // TODO: option 2 | ||||||
|  |  | ||||||
|  |         #define WAIT_TRIES_MS 10	// at most 10ms | ||||||
|  |  | ||||||
|  |         int tries = 1+ WAIT_TRIES_MS; | ||||||
|  |  | ||||||
|  |         while (state() == ESTABLISHED && tcp_sndbuf(_pcb) != TCP_SND_BUF && --tries) { | ||||||
|  |             _write_some(); | ||||||
|  |             delay(1); // esp_ schedule+yield | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     uint8_t state() const |     uint8_t state() const | ||||||
|     { |     { | ||||||
|         if(!_pcb) { |         if(!_pcb) { | ||||||
|   | |||||||
| @@ -118,7 +118,7 @@ size_t EthernetUDP::write(const uint8_t *buffer, size_t size) | |||||||
| int EthernetUDP::parsePacket() | int EthernetUDP::parsePacket() | ||||||
| { | { | ||||||
|   // discard any remaining bytes in the last packet |   // discard any remaining bytes in the last packet | ||||||
|   flush(); |   clear_remaining(); | ||||||
|  |  | ||||||
|   if (recvAvailable(_sock) > 0) |   if (recvAvailable(_sock) > 0) | ||||||
|   { |   { | ||||||
| @@ -204,7 +204,7 @@ int EthernetUDP::peek() | |||||||
|   return b; |   return b; | ||||||
| } | } | ||||||
|  |  | ||||||
| void EthernetUDP::flush() | void EthernetUDP::clear_remaining() | ||||||
| { | { | ||||||
|   // could this fail (loop endlessly) if _remaining > 0 and recv in read fails? |   // could this fail (loop endlessly) if _remaining > 0 and recv in read fails? | ||||||
|   // should only occur if recv fails after telling us the data is there, lets |   // should only occur if recv fails after telling us the data is there, lets | ||||||
| @@ -216,3 +216,8 @@ void EthernetUDP::flush() | |||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | void EthernetUDP::flush() | ||||||
|  | { | ||||||
|  |   endPacket();   | ||||||
|  | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -49,6 +49,9 @@ private: | |||||||
|   uint16_t _remotePort; // remote port for the incoming packet whilst it's being processed |   uint16_t _remotePort; // remote port for the incoming packet whilst it's being processed | ||||||
|   uint16_t _offset; // offset into the packet being sent |   uint16_t _offset; // offset into the packet being sent | ||||||
|   uint16_t _remaining; // remaining bytes of incoming packet yet to be processed |   uint16_t _remaining; // remaining bytes of incoming packet yet to be processed | ||||||
|  |    | ||||||
|  | protected: | ||||||
|  |   void clear_remaining(); | ||||||
|  |  | ||||||
| public: | public: | ||||||
|   EthernetUDP();  // Constructor |   EthernetUDP();  // Constructor | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user