2007-09-09 03:50:59 +08:00
|
|
|
/****************************************************************************
|
2014-06-27 04:23:21 +08:00
|
|
|
* net/utils/utils.h
|
2007-09-09 03:50:59 +08:00
|
|
|
*
|
2021-02-19 19:45:37 +08:00
|
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
|
|
* contributor license agreements. See the NOTICE file distributed with
|
|
|
|
* this work for additional information regarding copyright ownership. The
|
|
|
|
* ASF licenses this file to you under the Apache License, Version 2.0 (the
|
|
|
|
* "License"); you may not use this file except in compliance with the
|
|
|
|
* License. You may obtain a copy of the License at
|
2007-09-09 03:50:59 +08:00
|
|
|
*
|
2021-02-19 19:45:37 +08:00
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
2007-09-09 03:50:59 +08:00
|
|
|
*
|
2021-02-19 19:45:37 +08:00
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
* License for the specific language governing permissions and limitations
|
|
|
|
* under the License.
|
2007-09-09 03:50:59 +08:00
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
2014-06-27 04:23:21 +08:00
|
|
|
#ifndef __NET_UTILS_UTILS_H
|
|
|
|
#define __NET_UTILS_UTILS_H
|
|
|
|
|
2007-09-09 03:50:59 +08:00
|
|
|
/****************************************************************************
|
|
|
|
* Included Files
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#include <nuttx/config.h>
|
2015-05-31 22:34:03 +08:00
|
|
|
#include <nuttx/net/net.h>
|
2015-02-06 22:11:09 +08:00
|
|
|
#include <nuttx/net/ip.h>
|
2022-11-30 13:15:34 +08:00
|
|
|
#include <nuttx/net/netdev.h>
|
2007-09-09 03:50:59 +08:00
|
|
|
|
2014-06-27 04:23:21 +08:00
|
|
|
/****************************************************************************
|
|
|
|
* Public Types
|
|
|
|
****************************************************************************/
|
|
|
|
|
2015-05-29 21:17:15 +08:00
|
|
|
/* These values control the behavior of net_timeval2desc */
|
|
|
|
|
|
|
|
enum tv2ds_remainder_e
|
|
|
|
{
|
|
|
|
TV2DS_TRUNC = 0, /* Truncate microsecond remainder */
|
|
|
|
TV2DS_ROUND, /* Round to the nearest full decisecond */
|
|
|
|
TV2DS_CEIL /* Force to next larger full decisecond */
|
|
|
|
};
|
|
|
|
|
2014-06-27 04:23:21 +08:00
|
|
|
/****************************************************************************
|
|
|
|
* Public Data
|
|
|
|
****************************************************************************/
|
2007-09-09 03:50:59 +08:00
|
|
|
|
2014-06-27 04:23:21 +08:00
|
|
|
#ifdef __cplusplus
|
|
|
|
#define EXTERN extern "C"
|
|
|
|
extern "C"
|
|
|
|
{
|
|
|
|
#else
|
|
|
|
#define EXTERN extern
|
|
|
|
#endif
|
2007-09-09 03:50:59 +08:00
|
|
|
|
|
|
|
/****************************************************************************
|
2014-06-27 04:23:21 +08:00
|
|
|
* Public Function Prototypes
|
2007-09-09 03:50:59 +08:00
|
|
|
****************************************************************************/
|
|
|
|
|
2014-06-29 07:25:18 +08:00
|
|
|
struct net_driver_s; /* Forward reference */
|
|
|
|
struct timeval; /* Forward reference */
|
|
|
|
|
2018-07-07 09:49:05 +08:00
|
|
|
/****************************************************************************
|
|
|
|
* Name: net_breaklock
|
|
|
|
*
|
|
|
|
* Description:
|
|
|
|
* Break the lock, return information needed to restore re-entrant lock
|
|
|
|
* state.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
int net_breaklock(FAR unsigned int *count);
|
|
|
|
|
|
|
|
/****************************************************************************
|
2020-02-01 02:09:01 +08:00
|
|
|
* Name: net_restorelock
|
2018-07-07 09:49:05 +08:00
|
|
|
*
|
|
|
|
* Description:
|
|
|
|
* Restore the locked state
|
|
|
|
*
|
2019-04-14 23:37:25 +08:00
|
|
|
* Returned Value:
|
|
|
|
* Zero (OK) is returned on success; a negated errno value is returned on
|
|
|
|
* failured (probably -ECANCELED).
|
|
|
|
*
|
2018-07-07 09:49:05 +08:00
|
|
|
****************************************************************************/
|
|
|
|
|
2019-04-14 23:37:25 +08:00
|
|
|
int net_restorelock(unsigned int count);
|
2018-07-07 09:49:05 +08:00
|
|
|
|
2007-09-09 03:50:59 +08:00
|
|
|
/****************************************************************************
|
2017-04-22 06:33:14 +08:00
|
|
|
* Name: net_dsec2timeval
|
2007-09-09 03:50:59 +08:00
|
|
|
*
|
|
|
|
* Description:
|
2014-07-06 05:15:40 +08:00
|
|
|
* Convert a decisecond value to a struct timeval. Needed by getsockopt()
|
|
|
|
* to report timeout values.
|
2007-09-09 03:50:59 +08:00
|
|
|
*
|
2018-03-13 23:52:27 +08:00
|
|
|
* Input Parameters:
|
2007-09-09 03:50:59 +08:00
|
|
|
* dsec The decisecond value to convert
|
|
|
|
* tv The struct timeval to receive the converted value
|
|
|
|
*
|
|
|
|
* Returned Value:
|
|
|
|
* None
|
|
|
|
*
|
|
|
|
* Assumptions:
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
2014-06-27 04:23:21 +08:00
|
|
|
void net_dsec2timeval(uint16_t dsec, FAR struct timeval *tv);
|
2014-06-29 07:25:18 +08:00
|
|
|
|
2014-07-06 05:15:40 +08:00
|
|
|
/****************************************************************************
|
2017-04-22 06:33:14 +08:00
|
|
|
* Name: net_dsec2tick
|
2014-07-06 05:15:40 +08:00
|
|
|
*
|
|
|
|
* Description:
|
|
|
|
* Convert a decisecond value to a system clock ticks. Used by IGMP logic.
|
|
|
|
*
|
2018-03-13 23:52:27 +08:00
|
|
|
* Input Parameters:
|
2014-07-06 05:15:40 +08:00
|
|
|
* dsec The decisecond value to convert
|
|
|
|
*
|
|
|
|
* Returned Value:
|
|
|
|
* The decisecond value expressed as system clock ticks
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
unsigned int net_dsec2tick(int dsec);
|
|
|
|
|
2014-06-29 07:25:18 +08:00
|
|
|
/****************************************************************************
|
2017-04-22 06:33:14 +08:00
|
|
|
* Name: net_timeval2dsec
|
2014-06-29 07:25:18 +08:00
|
|
|
*
|
|
|
|
* Description:
|
|
|
|
* Convert a struct timeval to deciseconds. Needed by setsockopt() to
|
|
|
|
* save new timeout values.
|
|
|
|
*
|
2018-03-13 23:52:27 +08:00
|
|
|
* Input Parameters:
|
2015-05-29 21:17:15 +08:00
|
|
|
* tv - The struct timeval to convert
|
|
|
|
* remainder - Determines how to handler the microsecond remainder
|
2014-06-29 07:25:18 +08:00
|
|
|
*
|
|
|
|
* Returned Value:
|
|
|
|
* The converted value
|
|
|
|
*
|
|
|
|
* Assumptions:
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
2015-05-29 21:17:15 +08:00
|
|
|
unsigned int net_timeval2dsec(FAR struct timeval *tv,
|
|
|
|
enum tv2ds_remainder_e remainder);
|
2014-06-27 04:23:21 +08:00
|
|
|
|
2016-01-10 05:56:08 +08:00
|
|
|
/****************************************************************************
|
|
|
|
* Name: net_ipv6_mask2pref
|
|
|
|
*
|
|
|
|
* Description:
|
2020-10-19 12:09:06 +08:00
|
|
|
* Convert a 128-bit netmask to a prefix length. The NuttX IPv6
|
2016-01-10 05:56:08 +08:00
|
|
|
* networking uses 128-bit network masks internally. This function
|
|
|
|
* converts the IPv6 netmask to a prefix length.
|
|
|
|
*
|
|
|
|
* The prefix length is the number of MS '1' bits on in the netmask.
|
|
|
|
* This, of course, assumes that all MS bits are '1' and all LS bits are
|
|
|
|
* '0' with no intermixed 1's and 0's. This function searches from the MS
|
|
|
|
* bit until the first '0' is found (this does not necessary mean that
|
|
|
|
* there might not be additional '1' bits following the firs '0', but that
|
|
|
|
* will be a malformed netmask.
|
|
|
|
*
|
2018-03-13 23:52:27 +08:00
|
|
|
* Input Parameters:
|
2016-01-10 05:56:08 +08:00
|
|
|
* mask Points to an IPv6 netmask in the form of uint16_t[8]
|
|
|
|
*
|
2018-02-02 00:00:02 +08:00
|
|
|
* Returned Value:
|
2016-01-10 05:56:08 +08:00
|
|
|
* The prefix length, range 0-128 on success; This function will not
|
|
|
|
* fail.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#ifdef CONFIG_NET_IPv6
|
|
|
|
uint8_t net_ipv6_mask2pref(FAR const uint16_t *mask);
|
|
|
|
#endif
|
|
|
|
|
2015-02-06 22:11:09 +08:00
|
|
|
/****************************************************************************
|
2017-04-22 06:33:14 +08:00
|
|
|
* Name: net_ipv6_pref2mask
|
2015-02-06 22:11:09 +08:00
|
|
|
*
|
|
|
|
* Description:
|
|
|
|
* Convert a IPv6 prefix length to a network mask. The prefix length
|
|
|
|
* specifies the number of MS bits under mask (0-128)
|
|
|
|
*
|
2018-03-13 23:52:27 +08:00
|
|
|
* Input Parameters:
|
2015-02-06 22:11:09 +08:00
|
|
|
* preflen - Determines the width of the netmask (in bits). Range 0-128
|
|
|
|
* mask - The location to return the netmask.
|
|
|
|
*
|
|
|
|
* Returned Value:
|
|
|
|
* None
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#ifdef CONFIG_NET_IPv6
|
|
|
|
void net_ipv6_pref2mask(uint8_t preflen, net_ipv6addr_t mask);
|
|
|
|
#endif
|
|
|
|
|
2022-10-31 14:48:46 +08:00
|
|
|
/****************************************************************************
|
|
|
|
* Name: net_chksum_adjust
|
|
|
|
*
|
|
|
|
* Description:
|
|
|
|
* Adjusts the checksum of a packet without having to completely
|
|
|
|
* recalculate it, as described in RFC 3022, Section 4.2, Page 9.
|
|
|
|
*
|
|
|
|
* Input Parameters:
|
|
|
|
* chksum - points to the chksum in the packet
|
|
|
|
* optr - points to the old data in the packet
|
|
|
|
* olen - length of old data
|
|
|
|
* nptr - points to the new data in the packet
|
|
|
|
* nlen - length of new data
|
|
|
|
*
|
|
|
|
* Limitations:
|
|
|
|
* The algorithm is applicable only for even offsets and even lengths.
|
2022-11-30 13:15:34 +08:00
|
|
|
*
|
2022-10-31 14:48:46 +08:00
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
void net_chksum_adjust(FAR uint16_t *chksum,
|
|
|
|
FAR const uint16_t *optr, ssize_t olen,
|
|
|
|
FAR const uint16_t *nptr, ssize_t nlen);
|
|
|
|
|
2014-06-28 07:51:32 +08:00
|
|
|
/****************************************************************************
|
2015-01-18 22:56:05 +08:00
|
|
|
* Name: tcp_chksum, tcp_ipv4_chksum, and tcp_ipv6_chksum
|
2014-06-28 07:51:32 +08:00
|
|
|
*
|
|
|
|
* Description:
|
|
|
|
* Calculate the TCP checksum of the packet in d_buf and d_appdata.
|
|
|
|
*
|
|
|
|
* The TCP checksum is the Internet checksum of data contents of the
|
|
|
|
* TCP segment, and a pseudo-header as defined in RFC793.
|
|
|
|
*
|
|
|
|
* Note: The d_appdata pointer that points to the packet data may
|
|
|
|
* point anywhere in memory, so it is not possible to simply calculate
|
|
|
|
* the Internet checksum of the contents of the d_buf buffer.
|
|
|
|
*
|
|
|
|
* Returned Value:
|
|
|
|
* The TCP checksum of the TCP segment in d_buf and pointed to by
|
|
|
|
* d_appdata.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
2015-01-18 22:56:05 +08:00
|
|
|
#ifdef CONFIG_NET_IPv4
|
|
|
|
uint16_t tcp_ipv4_chksum(FAR struct net_driver_s *dev);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef CONFIG_NET_IPv6
|
|
|
|
uint16_t tcp_ipv6_chksum(FAR struct net_driver_s *dev);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(CONFIG_NET_IPv4) && defined(CONFIG_NET_IPv6)
|
2014-06-28 07:51:32 +08:00
|
|
|
uint16_t tcp_chksum(FAR struct net_driver_s *dev);
|
2015-01-18 22:56:05 +08:00
|
|
|
#elif defined(CONFIG_NET_IPv4)
|
|
|
|
# define tcp_chksum(d) tcp_ipv4_chksum(d)
|
|
|
|
#else /* if defined(CONFIG_NET_IPv6) */
|
|
|
|
# define tcp_chksum(d) tcp_ipv6_chksum(d)
|
|
|
|
#endif
|
|
|
|
|
2014-06-28 07:51:32 +08:00
|
|
|
/****************************************************************************
|
2015-01-23 23:33:18 +08:00
|
|
|
* Name: udp_ipv4_chksum
|
2014-06-28 07:51:32 +08:00
|
|
|
*
|
|
|
|
* Description:
|
2015-01-23 23:33:18 +08:00
|
|
|
* Calculate the UDP/IPv4 checksum of the packet in d_buf and d_appdata.
|
2014-06-28 07:51:32 +08:00
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
2015-01-23 23:33:18 +08:00
|
|
|
#if defined(CONFIG_NET_UDP_CHECKSUMS) && defined(CONFIG_NET_IPv4)
|
|
|
|
uint16_t udp_ipv4_chksum(FAR struct net_driver_s *dev);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Name: udp_ipv6_chksum
|
|
|
|
*
|
|
|
|
* Description:
|
|
|
|
* Calculate the UDP/IPv6 checksum of the packet in d_buf and d_appdata.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#if defined(CONFIG_NET_UDP_CHECKSUMS) && defined(CONFIG_NET_IPv6)
|
|
|
|
uint16_t udp_ipv6_chksum(FAR struct net_driver_s *dev);
|
2014-06-28 07:51:32 +08:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Name: icmp_chksum
|
|
|
|
*
|
|
|
|
* Description:
|
2015-01-15 08:34:28 +08:00
|
|
|
* Calculate the checksum of the IPv4 ICMP message
|
2014-06-28 07:51:32 +08:00
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
2021-11-25 22:03:33 +08:00
|
|
|
#ifdef CONFIG_NET_ICMP
|
2014-06-28 07:51:32 +08:00
|
|
|
uint16_t icmp_chksum(FAR struct net_driver_s *dev, int len);
|
2015-01-15 08:34:28 +08:00
|
|
|
#endif
|
|
|
|
|
2022-11-23 19:39:40 +08:00
|
|
|
/****************************************************************************
|
|
|
|
* Name: icmp_chksum_iob
|
|
|
|
*
|
|
|
|
* Description:
|
|
|
|
* Calculate the checksum of the ICMP message, the input can be an I/O
|
|
|
|
* buffer chain
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#if defined(CONFIG_NET_ICMP) && defined(CONFIG_MM_IOB)
|
|
|
|
uint16_t icmp_chksum_iob(FAR struct iob_s *iob);
|
|
|
|
#endif /* CONFIG_NET_ICMP && CONFIG_MM_IOB */
|
|
|
|
|
2015-01-15 08:34:28 +08:00
|
|
|
/****************************************************************************
|
|
|
|
* Name: icmpv6_chksum
|
|
|
|
*
|
|
|
|
* Description:
|
|
|
|
* Calculate the checksum of the ICMPv6 message
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#ifdef CONFIG_NET_ICMPv6
|
2018-11-05 22:56:07 +08:00
|
|
|
uint16_t icmpv6_chksum(FAR struct net_driver_s *dev, unsigned int iplen);
|
2015-01-15 08:34:28 +08:00
|
|
|
#endif
|
2014-06-28 07:51:32 +08:00
|
|
|
|
2023-04-20 12:15:24 +08:00
|
|
|
/****************************************************************************
|
|
|
|
* Name: cmsg_append
|
|
|
|
*
|
|
|
|
* Description:
|
|
|
|
* Append specified data into the control message, msg_control and
|
|
|
|
* msg_controllen will be changed to the appropriate value when success
|
|
|
|
*
|
|
|
|
* Input Parameters:
|
|
|
|
* msg - Buffer to receive the message.
|
|
|
|
* level - The level of control message.
|
|
|
|
* type - The type of control message.
|
|
|
|
* value - If the value is not NULL, this interface copies the data
|
|
|
|
* to the appropriate location in msg_control, and modify
|
|
|
|
* msg_control and msg_controllen.
|
|
|
|
* If the value is NULL, just modify the corresponding value
|
|
|
|
* of msg.
|
|
|
|
* value_len - The value length of control message.
|
|
|
|
*
|
|
|
|
* Returned Value:
|
|
|
|
* On success, a pointer to the start address of control message data,
|
|
|
|
* the caller can copy the data in.
|
|
|
|
* On failure, return NULL, because of msg_controllen is not enough
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
FAR void *cmsg_append(FAR struct msghdr *msg, int level, int type,
|
|
|
|
FAR void *value, int value_len);
|
|
|
|
|
2014-06-27 04:23:21 +08:00
|
|
|
#undef EXTERN
|
|
|
|
#ifdef __cplusplus
|
2007-09-09 03:50:59 +08:00
|
|
|
}
|
2014-06-27 04:23:21 +08:00
|
|
|
#endif
|
2007-09-09 03:50:59 +08:00
|
|
|
|
2014-06-27 04:23:21 +08:00
|
|
|
#endif /* __NET_UTILS_UTILS_H */
|