mirror of
				https://github.com/esp8266/Arduino.git
				synced 2025-10-25 18:38:07 +03:00 
			
		
		
		
	Merge remote-tracking branch 'upstream/master'
This commit is contained in:
		| @@ -11,7 +11,7 @@ ESP8266 Arduino core comes with libraries to communicate over WiFi using TCP and | ||||
|   - [Using git version](#using-git-version-) | ||||
|   - [Using stable version with PlatformIO](#using-stable-version-with-platformio) | ||||
| - [Documentation](#documentation) | ||||
| - [Issues and support](#issues-and-support)  | ||||
| - [Issues and support](#issues-and-support) | ||||
| - [Contributing](#contributing)   | ||||
| - [License and credits](#license-and-credits)    | ||||
|  | ||||
| @@ -25,7 +25,7 @@ Starting with 1.6.4, Arduino allows installation of third-party platform package | ||||
| - Open Boards Manager from Tools > Board menu and install *esp8266* platform (and don't forget to select your ESP8266 board from Tools > Board menu after installation). | ||||
|  | ||||
| The best place to ask questions related to this core is ESP8266 community forum: http://www.esp8266.com/arduino. | ||||
| If you find this ESP8266 board manager useful, please consider supporting it with a donation. The ESP8266 Community Forum and IGRR have made this wonderful port available. | ||||
| If you find this forum or the ESP8266 Boards Manager package useful, please consider supporting it with a donation. | ||||
| [](https://www.paypal.com/webscr?cmd=_s-xclick&hosted_button_id=4M56YCWV6PX66) | ||||
|  | ||||
| #### Available versions | ||||
| @@ -38,11 +38,11 @@ Documentation: [http://esp8266.github.io/Arduino/versions/2.0.0/](http://esp8266 | ||||
| ##### Staging version  | ||||
| Boards manager link: `http://arduino.esp8266.com/staging/package_esp8266com_index.json` | ||||
|  | ||||
| Documentation: [http://esp8266.github.io/Arduino/versions/2.0.0-rc2/](http://esp8266.github.io/Arduino/versions/2.0.0-rc2/) | ||||
| Documentation: [http://esp8266.github.io/Arduino/versions/2.1.0-rc1/](http://esp8266.github.io/Arduino/versions/2.1.0-rc1/) | ||||
|  | ||||
| ### Using git version [](https://travis-ci.org/esp8266/Arduino) | ||||
|  | ||||
| - Install Arduino 1.6.5 | ||||
| - Install Arduino 1.6.7 | ||||
| - Go to Arduino directory | ||||
| - Clone this repository into hardware/esp8266com/esp8266 directory (or clone it elsewhere and create a symlink) | ||||
| ```bash | ||||
|   | ||||
| @@ -101,7 +101,8 @@ void uart_disarm_tx_interrupt(uart_t* uart); | ||||
| void uart_set_baudrate(uart_t* uart, int baud_rate); | ||||
| int uart_get_baudrate(uart_t* uart); | ||||
|  | ||||
| uart_t* uart_init(int uart_nr, int baudrate, byte config); | ||||
| uart_t* uart_start_init(int uart_nr, int baudrate, byte config); | ||||
| void uart_finish_init(uart_t* uart); | ||||
| void uart_uninit(uart_t* uart); | ||||
| void uart_swap(uart_t* uart); | ||||
|  | ||||
| @@ -116,6 +117,13 @@ int uart_get_debug(); | ||||
| // #################################################################################################### | ||||
| // #################################################################################################### | ||||
|  | ||||
| // These function internals can be used from interrupt handlers to ensure they | ||||
| // are in instruction RAM, or anywhere that the uart_nr has been validated. | ||||
| #define UART_GET_TX_FIFO_ROOM(uart_nr)     (UART_TX_FIFO_SIZE - ((USS(uart_nr) >> USTXC) & 0xff)) | ||||
| #define UART_TRANSMIT_CHAR(uart_nr, c)     do { USF(uart_nr) = (c); } while(0) | ||||
| #define UART_ARM_TX_INTERRUPT(uart_nr)     do { USIE(uart_nr) |= (1 << UIFE); } while(0) | ||||
| #define UART_DISARM_TX_INTERRUPT(uart_nr)  do { USIE(uart_nr) &= ~(1 << UIFE); } while(0) | ||||
|  | ||||
| void ICACHE_RAM_ATTR uart_interrupt_handler(uart_t* uart) { | ||||
|  | ||||
|     // -------------- UART 0 -------------- | ||||
| @@ -133,13 +141,7 @@ void ICACHE_RAM_ATTR uart_interrupt_handler(uart_t* uart) { | ||||
|     } | ||||
|  | ||||
|     // -------------- UART 1 -------------- | ||||
|  | ||||
|     if(Serial1.isRxEnabled()) { | ||||
|         while(U1IS & (1 << UIFF)) { | ||||
|             Serial1._rx_complete_irq((char) (U1F & 0xff)); | ||||
|             U1IC = (1 << UIFF); | ||||
|         } | ||||
|     } | ||||
|     // Note: only TX is supported on UART 1. | ||||
|     if(Serial1.isTxEnabled()) { | ||||
|         if(U1IS & (1 << UIFE)) { | ||||
|             U1IC = (1 << UIFE); | ||||
| @@ -166,7 +168,7 @@ size_t uart_get_tx_fifo_room(uart_t* uart) { | ||||
|     if(uart == 0) | ||||
|         return 0; | ||||
|     if(uart->txEnabled) { | ||||
|         return UART_TX_FIFO_SIZE - ((USS(uart->uart_nr) >> USTXC) & 0xff); | ||||
|         return UART_GET_TX_FIFO_ROOM(uart->uart_nr); | ||||
|     } | ||||
|     return 0; | ||||
| } | ||||
| @@ -183,7 +185,7 @@ void uart_transmit_char(uart_t* uart, char c) { | ||||
|     if(uart == 0) | ||||
|         return; | ||||
|     if(uart->txEnabled) { | ||||
|         USF(uart->uart_nr) = c; | ||||
|         UART_TRANSMIT_CHAR(uart->uart_nr, c); | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -247,7 +249,7 @@ void uart_arm_tx_interrupt(uart_t* uart) { | ||||
|     if(uart == 0) | ||||
|         return; | ||||
|     if(uart->txEnabled) { | ||||
|         USIE(uart->uart_nr) |= (1 << UIFE); | ||||
|         UART_ARM_TX_INTERRUPT(uart->uart_nr); | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -255,7 +257,7 @@ void uart_disarm_tx_interrupt(uart_t* uart) { | ||||
|     if(uart == 0) | ||||
|         return; | ||||
|     if(uart->txEnabled) { | ||||
|         USIE(uart->uart_nr) &= ~(1 << UIFE); | ||||
|         UART_DISARM_TX_INTERRUPT(uart->uart_nr); | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -272,9 +274,8 @@ int uart_get_baudrate(uart_t* uart) { | ||||
|     return uart->baud_rate; | ||||
| } | ||||
|  | ||||
| uart_t* uart_init(int uart_nr, int baudrate, byte config, byte mode) { | ||||
| uart_t* uart_start_init(int uart_nr, int baudrate, byte config, byte mode) { | ||||
|  | ||||
|     uint32_t conf1 = 0x00000000; | ||||
|     uart_t* uart = (uart_t*) os_malloc(sizeof(uart_t)); | ||||
|  | ||||
|     if(uart == 0) { | ||||
| @@ -294,6 +295,7 @@ uart_t* uart_init(int uart_nr, int baudrate, byte config, byte mode) { | ||||
|             IOSWAP &= ~(1 << IOSWAPU0); | ||||
|             break; | ||||
|         case UART1: | ||||
|             // Note: uart_interrupt_handler does not support RX on UART 1. | ||||
|             uart->rxEnabled = false; | ||||
|             uart->txEnabled = (mode != SERIAL_RX_ONLY); | ||||
|             uart->rxPin = 255; | ||||
| @@ -309,6 +311,12 @@ uart_t* uart_init(int uart_nr, int baudrate, byte config, byte mode) { | ||||
|     uart_set_baudrate(uart, baudrate); | ||||
|     USC0(uart->uart_nr) = config; | ||||
|  | ||||
|     return uart; | ||||
| } | ||||
|  | ||||
| void uart_finish_init(uart_t* uart) { | ||||
|     uint32_t conf1 = 0x00000000; | ||||
|  | ||||
|     uart_flush(uart); | ||||
|     uart_interrupt_enable(uart); | ||||
|  | ||||
| @@ -321,8 +329,6 @@ uart_t* uart_init(int uart_nr, int baudrate, byte config, byte mode) { | ||||
|     } | ||||
|  | ||||
|     USC1(uart->uart_nr) = conf1; | ||||
|  | ||||
|     return uart; | ||||
| } | ||||
|  | ||||
| void uart_uninit(uart_t* uart) { | ||||
| @@ -479,35 +485,48 @@ int uart_get_debug() { | ||||
| // #################################################################################################### | ||||
|  | ||||
| HardwareSerial::HardwareSerial(int uart_nr) : | ||||
|         _uart_nr(uart_nr), _uart(0), _tx_buffer(0), _rx_buffer(0), _written(false) { | ||||
|         _uart_nr(uart_nr), _uart(0), _tx_buffer(0), _rx_buffer(0) { | ||||
| } | ||||
|  | ||||
| void HardwareSerial::begin(unsigned long baud, byte config, byte mode) { | ||||
|     InterruptLock il; | ||||
|  | ||||
|     // disable debug for this interface | ||||
|     if(uart_get_debug() == _uart_nr) { | ||||
|         uart_set_debug(UART_NO); | ||||
|     } | ||||
|  | ||||
|     _uart = uart_init(_uart_nr, baud, config, mode); | ||||
|     if (_uart) { | ||||
|         os_free(_uart); | ||||
|     } | ||||
|     _uart = uart_start_init(_uart_nr, baud, config, mode); | ||||
|  | ||||
|     if(_uart == 0) { | ||||
|         return; | ||||
|     } | ||||
|  | ||||
|     if(_uart->rxEnabled) { | ||||
|         if(!_rx_buffer) | ||||
|             _rx_buffer = new cbuf(SERIAL_RX_BUFFER_SIZE); | ||||
|     // Disable the RX and/or TX functions if we fail to allocate circular buffers. | ||||
|     // The user can confirm they are enabled with isRxEnabled() and isTxEnabled(). | ||||
|     if(_uart->rxEnabled && !_rx_buffer) { | ||||
|         _rx_buffer = new cbuf(SERIAL_RX_BUFFER_SIZE); | ||||
|         if(!_rx_buffer) { | ||||
|             _uart->rxEnabled = false; | ||||
|         } | ||||
|     } | ||||
|     if(_uart->txEnabled) { | ||||
|         if(!_tx_buffer) | ||||
|             _tx_buffer = new cbuf(SERIAL_TX_BUFFER_SIZE); | ||||
|     if(_uart->txEnabled && !_tx_buffer) { | ||||
|         _tx_buffer = new cbuf(SERIAL_TX_BUFFER_SIZE); | ||||
|         if(!_tx_buffer) { | ||||
|             _uart->txEnabled = false; | ||||
|         } | ||||
|     } | ||||
|     _written = false; | ||||
|     delay(1); | ||||
|  | ||||
|     uart_finish_init(_uart); | ||||
| } | ||||
|  | ||||
| void HardwareSerial::end() { | ||||
|     InterruptLock il; | ||||
|  | ||||
|     if(uart_get_debug() == _uart_nr) { | ||||
|         uart_set_debug(UART_NO); | ||||
|     } | ||||
| @@ -541,13 +560,13 @@ void HardwareSerial::setDebugOutput(bool en) { | ||||
|     } | ||||
| } | ||||
|  | ||||
| bool HardwareSerial::isTxEnabled(void) { | ||||
| bool ICACHE_RAM_ATTR HardwareSerial::isTxEnabled(void) { | ||||
|     if(_uart == 0) | ||||
|         return false; | ||||
|     return _uart->txEnabled; | ||||
| } | ||||
|  | ||||
| bool HardwareSerial::isRxEnabled(void) { | ||||
| bool ICACHE_RAM_ATTR HardwareSerial::isRxEnabled(void) { | ||||
|     if(_uart == 0) | ||||
|         return false; | ||||
|     return _uart->rxEnabled; | ||||
| @@ -606,44 +625,52 @@ void HardwareSerial::flush() { | ||||
|         return; | ||||
|     if(!_uart->txEnabled) | ||||
|         return; | ||||
|     if(!_written) | ||||
|         return; | ||||
|  | ||||
|     const int uart_nr = _uart->uart_nr; | ||||
|     while(true) { | ||||
|         { | ||||
|             InterruptLock il; | ||||
|             if(_tx_buffer->getSize() == 0 && | ||||
|                uart_get_tx_fifo_room(_uart) >= UART_TX_FIFO_SIZE) { | ||||
|                UART_GET_TX_FIFO_ROOM(uart_nr) >= UART_TX_FIFO_SIZE) { | ||||
|                 break; | ||||
|             } else if(il.savedInterruptLevel() > 0) { | ||||
|                 _tx_empty_irq(); | ||||
|                 continue; | ||||
|             } | ||||
|         } | ||||
|         yield(); | ||||
|     } | ||||
|     _written = false; | ||||
| } | ||||
|  | ||||
| size_t HardwareSerial::write(uint8_t c) { | ||||
|     if(_uart == 0 || !_uart->txEnabled) | ||||
|         return 0; | ||||
|     _written = true; | ||||
|  | ||||
|     bool tx_now = false; | ||||
|     const int uart_nr = _uart->uart_nr; | ||||
|     while(true) { | ||||
|         { | ||||
|             InterruptLock il; | ||||
|             if(_tx_buffer->empty()) { | ||||
|                 if(uart_get_tx_fifo_room(_uart) > 0) { | ||||
|                     uart_transmit_char(_uart, c); | ||||
|                 if(UART_GET_TX_FIFO_ROOM(uart_nr) > 0) { | ||||
|                     tx_now = true; | ||||
|                 } else { | ||||
|                     _tx_buffer->write(c); | ||||
|                     uart_arm_tx_interrupt(_uart); | ||||
|                     UART_ARM_TX_INTERRUPT(uart_nr); | ||||
|                 } | ||||
|                 break; | ||||
|             } else if(_tx_buffer->write(c)) { | ||||
|                 break; | ||||
|             } else if(il.savedInterruptLevel() > 0) { | ||||
|                 _tx_empty_irq(); | ||||
|                 continue; | ||||
|             } | ||||
|         } | ||||
|         yield(); | ||||
|     } | ||||
|     if (tx_now) { | ||||
|         UART_TRANSMIT_CHAR(uart_nr, c); | ||||
|     } | ||||
|     return 1; | ||||
| } | ||||
|  | ||||
| @@ -651,26 +678,21 @@ HardwareSerial::operator bool() const { | ||||
|     return _uart != 0; | ||||
| } | ||||
|  | ||||
| void HardwareSerial::_rx_complete_irq(char c) { | ||||
|     if(_rx_buffer) { | ||||
|         _rx_buffer->write(c); | ||||
|     } | ||||
| void ICACHE_RAM_ATTR HardwareSerial::_rx_complete_irq(char c) { | ||||
|     _rx_buffer->write(c); | ||||
| } | ||||
|  | ||||
| void HardwareSerial::_tx_empty_irq(void) { | ||||
|     if(_uart == 0) | ||||
|         return; | ||||
|     if(_tx_buffer == 0) | ||||
|         return; | ||||
| void ICACHE_RAM_ATTR HardwareSerial::_tx_empty_irq(void) { | ||||
|     const int uart_nr = _uart->uart_nr; | ||||
|     size_t queued = _tx_buffer->getSize(); | ||||
|     if(!queued) { | ||||
|         uart_disarm_tx_interrupt(_uart); | ||||
|         UART_DISARM_TX_INTERRUPT(uart_nr); | ||||
|         return; | ||||
|     } | ||||
|  | ||||
|     size_t room = uart_get_tx_fifo_room(_uart); | ||||
|     size_t room = UART_GET_TX_FIFO_ROOM(uart_nr); | ||||
|     int n = static_cast<int>((queued < room) ? queued : room); | ||||
|     while(n--) { | ||||
|         uart_transmit_char(_uart, _tx_buffer->read()); | ||||
|         UART_TRANSMIT_CHAR(uart_nr, _tx_buffer->read()); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -117,7 +117,6 @@ class HardwareSerial: public Stream { | ||||
|         uart_t* _uart; | ||||
|         cbuf* _tx_buffer; | ||||
|         cbuf* _rx_buffer; | ||||
|         bool _written; | ||||
| }; | ||||
|  | ||||
| extern HardwareSerial Serial; | ||||
|   | ||||
							
								
								
									
										45
									
								
								cores/esp8266/cbuf.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								cores/esp8266/cbuf.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,45 @@ | ||||
| /*  | ||||
|  cbuf.cpp - Circular buffer implementation | ||||
|  Copyright (c) 2014 Ivan Grokhotkov. All rights reserved. | ||||
|  This file is part of the esp8266 core for Arduino environment. | ||||
|   | ||||
|  This library is free software; you can redistribute it and/or | ||||
|  modify it under the terms of the GNU Lesser General Public | ||||
|  License as published by the Free Software Foundation; either | ||||
|  version 2.1 of the License, or (at your option) any later version. | ||||
|  | ||||
|  This library is distributed in the hope that it will be useful, | ||||
|  but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | ||||
|  Lesser General Public License for more details. | ||||
|  | ||||
|  You should have received a copy of the GNU Lesser General Public | ||||
|  License along with this library; if not, write to the Free Software | ||||
|  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA | ||||
|  */ | ||||
|  | ||||
| #include "cbuf.h" | ||||
| #include "c_types.h" | ||||
|  | ||||
| size_t ICACHE_RAM_ATTR cbuf::getSize() const { | ||||
|     if(_end >= _begin) { | ||||
|         return _end - _begin; | ||||
|     } | ||||
|     return _size - (_begin - _end); | ||||
| } | ||||
|  | ||||
| int ICACHE_RAM_ATTR cbuf::read() { | ||||
|     if(empty()) return -1; | ||||
|  | ||||
|     char result = *_begin; | ||||
|     _begin = wrap_if_bufend(_begin + 1); | ||||
|     return static_cast<int>(result); | ||||
| } | ||||
|  | ||||
| size_t ICACHE_RAM_ATTR cbuf::write(char c) { | ||||
|      if(full()) return 0; | ||||
|  | ||||
|      *_end = c; | ||||
|      _end = wrap_if_bufend(_end + 1); | ||||
|      return 1; | ||||
| } | ||||
| @@ -21,7 +21,10 @@ | ||||
| #ifndef __cbuf_h | ||||
| #define __cbuf_h | ||||
|  | ||||
| #include <stddef.h> | ||||
| #include <stdint.h> | ||||
| #include <string.h> | ||||
|  | ||||
| class cbuf { | ||||
|     public: | ||||
|         cbuf(size_t size) : | ||||
| @@ -32,11 +35,7 @@ class cbuf { | ||||
|             delete[] _buf; | ||||
|         } | ||||
|  | ||||
|         size_t getSize() const { | ||||
|             if(_end >= _begin) return _end - _begin; | ||||
|  | ||||
|             return _size - (_begin - _end); | ||||
|         } | ||||
|         size_t getSize() const; | ||||
|  | ||||
|         size_t room() const { | ||||
|             if(_end >= _begin) { | ||||
| @@ -45,23 +44,21 @@ class cbuf { | ||||
|             return _begin - _end - 1; | ||||
|         } | ||||
|  | ||||
|         bool empty() const { | ||||
|         inline bool empty() const { | ||||
|             return _begin == _end; | ||||
|         } | ||||
|  | ||||
|         inline bool full() const { | ||||
|             return wrap_if_bufend(_end + 1) == _begin; | ||||
|         } | ||||
|  | ||||
|         int peek() { | ||||
|             if(_end == _begin) return -1; | ||||
|             if(empty()) return -1; | ||||
|  | ||||
|             return static_cast<int>(*_begin); | ||||
|         } | ||||
|  | ||||
|         int read() { | ||||
|             if(getSize() == 0) return -1; | ||||
|  | ||||
|             char result = *_begin; | ||||
|             _begin = wrap_if_bufend(_begin + 1); | ||||
|             return static_cast<int>(result); | ||||
|         } | ||||
|         int read(); | ||||
|  | ||||
|         size_t read(char* dst, size_t size) { | ||||
|             size_t bytes_available = getSize(); | ||||
| @@ -79,13 +76,7 @@ class cbuf { | ||||
|             return size_read; | ||||
|         } | ||||
|  | ||||
|         size_t write(char c) { | ||||
|             if(room() == 0) return 0; | ||||
|  | ||||
|             *_end = c; | ||||
|             _end = wrap_if_bufend(_end + 1); | ||||
|             return 1; | ||||
|         } | ||||
|         size_t write(char c); | ||||
|  | ||||
|         size_t write(const char* src, size_t size) { | ||||
|             size_t bytes_available = room(); | ||||
| @@ -109,7 +100,7 @@ class cbuf { | ||||
|         } | ||||
|  | ||||
|     private: | ||||
|         inline char* wrap_if_bufend(char* ptr) { | ||||
|         inline char* wrap_if_bufend(char* ptr) const { | ||||
|             return (ptr == _bufend) ? _buf : ptr; | ||||
|         } | ||||
|  | ||||
|   | ||||
| @@ -31,6 +31,10 @@ public: | ||||
|         xt_wsr_ps(_state); | ||||
|     } | ||||
|  | ||||
|     uint32_t savedInterruptLevel() const { | ||||
|         return _state & 0x0f; | ||||
|     } | ||||
|  | ||||
| protected: | ||||
|     uint32_t _state; | ||||
| }; | ||||
|   | ||||
| @@ -6,10 +6,44 @@ title: Change Log | ||||
|  | ||||
| ### Core | ||||
|  | ||||
| - Allow control of enabling debug and debug level from IDE | ||||
| - Make HardwareSerial::begin() and end() interrupt safe | ||||
| - Put HardwareSerial and cbuf methods called from interrupt context in RAM | ||||
| - Re-enable interrupts before directly enqueuing characters in the UART FIFO | ||||
| - Add espduino board | ||||
| - Rework StreamString::write to use String internal buffer directly (#1289) | ||||
| - Add function to measure stack high water mark | ||||
| - Update SDK to esp_iot_sdk_v1.5.0_15_12_15_p1 | ||||
| - Fix RAM corruption caused by our hook of register_chipv6_phy(init_data*). | ||||
| - Optimize PWM interrupt handler for better precision | ||||
| - Add warning levels configurable through Preferences | ||||
| - Protect HardwareSerial's cbuf usage with InterruptLock | ||||
| - SPIFFS: check if path length is valid (#1089) | ||||
| - Set CPU frequency before running setup | ||||
| - Add core_esp8266_features.h to be able to detect the features and libraries included in the ESP core | ||||
| - Added ESPino to supported boards | ||||
|  | ||||
| ### Libraries | ||||
|  | ||||
| - ESP8266HTTPClient: add CHUNKED encoding support (#1324) | ||||
| - Fixed crash bug with mDNS where a string buffer could be used uninitialized | ||||
| - Add WiFi TX power control | ||||
| - Add WiFi sleep management | ||||
| - Allow to hook into WiFi events from sketch | ||||
| - Allow setting TCP timeout | ||||
| - Add setSleepMode + getSleepMode and setPhyMode + getPhyMode to WiFi | ||||
| - Update GDBStub library with the source of esp-gdbstub | ||||
| - Servo: fix detach and attach | ||||
| - ESP8266mDNS: refactoring, add TXT support | ||||
| - Add HTTP Basic Auth to WebServer and libb64 (base64) to core | ||||
| - Fix link-time dependency of ESP8266WebServer on SPIFFS (#862) | ||||
| - Allow setting client side TLS key and certificate | ||||
| - Replace chain of UDP pbufs with a single pbuf before sending (#1009) | ||||
|  | ||||
| ### Tools | ||||
|  | ||||
| - espota.py: add support for manually selecting ip and port for host side | ||||
|  | ||||
| --- | ||||
| ## 2.0.0 | ||||
| November 30, 2015 | ||||
|   | ||||
| @@ -127,7 +127,7 @@ wl_status_t ESP8266WiFiMulti::run(void) { | ||||
|                         ip = WiFi.localIP(); | ||||
|                         mac = WiFi.BSSID(); | ||||
|                         DEBUG_WIFI_MULTI("[WIFI] Connecting done.\n"); | ||||
|                         DEBUG_WIFI_MULTI("[WIFI] SSID: %s\n", WiFi.SSID()); | ||||
|                         DEBUG_WIFI_MULTI("[WIFI] SSID: %s\n", WiFi.SSID().c_str()); | ||||
|                         DEBUG_WIFI_MULTI("[WIFI] IP: %d.%d.%d.%d\n", ip[0], ip[1], ip[2], ip[3]); | ||||
|                         DEBUG_WIFI_MULTI("[WIFI] MAC: %02X:%02X:%02X:%02X:%02X:%02X\n", mac[0], mac[1], mac[2], mac[3], mac[4], mac[5]); | ||||
|                         DEBUG_WIFI_MULTI("[WIFI] Channel: %d\n", WiFi.channel()); | ||||
|   | ||||
| @@ -38,7 +38,6 @@ extern "C" | ||||
| #include "lwip/tcp.h" | ||||
| #include "lwip/inet.h" | ||||
| #include "lwip/netif.h" | ||||
| #include "cbuf.h" | ||||
| #include "include/ClientContext.h" | ||||
| #include "c_types.h" | ||||
|  | ||||
|   | ||||
| @@ -37,7 +37,6 @@ extern "C" | ||||
| #include "lwip/tcp.h" | ||||
| #include "lwip/inet.h" | ||||
| #include "lwip/netif.h" | ||||
| #include "cbuf.h" | ||||
| #include "include/ClientContext.h" | ||||
| #include "c_types.h" | ||||
|  | ||||
|   | ||||
| @@ -35,7 +35,6 @@ extern "C" { | ||||
| #include "lwip/opt.h" | ||||
| #include "lwip/tcp.h" | ||||
| #include "lwip/inet.h" | ||||
| #include "cbuf.h" | ||||
| #include "include/ClientContext.h" | ||||
|  | ||||
| WiFiServer::WiFiServer(IPAddress addr, uint16_t port) | ||||
|   | ||||
| @@ -39,7 +39,7 @@ cat << EOF > exclude.txt | ||||
| package | ||||
| EOF | ||||
| # Also include all files which are ignored by git | ||||
| git ls-files --other --ignored --exclude-standard --directory >> exclude.txt | ||||
| git ls-files --other --directory >> exclude.txt | ||||
| # Now copy files to $outdir | ||||
| rsync -a --exclude-from 'exclude.txt' $srcdir/ $outdir/ | ||||
| rm exclude.txt | ||||
|   | ||||
| @@ -24,8 +24,9 @@ set -e | ||||
|  | ||||
| # some variable definitions | ||||
| tmp_path=$1 | ||||
| arduinoESP_src="$tmp_path/arduino" | ||||
| version="$(git --work-tree=$arduinoESP_src describe --tags --always)" | ||||
| doc_src_path=$2 | ||||
| arduinoESP_src=$(cd $PWD/..; pwd) | ||||
| version="$(git --work-tree=$arduinoESP_src --git-dir=$arduinoESP_src/.git describe --tags --always)" | ||||
| release_date=$(date "+%b_%d,_%Y") # format for badge link | ||||
| build_date=$(date "+%b %d, %Y") | ||||
| destination_path="$tmp_path/doc" | ||||
| @@ -62,7 +63,8 @@ mkdir -p $destination_path/$version | ||||
| cp -R $arduinoESP_src/doc/* $destination_path/src | ||||
|  | ||||
| # download doc template | ||||
| git clone $doc_template_url $destination_path/build | ||||
| rsync -av $doc_src_path/ $destination_path/build/ | ||||
| # git clone $doc_template_url $destination_path/build | ||||
|  | ||||
| # create versions.html file | ||||
|  | ||||
| @@ -113,4 +115,3 @@ popd | ||||
|  | ||||
| # grab badge | ||||
| wget -q -O $destination_path/$version/badge.svg "https://img.shields.io/badge/updated-$release_date-blue.svg" | ||||
|  | ||||
|   | ||||
| @@ -5,11 +5,12 @@ | ||||
| # | ||||
| # Modified since 2015-09-18 from Pascal Gollor (https://github.com/pgollor) | ||||
| # Modified since 2015-11-09 from Hristo Gochkov (https://github.com/me-no-dev) | ||||
| # Modified since 2016-01-03 from Matthew O'Gorman (https://githumb.com/mogorman) | ||||
| # | ||||
| # This script will push an OTA update to the ESP | ||||
| # use it like: python espota.py -i <ESP_IP_address> -p <ESP_port> [-a password] -f <sketch.bin> | ||||
| # use it like: python espota.py -i <ESP_IP_address> -I <Host_IP_address> -p <ESP_port> -P <Host_port> [-a password] -f <sketch.bin> | ||||
| # Or to upload SPIFFS image: | ||||
| # python espota.py -i <ESP_IP_address> -p <ESP_port> [-a password] -s -f <spiffs.bin> | ||||
| # python espota.py -i <ESP_IP_address> -I <Host_IP_address> -p <ESP_port> -P <HOST_port> [-a password] -s -f <spiffs.bin> | ||||
| # | ||||
| # Changes | ||||
| # 2015-09-18: | ||||
| @@ -22,6 +23,10 @@ | ||||
| # - Added digest authentication | ||||
| # - Enchanced error tracking and reporting | ||||
| # | ||||
| # Changes | ||||
| # 2016-01-03: | ||||
| # - Added more options to parser. | ||||
| # | ||||
|  | ||||
| from __future__ import print_function | ||||
| import socket | ||||
| @@ -64,11 +69,10 @@ def update_progress(progress): | ||||
|     sys.stderr.write('.') | ||||
|     sys.stderr.flush() | ||||
|  | ||||
| def serve(remoteAddr, remotePort, password, filename, command = FLASH): | ||||
| def serve(remoteAddr, localAddr, remotePort, localPort, password, filename, command = FLASH): | ||||
|   # Create a TCP/IP socket | ||||
|   sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) | ||||
|   serverPort = random.randint(10000,60000) | ||||
|   server_address = ('0.0.0.0', serverPort) | ||||
|   server_address = (localAddr, localPort) | ||||
|   logging.info('Starting on %s:%s', str(server_address[0]), str(server_address[1])) | ||||
|   try: | ||||
|     sock.bind(server_address) | ||||
| @@ -82,7 +86,7 @@ def serve(remoteAddr, remotePort, password, filename, command = FLASH): | ||||
|   file_md5 = hashlib.md5(f.read()).hexdigest() | ||||
|   f.close() | ||||
|   logging.info('Upload size: %d', content_size) | ||||
|   message = '%d %d %d %s\n' % (command, serverPort, content_size, file_md5) | ||||
|   message = '%d %d %d %s\n' % (command, localPort, content_size, file_md5) | ||||
|  | ||||
|   # Wait for a connection | ||||
|   logging.info('Sending invitation to: %s', remoteAddr) | ||||
| @@ -209,12 +213,24 @@ def parser(): | ||||
|     help = "ESP8266 IP Address.", | ||||
|     default = False | ||||
|   ) | ||||
|   group.add_option("-I", "--host_ip", | ||||
|     dest = "host_ip", | ||||
|     action = "store", | ||||
|     help = "Host IP Address.", | ||||
|     default = "0.0.0.0" | ||||
|   ) | ||||
|   group.add_option("-p", "--port", | ||||
|     dest = "esp_port", | ||||
|     type = "int", | ||||
|     help = "ESP8266 ota Port. Default 8266", | ||||
|     default = 8266 | ||||
|   ) | ||||
|   group.add_option("-P", "--host_port", | ||||
|     dest = "host_port", | ||||
|     type = "int", | ||||
|     help = "Host server ota Port. Default random 10000-60000", | ||||
|     default = random.randint(10000,60000) | ||||
|   ) | ||||
|   parser.add_option_group(group) | ||||
|  | ||||
|   # auth | ||||
| @@ -294,7 +310,7 @@ def main(args): | ||||
|     command = SPIFFS | ||||
|   # end if | ||||
|  | ||||
|   return serve(options.esp_ip, options.esp_port, options.auth, options.image, command) | ||||
|   return serve(options.esp_ip, options.host_ip, options.esp_port, options.host_port, options.auth, options.image, command) | ||||
| # end main | ||||
|  | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user