#mqtt-client #mqtt #w5500 #wiznet

no-std w5500-mqtt

MQTT client for the Wiznet W5500 internet offload chip

7 unstable releases (3 breaking)

0.4.0 Jun 9, 2024
0.3.0 Oct 2, 2023
0.2.0 Aug 6, 2023
0.1.2 Aug 1, 2022
0.1.0-alpha.0 Mar 20, 2022

#536 in Embedded development

Download history 52/week @ 2024-08-05 13/week @ 2024-08-12 15/week @ 2024-08-19 39/week @ 2024-08-26 24/week @ 2024-09-02 44/week @ 2024-09-09 60/week @ 2024-09-16 87/week @ 2024-09-23 26/week @ 2024-09-30 7/week @ 2024-10-07 30/week @ 2024-10-14 5/week @ 2024-10-21 17/week @ 2024-10-28 59/week @ 2024-11-04 56/week @ 2024-11-11 28/week @ 2024-11-18

160 downloads per month

MIT license

210KB
3K SLoC

w5500-mqtt

MQTT v5 client for the Wiznet W5500 SPI internet offload chip.

Limitations

This is very basic at the moment, and will be expanded in the future.

  • Does not support password protected MQTT servers.
  • Only supports QoS 0: At most once delivery.

Example

use w5500_mqtt::{
    ll::{
        net::{Ipv4Addr, SocketAddrV4},
        Sn,
    },
    Client, ClientId, Event, DST_PORT, SRC_PORT,
};

let mut client: Client = Client::new(
    Sn::Sn2,
    SRC_PORT,
    SocketAddrV4::new(Ipv4Addr::new(192, 168, 5, 6), DST_PORT),
);

// wait for a connection or die trying
while !matches!(client.process(&mut w5500, monotonic_secs())?, Event::None) {}

// publish to "duck" with a payload "quack"
client.publish(&mut w5500, "duck", b"quack")?;

// subscribe to "cow"
client.subscribe(&mut w5500, "cow")?;

Relevant Specifications

Feature Flags

All features are disabled by default.

  • eh0: Passthrough to w5500-hl.
  • eh1: Passthrough to w5500-hl.
  • defmt: Enable logging with defmt. Also a passthrough to w5500-hl.
  • log: Enable logging with log.
  • w5500-tls: Enable MQTT over TLS.
  • p256-cm4: Passthrough to w5500-tls.

Dependencies

~0.3–1MB
~17K SLoC