first pass implementing broadcast, two devices can ping-pong each other
This commit is contained in:
parent
34d7d5a013
commit
c2e6c645b3
3 changed files with 81 additions and 8 deletions
|
|
@ -1 +1 @@
|
|||
Subproject commit 990f338826b50c3bca9953dcea7411ac841cd1c1
|
||||
Subproject commit a893586025d4f8591de124b42a9ba529fd397a31
|
||||
2
esp-idf
2
esp-idf
|
|
@ -1 +1 @@
|
|||
Subproject commit 490691bc61802e28ddfc1997edc8df6c203c1537
|
||||
Subproject commit 3b8741b172dc951e18509698dee938304bcf1523
|
||||
85
main/main.c
85
main/main.c
|
|
@ -1,14 +1,19 @@
|
|||
#include <string.h>
|
||||
#include "esp_random.h"
|
||||
#include "esp_log.h"
|
||||
#include "esp_mac.h"
|
||||
#include "esp_wifi.h"
|
||||
|
||||
#include "nvs_flash.h"
|
||||
#include "socket.h"
|
||||
|
||||
#include "esp_netif_lora.h"
|
||||
|
||||
#define TAG "netif"
|
||||
|
||||
void app_main() {
|
||||
esp_netif_lora_config_t config;
|
||||
static esp_netif_lora_config_t config;
|
||||
|
||||
config.netif = NULL;
|
||||
config.lora = NULL;
|
||||
|
||||
ESP_LOGI(TAG, "config.lora: %p", (void*)config.lora);
|
||||
|
||||
esp_efuse_mac_get_default((uint8_t*)&config.mac);
|
||||
|
||||
|
|
@ -16,6 +21,74 @@ void app_main() {
|
|||
esp_netif_set_ip4_addr(&config.ip_info.gw, 10, 10 , 0, 1);
|
||||
esp_netif_set_ip4_addr(&config.ip_info.netmask, 255, 255 , 255, 0);
|
||||
|
||||
esp_log_level_set("LoRa32", ESP_LOG_INFO);
|
||||
//esp_log_level_set("spi_master", ESP_LOG_DEBUG);
|
||||
//esp_log_level_set("LoRa32", ESP_LOG_DEBUG);
|
||||
|
||||
esp_netif_lora_init(&config);
|
||||
|
||||
int sock = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP);
|
||||
|
||||
struct sockaddr_in local_addr;
|
||||
local_addr.sin_family = AF_INET;
|
||||
//local_addr.sin_addr.s_addr = config.ip_info.ip.addr;
|
||||
local_addr.sin_addr.s_addr = INADDR_ANY;
|
||||
local_addr.sin_port = htons(666);
|
||||
|
||||
//ESP_ERROR_CHECK(ret);
|
||||
|
||||
struct timeval timeout;
|
||||
|
||||
timeout.tv_sec = esp_random() % 4 + 1;
|
||||
timeout.tv_usec = 0;
|
||||
|
||||
setsockopt(sock, SOL_SOCKET, SO_RCVTIMEO, &timeout, sizeof(timeout));
|
||||
setsockopt(sock, SOL_SOCKET, SO_BROADCAST, NULL, 0);
|
||||
|
||||
ip_mreq mreq;
|
||||
mreq.imr_multiaddr.s_addr = inet_addr("224.0.1.187");
|
||||
mreq.imr_interface.s_addr = config.ip_info.ip.addr;
|
||||
|
||||
setsockopt(sock, IPPROTO_IP, IP_ADD_MEMBERSHIP, (char *)&mreq, sizeof(mreq));
|
||||
|
||||
// TODO double check this is actually part of accepting multicast
|
||||
// or if it was just binding to INADDR_ANY
|
||||
setsockopt(sock, SOL_SOCKET, SO_BROADCAST, (void*)1, 1);
|
||||
|
||||
int ret = bind(sock, (struct sockaddr *)&local_addr, sizeof(local_addr));
|
||||
|
||||
ESP_LOGI(TAG, "looping");
|
||||
|
||||
uint8_t buf[200];
|
||||
uint8_t client_addr_len;
|
||||
ssize_t recieved;
|
||||
ssize_t sent;
|
||||
|
||||
buf[0] = 0x06;
|
||||
buf[1] = 0x06;
|
||||
buf[2] = 0x06;
|
||||
|
||||
struct sockaddr_in broadcast;
|
||||
broadcast.sin_family = AF_INET;
|
||||
broadcast.sin_addr.s_addr = inet_addr("224.0.1.187");
|
||||
broadcast.sin_port = htons(666);
|
||||
|
||||
while(1) {
|
||||
recieved = recvfrom(sock, &buf, 255, 0, (struct sockaddr *)&local_addr, (socklen_t *)&client_addr_len);
|
||||
|
||||
if((int)recieved == -1) {
|
||||
sent = sendto(sock, &buf, sizeof(buf), 0, (struct sockaddr *)&broadcast, sizeof(broadcast));
|
||||
|
||||
if(sent == -1) {
|
||||
ESP_LOGI(TAG, "sendto errno: %d", errno);
|
||||
}
|
||||
} else {
|
||||
ESP_LOGI(TAG, "buf[0] = %d", buf[0]);
|
||||
|
||||
buf[0]++;
|
||||
|
||||
sent = sendto(sock, &buf, sizeof(buf), 0, (struct sockaddr *)&broadcast, sizeof(broadcast));
|
||||
}
|
||||
|
||||
vTaskDelay(10 / portTICK_PERIOD_MS);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue