net: Simplify getting value for different domain
Signed-off-by: Zhe Weng <wengzhe@xiaomi.com>
This commit is contained in:
parent
2f5bb9200a
commit
c95fd46be3
@ -420,6 +420,30 @@ extern "C"
|
|||||||
(ipv6addr)->s6_addr16[4] == 0 && \
|
(ipv6addr)->s6_addr16[4] == 0 && \
|
||||||
(ipv6addr)->s6_addr16[5] == 0xffff)
|
(ipv6addr)->s6_addr16[5] == 0xffff)
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Macro: net_ip_domain_select
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Select different value by the domain (PF_INET/PF_INET6).
|
||||||
|
* This domain only needs to exist when both IPv4 and IPv6 are enabled.
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* value4 - The value returned when domain is PF_INET.
|
||||||
|
* value6 - The value returned when domain is PF_INET6.
|
||||||
|
* domain - The domain field which may only exists when both IPv4 and IPv6
|
||||||
|
* are enabled.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#if defined(CONFIG_NET_IPv4) && defined(CONFIG_NET_IPv6)
|
||||||
|
# define net_ip_domain_select(domain, value4, value6) \
|
||||||
|
(((domain) == PF_INET) ? (value4) : (value6))
|
||||||
|
#elif defined(CONFIG_NET_IPv4)
|
||||||
|
# define net_ip_domain_select(domain, value4, value6) (value4)
|
||||||
|
#else
|
||||||
|
# define net_ip_domain_select(domain, value4, value6) (value6)
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Macro: net_ip_binding_laddr, net_ip_binding_raddr
|
* Macro: net_ip_binding_laddr, net_ip_binding_raddr
|
||||||
*
|
*
|
||||||
@ -428,24 +452,17 @@ extern "C"
|
|||||||
*
|
*
|
||||||
* Input Parameters:
|
* Input Parameters:
|
||||||
* u - The union of address binding.
|
* u - The union of address binding.
|
||||||
* domain - The domain of address.
|
* domain - The domain of address, only needs to exist when both IPv4 and
|
||||||
|
* IPv6 are enabled.
|
||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#if defined(CONFIG_NET_IPv4) && defined(CONFIG_NET_IPv6)
|
#define net_ip_binding_laddr(u, domain) \
|
||||||
# define net_ip_binding_laddr(u, domain) \
|
net_ip_domain_select(domain, (FAR void *)(&(u)->ipv4.laddr), \
|
||||||
(((domain) == PF_INET) ? (FAR void *)(&(u)->ipv4.laddr) : \
|
(FAR void *)(&(u)->ipv6.laddr))
|
||||||
(FAR void *)(&(u)->ipv6.laddr))
|
#define net_ip_binding_raddr(u, domain) \
|
||||||
# define net_ip_binding_raddr(u, domain) \
|
net_ip_domain_select(domain, (FAR void *)(&(u)->ipv4.raddr), \
|
||||||
(((domain) == PF_INET) ? (FAR void *)(&(u)->ipv4.raddr) : \
|
(FAR void *)(&(u)->ipv6.raddr))
|
||||||
(FAR void *)(&(u)->ipv6.raddr))
|
|
||||||
#elif defined(CONFIG_NET_IPv4)
|
|
||||||
# define net_ip_binding_laddr(u, domain) ((FAR void *)(&(u)->ipv4.laddr))
|
|
||||||
# define net_ip_binding_raddr(u, domain) ((FAR void *)(&(u)->ipv4.raddr))
|
|
||||||
#else
|
|
||||||
# define net_ip_binding_laddr(u, domain) ((FAR void *)(&(u)->ipv6.laddr))
|
|
||||||
# define net_ip_binding_raddr(u, domain) ((FAR void *)(&(u)->ipv6.raddr))
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Macro: net_ipv4addr_copy, net_ipv4addr_hdrcopy, net_ipv6addr_copy, and
|
* Macro: net_ipv4addr_copy, net_ipv4addr_hdrcopy, net_ipv6addr_copy, and
|
||||||
|
@ -150,14 +150,9 @@ int psock_fstat(FAR struct socket *psock, FAR struct stat *buf)
|
|||||||
{
|
{
|
||||||
/* We need the length of the IP header */
|
/* We need the length of the IP header */
|
||||||
|
|
||||||
#if defined(CONFIG_NET_IPv4) && defined(CONFIG_NET_IPv6)
|
iplen = net_ip_domain_select(udp_conn->domain,
|
||||||
iplen = (udp_conn->domain == PF_INET) ? IPv4_HDRLEN :
|
IPv4_HDRLEN, IPv6_HDRLEN);
|
||||||
IPv6_HDRLEN;
|
|
||||||
#elif defined(CONFIG_NET_IPv4)
|
|
||||||
iplen = IPv4_HDRLEN;
|
|
||||||
#else
|
|
||||||
iplen = IPv6_HDRLEN;
|
|
||||||
#endif
|
|
||||||
/* Now we can calculate the MSS */
|
/* Now we can calculate the MSS */
|
||||||
|
|
||||||
buf->st_blksize = UDP_MSS(dev, iplen);
|
buf->st_blksize = UDP_MSS(dev, iplen);
|
||||||
|
@ -57,13 +57,7 @@
|
|||||||
|
|
||||||
static void tcp_path(FAR struct tcp_conn_s *conn, FAR char *buf, size_t len)
|
static void tcp_path(FAR struct tcp_conn_s *conn, FAR char *buf, size_t len)
|
||||||
{
|
{
|
||||||
#if defined(CONFIG_NET_IPv4) && defined(CONFIG_NET_IPv6)
|
uint8_t domain = net_ip_domain_select(conn->domain, PF_INET, PF_INET6);
|
||||||
uint8_t domain = conn->domain;
|
|
||||||
#elif defined(CONFIG_NET_IPv4)
|
|
||||||
const uint8_t domain = PF_INET;
|
|
||||||
#else
|
|
||||||
const uint8_t domain = PF_INET6;
|
|
||||||
#endif
|
|
||||||
char remote[INET6_ADDRSTRLEN];
|
char remote[INET6_ADDRSTRLEN];
|
||||||
char local[INET6_ADDRSTRLEN];
|
char local[INET6_ADDRSTRLEN];
|
||||||
FAR void *laddr = net_ip_binding_laddr(&conn->u, domain);
|
FAR void *laddr = net_ip_binding_laddr(&conn->u, domain);
|
||||||
|
@ -703,26 +703,10 @@ uint16_t tcpip_hdrsize(FAR struct tcp_conn_s *conn)
|
|||||||
{
|
{
|
||||||
uint16_t hdrsize = sizeof(struct tcp_hdr_s);
|
uint16_t hdrsize = sizeof(struct tcp_hdr_s);
|
||||||
|
|
||||||
#if defined(CONFIG_NET_IPv4) && defined(CONFIG_NET_IPv6)
|
UNUSED(conn);
|
||||||
if (conn->domain == PF_INET)
|
return net_ip_domain_select(conn->domain,
|
||||||
{
|
sizeof(struct ipv4_hdr_s) + hdrsize,
|
||||||
/* Select the IPv4 domain */
|
sizeof(struct ipv6_hdr_s) + hdrsize);
|
||||||
|
|
||||||
return sizeof(struct ipv4_hdr_s) + hdrsize;
|
|
||||||
}
|
|
||||||
else /* if (domain == PF_INET6) */
|
|
||||||
{
|
|
||||||
/* Select the IPv6 domain */
|
|
||||||
|
|
||||||
return sizeof(struct ipv6_hdr_s) + hdrsize;
|
|
||||||
}
|
|
||||||
#elif defined(CONFIG_NET_IPv4)
|
|
||||||
((void)conn);
|
|
||||||
return sizeof(struct ipv4_hdr_s) + hdrsize;
|
|
||||||
#elif defined(CONFIG_NET_IPv6)
|
|
||||||
((void)conn);
|
|
||||||
return sizeof(struct ipv6_hdr_s) + hdrsize;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* CONFIG_NET && CONFIG_NET_TCP */
|
#endif /* CONFIG_NET && CONFIG_NET_TCP */
|
||||||
|
@ -57,13 +57,7 @@
|
|||||||
|
|
||||||
static void udp_path(FAR struct udp_conn_s *conn, FAR char *buf, size_t len)
|
static void udp_path(FAR struct udp_conn_s *conn, FAR char *buf, size_t len)
|
||||||
{
|
{
|
||||||
#if defined(CONFIG_NET_IPv4) && defined(CONFIG_NET_IPv6)
|
uint8_t domain = net_ip_domain_select(conn->domain, PF_INET, PF_INET6);
|
||||||
uint8_t domain = conn->domain;
|
|
||||||
#elif defined(CONFIG_NET_IPv4)
|
|
||||||
const uint8_t domain = PF_INET;
|
|
||||||
#else
|
|
||||||
const uint8_t domain = PF_INET6;
|
|
||||||
#endif
|
|
||||||
char remote[INET6_ADDRSTRLEN];
|
char remote[INET6_ADDRSTRLEN];
|
||||||
char local[INET6_ADDRSTRLEN];
|
char local[INET6_ADDRSTRLEN];
|
||||||
FAR void *laddr = net_ip_binding_laddr(&conn->u, domain);
|
FAR void *laddr = net_ip_binding_laddr(&conn->u, domain);
|
||||||
|
@ -232,28 +232,18 @@ uint16_t udpip_hdrsize(FAR struct udp_conn_s *conn)
|
|||||||
uint16_t hdrsize = sizeof(struct udp_hdr_s);
|
uint16_t hdrsize = sizeof(struct udp_hdr_s);
|
||||||
|
|
||||||
#if defined(CONFIG_NET_IPv4) && defined(CONFIG_NET_IPv6)
|
#if defined(CONFIG_NET_IPv4) && defined(CONFIG_NET_IPv6)
|
||||||
/* Which domain the socket used */
|
if (conn->domain == PF_INET6 &&
|
||||||
|
ip6_is_ipv4addr((FAR struct in6_addr *)conn->u.ipv6.raddr))
|
||||||
if (conn->domain == PF_INET ||
|
|
||||||
(conn->domain == PF_INET6 &&
|
|
||||||
ip6_is_ipv4addr((FAR struct in6_addr *)conn->u.ipv6.raddr)))
|
|
||||||
{
|
{
|
||||||
/* Select the IPv4 domain */
|
/* Select the IPv4 domain for hybrid dual-stack IPv6/IPv4 socket */
|
||||||
|
|
||||||
return sizeof(struct ipv4_hdr_s) + hdrsize;
|
return sizeof(struct ipv4_hdr_s) + hdrsize;
|
||||||
}
|
}
|
||||||
else /* if (domain == PF_INET6) */
|
|
||||||
{
|
|
||||||
/* Select the IPv6 domain */
|
|
||||||
|
|
||||||
return sizeof(struct ipv6_hdr_s) + hdrsize;
|
|
||||||
}
|
|
||||||
#elif defined(CONFIG_NET_IPv4)
|
|
||||||
((void)conn);
|
|
||||||
return sizeof(struct ipv4_hdr_s) + hdrsize;
|
|
||||||
#elif defined(CONFIG_NET_IPv6)
|
|
||||||
((void)conn);
|
|
||||||
return sizeof(struct ipv6_hdr_s) + hdrsize;
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
UNUSED(conn);
|
||||||
|
return net_ip_domain_select(conn->domain,
|
||||||
|
sizeof(struct ipv4_hdr_s) + hdrsize,
|
||||||
|
sizeof(struct ipv6_hdr_s) + hdrsize);
|
||||||
}
|
}
|
||||||
#endif /* CONFIG_NET && CONFIG_NET_UDP */
|
#endif /* CONFIG_NET && CONFIG_NET_UDP */
|
||||||
|
Loading…
Reference in New Issue
Block a user