Skip to content

Commit ee82a06

Browse files
committed
Merge branch 'feature/support_esptouch_v2_send_unicast' into 'master'
feat(sc): Support ESP-Touch-V2 to send unicast See merge request sdk/ESP8266_RTOS_SDK!1622
2 parents a683bd7 + d1b4451 commit ee82a06

File tree

1 file changed

+11
-6
lines changed

1 file changed

+11
-6
lines changed

components/esp8266/source/smartconfig_ack.c

+11-6
Original file line numberDiff line numberDiff line change
@@ -31,6 +31,7 @@
3131
#include "esp_wifi.h"
3232
#include "esp_smartconfig.h"
3333
#include "smartconfig_ack.h"
34+
#include "lwip/inet.h"
3435

3536
#define SC_ACK_TASK_PRIORITY 2 /*!< Priority of sending smartconfig ACK task */
3637
#define SC_ACK_TASK_STACK_SIZE 2048 /*!< Stack size of sending smartconfig ACK task */
@@ -40,7 +41,7 @@
4041
#define SC_ACK_TOUCH_V2_SERVER_PORT(i) (18266+i*10000) /*!< ESP touch_v2 UDP port of server on cellphone */
4142
#define SC_ACK_AIRKISS_SERVER_PORT 10000 /*!< Airkiss UDP port of server on cellphone */
4243
#define SC_ACK_AIRKISS_DEVICE_PORT 10001 /*!< Airkiss UDP port of server on device */
43-
#define SC_ACK_AIRKISS_TIMEOUT 1500 /*!< Airkiss read data timout millisecond */
44+
#define SC_ACK_TIMEOUT 1500 /*!< Airkiss and ESP touch_v2 read data timout millisecond */
4445

4546
#define SC_ACK_TOUCH_LEN 11 /*!< Length of ESP touch ACK context */
4647
#define SC_ACK_AIRKISS_LEN 7 /*!< Length of Airkiss ACK context */
@@ -133,21 +134,24 @@ static void sc_ack_send_task(void* pvParameters)
133134

134135
setsockopt(send_sock, SOL_SOCKET, SO_BROADCAST | SO_REUSEADDR, &optval, sizeof(int));
135136

136-
if (ack->type == SC_TYPE_AIRKISS) {
137+
if (ack->type == SC_TYPE_AIRKISS || ack->type == SC_TYPE_ESPTOUCH_V2) {
137138
char data = 0;
138139
struct sockaddr_in local_addr, from;
139140
socklen_t sockadd_len = sizeof(struct sockaddr);
140141
struct timeval timeout = {
141-
SC_ACK_AIRKISS_TIMEOUT / 1000,
142-
SC_ACK_AIRKISS_TIMEOUT % 1000 * 1000
142+
SC_ACK_TIMEOUT / 1000,
143+
SC_ACK_TIMEOUT % 1000 * 1000
143144
};
144145

145146
bzero(&local_addr, sizeof(struct sockaddr_in));
146147
bzero(&from, sizeof(struct sockaddr_in));
147148
local_addr.sin_family = AF_INET;
148149
local_addr.sin_addr.s_addr = INADDR_ANY;
149-
local_addr.sin_port = htons(SC_ACK_AIRKISS_DEVICE_PORT);
150-
150+
if (ack->type == SC_TYPE_AIRKISS) {
151+
local_addr.sin_port = htons(SC_ACK_AIRKISS_DEVICE_PORT);
152+
} else {
153+
local_addr.sin_port = htons(SC_ACK_TOUCH_DEVICE_PORT);
154+
}
151155
bind(send_sock, (struct sockaddr*)&local_addr, sockadd_len);
152156
setsockopt(send_sock, SOL_SOCKET, SO_RCVTIMEO, &timeout, sizeof(timeout));
153157

@@ -156,6 +160,7 @@ static void sc_ack_send_task(void* pvParameters)
156160
if (from.sin_addr.s_addr != INADDR_ANY) {
157161
memcpy(remote_ip, &from.sin_addr, 4);
158162
server_addr.sin_addr.s_addr = from.sin_addr.s_addr;
163+
ESP_LOGI(TAG, "cellphone_ip: %s", inet_ntoa(server_addr.sin_addr));
159164
} else {
160165
server_addr.sin_addr.s_addr = INADDR_BROADCAST;
161166
}

0 commit comments

Comments
 (0)