Morse Micro IoT SDK  2.9.7
mmipal.h
1/*
2 * Copyright 2023 Morse Micro
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
16#pragma once
17
18#ifdef __cplusplus
19extern "C" {
20#endif
21
22#include <stdbool.h>
23#include <stdint.h>
24
26#ifndef MMIPAL_IPADDR_STR_MAXLEN
27#define MMIPAL_IPADDR_STR_MAXLEN (48)
28#endif
29
31#ifndef MMIPAL_MAX_IPV6_ADDRESSES
32#define MMIPAL_MAX_IPV6_ADDRESSES (3)
33#endif
34
37{
48};
49
52{
57};
58
61{
72};
73
76
88{
97};
98
100#define MMIPAL_IP_CONFIG_DEFAULT { MMIPAL_DHCP, "", "", "", }
101
104{
115};
116
128{
133};
134
136#define MMIPAL_IP6_CONFIG_DEFAULT { MMIPAL_IP6_AUTOCONFIG }
137
149{
158
167};
168
173#define MMIPAL_INIT_ARGS_DEFAULT { MMIPAL_DHCP, { 0 }, { 0 }, { 0 }, \
174 MMIPAL_IP6_DISABLED, { 0 }, false, 0 }
175
192
197{
206};
207
213typedef void (*mmipal_link_status_cb_fn_t)(const struct mmipal_link_status *link_status);
214
227
237typedef void (*mmipal_ext_link_status_cb_fn_t)(const struct mmipal_link_status *link_status,
238 void *arg);
239
253
263void mmipal_get_link_packet_counts(uint32_t *tx_packets, uint32_t *rx_packets);
264
270void mmipal_set_tx_qos_tid(uint8_t tid);
271
295 const mmipal_ip_addr_t dest_addr);
296
307
318
327
338
349
356
369
380
381#ifdef __cplusplus
382}
383#endif
384
enum mmipal_status mmipal_init(const struct mmipal_init_args *args)
Initialize the IP stack and enable the MMWLAN interface.
enum mmipal_status mmipal_get_ip_broadcast_addr(mmipal_ip_addr_t broadcast_addr)
Gets the current IPv4 broadcast address.
void(* mmipal_ext_link_status_cb_fn_t)(const struct mmipal_link_status *link_status, void *arg)
Prototype for callback function invoked on link status changes.
Definition: mmipal.h:237
void mmipal_set_tx_qos_tid(uint8_t tid)
Set the QoS Traffic ID to use when transmitting.
void mmipal_get_link_packet_counts(uint32_t *tx_packets, uint32_t *rx_packets)
Get the total number of transmitted and received packets on the MMWLAN interface.
enum mmipal_status mmipal_get_dns_server(uint8_t index, mmipal_ip_addr_t addr)
Get the DNS server at the given index.
enum mmipal_status mmipal_set_ip_config(const struct mmipal_ip_config *config)
Set the IP configurations.
enum mmipal_status mmipal_set_dns_server(uint8_t index, const mmipal_ip_addr_t addr)
Set the DNS server at the given index.
void(* mmipal_link_status_cb_fn_t)(const struct mmipal_link_status *link_status)
Prototype for callback function invoked on link status changes.
Definition: mmipal.h:213
mmipal_link_state
Enumeration of link states.
Definition: mmipal.h:52
enum mmipal_link_state mmipal_get_link_state(void)
Get current IPv4 link state.
mmipal_ip6_addr_mode
Enumeration of IPv6 address allocation modes.
Definition: mmipal.h:104
void mmipal_set_link_status_callback(mmipal_link_status_cb_fn_t fn)
Sets the callback function to be invoked on link status changes.
void mmipal_set_ext_link_status_callback(mmipal_ext_link_status_cb_fn_t fn, void *arg)
Sets the extended link status callback function to be invoked on link status changes.
enum mmipal_status mmipal_get_ip6_config(struct mmipal_ip6_config *config)
Get the IP configurations.
mmipal_status
Enumeration of status codes returned by MMIPAL functions.
Definition: mmipal.h:37
char mmipal_ip_addr_t[MMIPAL_IPADDR_STR_MAXLEN]
IP address string type.
Definition: mmipal.h:75
#define MMIPAL_MAX_IPV6_ADDRESSES
Maximum number of IPv6 addresses supported.
Definition: mmipal.h:32
enum mmipal_status mmipal_set_ip6_config(const struct mmipal_ip6_config *config)
Set the IPv6 configurations.
enum mmipal_status mmipal_get_ip_config(struct mmipal_ip_config *config)
Get the IP configurations.
#define MMIPAL_IPADDR_STR_MAXLEN
Maximum length of an IP address string, including null-terminator.
Definition: mmipal.h:27
mmipal_addr_mode
Enumeration of IP address allocation modes.
Definition: mmipal.h:61
enum mmipal_status mmipal_get_local_addr(mmipal_ip_addr_t local_addr, const mmipal_ip_addr_t dest_addr)
Gets the local address for the MMWLAN interface that is appropriate for a given destination address.
@ MMIPAL_LINK_UP
Link is up.
Definition: mmipal.h:56
@ MMIPAL_LINK_DOWN
Link is down.
Definition: mmipal.h:54
@ MMIPAL_IP6_AUTOCONFIG
IPv6 address allocated via autoconfiguration.
Definition: mmipal.h:111
@ MMIPAL_IP6_DISABLED
Disabled.
Definition: mmipal.h:106
@ MMIPAL_IP6_STATIC
Static IPv6 addresses.
Definition: mmipal.h:108
@ MMIPAL_IP6_DHCP6_STATELESS
IPv6 address allocated via stateless DHCPv6.
Definition: mmipal.h:114
@ MMIPAL_INVALID_ARGUMENT
One or more arguments were invalid.
Definition: mmipal.h:41
@ MMIPAL_SUCCESS
Completed successfully.
Definition: mmipal.h:39
@ MMIPAL_NOT_SUPPORTED
This functionality is not supported (e.g., due to build configuration).
Definition: mmipal.h:47
@ MMIPAL_NO_MEM
Failed due to memory allocation failure.
Definition: mmipal.h:45
@ MMIPAL_NO_LINK
The operation could not complete because the link is not up.
Definition: mmipal.h:43
@ MMIPAL_AUTOIP
IP address allocated via AutoIP.
Definition: mmipal.h:69
@ MMIPAL_DISABLED
Disabled.
Definition: mmipal.h:63
@ MMIPAL_DHCP
IP address allocated via DHCP.
Definition: mmipal.h:67
@ MMIPAL_DHCP_OFFLOAD
DHCP offloaded to chip.
Definition: mmipal.h:71
@ MMIPAL_STATIC
Static IP address.
Definition: mmipal.h:65
Initialize arguments structure.
Definition: mmipal.h:149
enum mmipal_ip6_addr_mode ip6_mode
IPv6 address allocation mode to use.
Definition: mmipal.h:160
uint32_t offload_arp_refresh_s
ARP refresh offload interval in seconds.
Definition: mmipal.h:166
mmipal_ip_addr_t ip6_addr
IPv6 address to use (if ip6_mode is MMIPAL_IP6_STATIC).
Definition: mmipal.h:162
bool offload_arp_response
Flag requesting ARP response offload feature.
Definition: mmipal.h:164
mmipal_ip_addr_t gateway_addr
Gateway IP address to use (if mode is MMIPAL_STATIC).
Definition: mmipal.h:157
enum mmipal_addr_mode mode
IP address allocation mode to use.
Definition: mmipal.h:151
mmipal_ip_addr_t netmask
Netmask to use (if mode is MMIPAL_STATIC).
Definition: mmipal.h:155
mmipal_ip_addr_t ip_addr
IP address to use (if mode is MMIPAL_STATIC).
Definition: mmipal.h:153
IPv6 configuration structure.
Definition: mmipal.h:128
enum mmipal_ip6_addr_mode ip6_mode
IPv6 addresses allocation mode.
Definition: mmipal.h:130
mmipal_ip_addr_t ip6_addr[MMIPAL_MAX_IPV6_ADDRESSES]
Array of IPv6 addresses.
Definition: mmipal.h:132
IPv4 configuration structure.
Definition: mmipal.h:88
enum mmipal_addr_mode mode
IP address allocation mode.
Definition: mmipal.h:90
mmipal_ip_addr_t gateway_addr
Gateway address.
Definition: mmipal.h:96
mmipal_ip_addr_t ip_addr
local IP address
Definition: mmipal.h:92
mmipal_ip_addr_t netmask
Netmask address.
Definition: mmipal.h:94