mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
paho: use GNRC instead of lwip
This commit is contained in:
parent
388f9a2015
commit
ef2b581c10
@ -34,24 +34,12 @@ USEMODULE += netdev_default
|
|||||||
USEPKG += paho-mqtt
|
USEPKG += paho-mqtt
|
||||||
|
|
||||||
# paho-mqtt depends on TCP support, choose which stacks you want
|
# paho-mqtt depends on TCP support, choose which stacks you want
|
||||||
|
GNRC_IPV6 ?= 1
|
||||||
LWIP_IPV4 ?= 0
|
LWIP_IPV4 ?= 0
|
||||||
LWIP_IPV6 ?= 1
|
LWIP_IPV6 ?= 0
|
||||||
|
|
||||||
ifneq (0,$(LWIP_IPV4))
|
include Makefile.lwip
|
||||||
USEMODULE += ipv4_addr
|
include Makefile.gnrc
|
||||||
USEMODULE += lwip_arp
|
|
||||||
USEMODULE += lwip_ipv4
|
|
||||||
USEMODULE += lwip_dhcp_auto
|
|
||||||
CFLAGS += -DETHARP_SUPPORT_STATIC_ENTRIES=1
|
|
||||||
endif
|
|
||||||
|
|
||||||
ifneq (0,$(LWIP_IPV6))
|
|
||||||
USEMODULE += ipv6_addr
|
|
||||||
USEMODULE += lwip_ipv6_autoconfig
|
|
||||||
endif
|
|
||||||
|
|
||||||
USEMODULE += lwip_netdev
|
|
||||||
USEMODULE += lwip
|
|
||||||
|
|
||||||
USEMODULE += sock_async_event
|
USEMODULE += sock_async_event
|
||||||
USEMODULE += sock_ip
|
USEMODULE += sock_ip
|
||||||
|
@ -1,7 +1,9 @@
|
|||||||
BOARD_INSUFFICIENT_MEMORY := \
|
BOARD_INSUFFICIENT_MEMORY := \
|
||||||
airfy-beacon \
|
airfy-beacon \
|
||||||
blackpill \
|
blackpill \
|
||||||
|
blackpill-128kib \
|
||||||
bluepill \
|
bluepill \
|
||||||
|
bluepill-128kib \
|
||||||
bluepill-stm32f030c8 \
|
bluepill-stm32f030c8 \
|
||||||
calliope-mini \
|
calliope-mini \
|
||||||
hifive1 \
|
hifive1 \
|
||||||
|
16
examples/paho-mqtt/Makefile.gnrc
Normal file
16
examples/paho-mqtt/Makefile.gnrc
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
ifneq (0,$(GNRC_IPV6))
|
||||||
|
ifneq (0,$(USE_LWIP))
|
||||||
|
$(error No valid choice: Select either LWIP or GNRC)
|
||||||
|
endif
|
||||||
|
USEMODULE += auto_init_gnrc_netif
|
||||||
|
# Activate ICMPv6 error messages
|
||||||
|
USEMODULE += gnrc_icmpv6_error
|
||||||
|
# Specify the mandatory networking modules for IPv6
|
||||||
|
USEMODULE += gnrc_ipv6_default
|
||||||
|
# Additional networking modules that can be dropped if not needed
|
||||||
|
USEMODULE += gnrc_icmpv6_echo
|
||||||
|
else
|
||||||
|
ifeq (0,$(USE_LWIP))
|
||||||
|
$(error No network stack selected. Please choose either GNRC or LWIP)
|
||||||
|
endif
|
||||||
|
endif
|
25
examples/paho-mqtt/Makefile.lwip
Normal file
25
examples/paho-mqtt/Makefile.lwip
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
USE_LWIP := 0
|
||||||
|
ifneq (0,$(LWIP_IPV4))
|
||||||
|
USE_LWIP := 1
|
||||||
|
endif
|
||||||
|
ifneq (0,$(LWIP_IPV6))
|
||||||
|
USE_LWIP := 1
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifneq (0,$(LWIP_IPV4))
|
||||||
|
USEMODULE += ipv4_addr
|
||||||
|
USEMODULE += lwip_arp
|
||||||
|
USEMODULE += lwip_ipv4
|
||||||
|
USEMODULE += lwip_dhcp_auto
|
||||||
|
CFLAGS += -DETHARP_SUPPORT_STATIC_ENTRIES=1
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifneq (0,$(LWIP_IPV6))
|
||||||
|
USEMODULE += ipv6_addr
|
||||||
|
USEMODULE += lwip_ipv6_autoconfig
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifneq (0,$(USE_LWIP))
|
||||||
|
USEMODULE += lwip_netdev
|
||||||
|
USEMODULE += lwip
|
||||||
|
endif
|
@ -29,6 +29,9 @@
|
|||||||
#include "paho_mqtt.h"
|
#include "paho_mqtt.h"
|
||||||
#include "MQTTClient.h"
|
#include "MQTTClient.h"
|
||||||
|
|
||||||
|
#define MAIN_QUEUE_SIZE (8)
|
||||||
|
static msg_t _main_msg_queue[MAIN_QUEUE_SIZE];
|
||||||
|
|
||||||
#define BUF_SIZE 1024
|
#define BUF_SIZE 1024
|
||||||
#define MQTT_VERSION_v311 4 /* MQTT v3.1.1 version is 4 */
|
#define MQTT_VERSION_v311 4 /* MQTT v3.1.1 version is 4 */
|
||||||
#define COMMAND_TIMEOUT_MS 4000
|
#define COMMAND_TIMEOUT_MS 4000
|
||||||
@ -293,6 +296,9 @@ static unsigned char readbuf[BUF_SIZE];
|
|||||||
|
|
||||||
int main(void)
|
int main(void)
|
||||||
{
|
{
|
||||||
|
if (IS_USED(MODULE_GNRC_ICMPV6_ECHO)) {
|
||||||
|
msg_init_queue(_main_msg_queue, MAIN_QUEUE_SIZE);
|
||||||
|
}
|
||||||
#ifdef MODULE_LWIP
|
#ifdef MODULE_LWIP
|
||||||
/* let LWIP initialize */
|
/* let LWIP initialize */
|
||||||
ztimer_sleep(ZTIMER_MSEC, 1 * MS_PER_SEC);
|
ztimer_sleep(ZTIMER_MSEC, 1 * MS_PER_SEC);
|
||||||
|
@ -39,11 +39,9 @@
|
|||||||
#define TSRB_MAX_SIZE (1024)
|
#define TSRB_MAX_SIZE (1024)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef MODULE_LWIP
|
|
||||||
static uint8_t buffer[TSRB_MAX_SIZE];
|
static uint8_t buffer[TSRB_MAX_SIZE];
|
||||||
static uint8_t _temp_buf[TSRB_MAX_SIZE];
|
static uint8_t _temp_buf[TSRB_MAX_SIZE];
|
||||||
static tsrb_t tsrb_lwip_tcp;
|
static tsrb_t tsrb_lwip_tcp;
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef PAHO_MQTT_YIELD_MS
|
#ifndef PAHO_MQTT_YIELD_MS
|
||||||
#define PAHO_MQTT_YIELD_MS (10)
|
#define PAHO_MQTT_YIELD_MS (10)
|
||||||
@ -75,7 +73,7 @@ static int mqtt_read(struct Network *n, unsigned char *buf, int len,
|
|||||||
uint32_t send_time = ztimer_now(ZTIMER_MSEC) + timeout_ms;
|
uint32_t send_time = ztimer_now(ZTIMER_MSEC) + timeout_ms;
|
||||||
do {
|
do {
|
||||||
rc = sock_tcp_read(&n->sock, _buf, _len, _timeout);
|
rc = sock_tcp_read(&n->sock, _buf, _len, _timeout);
|
||||||
if (rc == -EAGAIN) {
|
if ((rc == -EAGAIN) || (rc == -ETIMEDOUT)) {
|
||||||
rc = 0;
|
rc = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user