esp8266~lwip突破MTU最大1500限制

{

switch (event->event_id) {

case SYSTEM_EVENT_STA_START:

esp_wifi_connect();

ESP_LOGI(TAG, “SYSTEM_EVENT_STA_START”);

break;

case SYSTEM_EVENT_STA_CONNECTED:

break;

case SYSTEM_EVENT_STA_GOT_IP:

xEventGroupSetBits(wifi_event_group, IPV4_GOTIP_BIT);

ESP_LOGI(TAG, “SYSTEM_EVENT_STA_GOT_IP”);

break;

case SYSTEM_EVENT_STA_DISCONNECTED:

/* This is a workaround as ESP32 WiFi libs don’t currently auto-reassociate. */

esp_wifi_connect();

xEventGroupClearBits(wifi_event_group, IPV4_GOTIP_BIT);

break;

default:

break;

}

return ESP_OK;

}

static void initialise_wifi(void)

{

tcpip_adapter_init();

wifi_event_group = xEventGroupCreate();

ESP_ERROR_CHECK( esp_event_loop_init(event_handler, NULL) );

wifi_init_config_t cfg = WIFI_INIT_CONFIG_DEFAULT();

ESP_ERROR_CHECK( esp_wifi_init(&cfg) );

ESP_ERROR_CHECK( esp_wifi_set_storage(WIFI_STORAGE_RAM) );

wifi_config_t wifi_config = {

.sta = {

.ssid = EXAMPLE_WIFI_SSID,

.password = EXAMPLE_WIFI_PASS,

},

};

ESP_LOGI(TAG, “Setting WiFi configuration SSID %s…”, wifi_config.sta.ssid);

ESP_ERROR_CHECK( esp_wifi_set_mode(WIFI_MODE_STA) );

ESP_ERROR_CHECK( esp_wifi_set_config(ESP_IF_WIFI_STA, &wifi_config) );

ESP_ERROR_CHECK( esp_wifi_start() );

}

static void wait_for_ip()

{

uint32_t bits = IPV4_GOTIP_BIT;

ESP_LOGI(TAG, “Waiting for AP connection…”);

xEventGroupWaitBits(wifi_event_group, bits, false, true, portMAX_DELAY);

ESP_LOGI(TAG, “Connected to AP”);

}

static void udp_server_task(void *pvParameters)

{

char rx_buffer[4000];

char addr_str[128];

int addr_family;

int ip_protocol;

while (1) {

struct sockaddr_in destAddr;

destAddr.sin_addr.s_addr = htonl(INADDR_ANY);

destAddr.sin_family = AF_INET;

destAddr.sin_port = htons(PORT);

addr_family = AF_INET;

ip_protocol = IPPROTO_IP;

inet_ntoa_r(destAddr.sin_addr, addr_str, sizeof(addr_str) - 1);

int sock = socket(addr_family, SOCK_DGRAM, ip_protocol);

if (sock < 0) {

ESP_LOGE(TAG, “Unable to create socket: errno %d”, errno);

break;

}

ESP_LOGI(TAG, “Socket created”);

int err = bind(sock, (struct sockaddr *)&destAddr, sizeof(destAddr));

if (err < 0) {

ESP_LOGE(TAG, “Socket unable to bind: errno %d”, errno);

}

ESP_LOGI(TAG, “Socket binded”);

while (1) {

ESP_LOGI(TAG, “Waiting for data”);

struct sockaddr_in sourceAddr;

socklen_t socklen = sizeof(sourceAddr);

int len = recvfrom(sock, rx_buffer, sizeof(rx_buffer) - 1, 0, (struct sockaddr *)&sourceAddr, &socklen);

// Error occured during receiving

if (len < 0) {

ESP_LOGE(TAG, “recvfrom failed: errno %d”, errno);

break;

}

// Data received

else {

// Get the sender’s ip address as string

inet_ntoa_r(((struct sockaddr_in *)&sourceAddr)->sin_addr.s_addr, addr_str, sizeof(addr_str) - 1);

rx_buffer[len] = 0; // Null-terminate whatever we received and treat like a string…

ESP_LOGI(TAG, “Received %d bytes from %s Free memory %d bytes”, len, addr_str,esp_get_free_heap_size());

}

}

if (sock != -1) {

ESP_LOGE(TAG, “Shutting down socket and restarting…”);

shutdown(sock, 0);

close(sock);

}

}

vTaskDelete(NULL);

}

void app_main()

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

最后

分享一份NDK基础开发资料

详解:Linux网络虚拟化技术

分享内容包括不限于高级UI、性能优化、架构师课程、NDK、混合式开发(ReactNative+Weex)微信小程序、Flutter等全方面的Android进阶实践技术;希望能帮助到大家,也节省大家在网上搜索资料的时间来学习,也可以分享动态给身边好友一起学习!

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!

57ttC-1711815725176)]

分享内容包括不限于高级UI、性能优化、架构师课程、NDK、混合式开发(ReactNative+Weex)微信小程序、Flutter等全方面的Android进阶实践技术;希望能帮助到大家,也节省大家在网上搜索资料的时间来学习,也可以分享动态给身边好友一起学习!

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值