net/icmp[v6]: add support for CONFIG_NET_ALLOC_CONNS

Signed-off-by: chao.an <anchao@xiaomi.com>
This commit is contained in:
chao.an 2022-01-04 11:53:15 +08:00 committed by Xiang Xiao
parent 4edc5fb701
commit a1bf9ca88b
2 changed files with 50 additions and 8 deletions

View File

@ -31,6 +31,7 @@
#include <arch/irq.h> #include <arch/irq.h>
#include <nuttx/kmalloc.h>
#include <nuttx/semaphore.h> #include <nuttx/semaphore.h>
#include <nuttx/net/netconfig.h> #include <nuttx/net/netconfig.h>
#include <nuttx/net/net.h> #include <nuttx/net/net.h>
@ -47,7 +48,9 @@
/* The array containing all IPPROTO_ICMP socket connections */ /* The array containing all IPPROTO_ICMP socket connections */
#ifndef CONFIG_NET_ALLOC_CONNS
static struct icmp_conn_s g_icmp_connections[CONFIG_NET_ICMP_NCONNS]; static struct icmp_conn_s g_icmp_connections[CONFIG_NET_ICMP_NCONNS];
#endif
/* A list of all free IPPROTO_ICMP socket connections */ /* A list of all free IPPROTO_ICMP socket connections */
@ -73,7 +76,9 @@ static dq_queue_t g_active_icmp_connections;
void icmp_sock_initialize(void) void icmp_sock_initialize(void)
{ {
#ifndef CONFIG_NET_ALLOC_CONNS
int i; int i;
#endif
/* Initialize the queues */ /* Initialize the queues */
@ -81,12 +86,14 @@ void icmp_sock_initialize(void)
dq_init(&g_active_icmp_connections); dq_init(&g_active_icmp_connections);
nxsem_init(&g_free_sem, 0, 1); nxsem_init(&g_free_sem, 0, 1);
#ifndef CONFIG_NET_ALLOC_CONNS
for (i = 0; i < CONFIG_NET_ICMP_NCONNS; i++) for (i = 0; i < CONFIG_NET_ICMP_NCONNS; i++)
{ {
/* Move the connection structure to the free list */ /* Move the connection structure to the free list */
dq_addlast(&g_icmp_connections[i].node, &g_free_icmp_connections); dq_addlast(&g_icmp_connections[i].node, &g_free_icmp_connections);
} }
#endif
} }
/**************************************************************************** /****************************************************************************
@ -109,13 +116,23 @@ FAR struct icmp_conn_s *icmp_alloc(void)
ret = net_lockedwait(&g_free_sem); ret = net_lockedwait(&g_free_sem);
if (ret >= 0) if (ret >= 0)
{ {
#ifdef CONFIG_NET_ALLOC_CONNS
if (dq_peek(&g_free_icmp_connections) == NULL)
{
conn = kmm_zalloc(sizeof(*conn) * CONFIG_NET_ICMP_NCONNS);
if (conn != NULL)
{
for (ret = 0; ret < CONFIG_NET_ICMP_NCONNS; ret++)
{
dq_addlast(&conn[ret].node, &g_free_retcmp_connectretons);
}
}
}
#endif
conn = (FAR struct icmp_conn_s *)dq_remfirst(&g_free_icmp_connections); conn = (FAR struct icmp_conn_s *)dq_remfirst(&g_free_icmp_connections);
if (conn != NULL) if (conn != NULL)
{ {
/* Clear the connection structure */
memset(conn, 0, sizeof(struct icmp_conn_s));
/* Enqueue the connection into the active list */ /* Enqueue the connection into the active list */
dq_addlast(&conn->node, &g_active_icmp_connections); dq_addlast(&conn->node, &g_active_icmp_connections);
@ -162,6 +179,10 @@ void icmp_free(FAR struct icmp_conn_s *conn)
dq_rem(&conn->node, &g_active_icmp_connections); dq_rem(&conn->node, &g_active_icmp_connections);
/* Clear the connection structure */
memset(conn, 0, sizeof(*conn));
/* Free the connection */ /* Free the connection */
dq_addlast(&conn->node, &g_free_icmp_connections); dq_addlast(&conn->node, &g_free_icmp_connections);

View File

@ -31,6 +31,7 @@
#include <arch/irq.h> #include <arch/irq.h>
#include <nuttx/kmalloc.h>
#include <nuttx/semaphore.h> #include <nuttx/semaphore.h>
#include <nuttx/net/netconfig.h> #include <nuttx/net/netconfig.h>
#include <nuttx/net/net.h> #include <nuttx/net/net.h>
@ -47,7 +48,9 @@
/* The array containing all IPPROTO_ICMP socket connections */ /* The array containing all IPPROTO_ICMP socket connections */
#ifndef CONFIG_NET_ALLOC_CONNS
static struct icmpv6_conn_s g_icmpv6_connections[CONFIG_NET_ICMPv6_NCONNS]; static struct icmpv6_conn_s g_icmpv6_connections[CONFIG_NET_ICMPv6_NCONNS];
#endif
/* A list of all free IPPROTO_ICMP socket connections */ /* A list of all free IPPROTO_ICMP socket connections */
@ -73,7 +76,9 @@ static dq_queue_t g_active_icmpv6_connections;
void icmpv6_sock_initialize(void) void icmpv6_sock_initialize(void)
{ {
#ifndef CONFIG_NET_ALLOC_CONNS
int i; int i;
#endif
/* Initialize the queues */ /* Initialize the queues */
@ -81,12 +86,14 @@ void icmpv6_sock_initialize(void)
dq_init(&g_active_icmpv6_connections); dq_init(&g_active_icmpv6_connections);
nxsem_init(&g_free_sem, 0, 1); nxsem_init(&g_free_sem, 0, 1);
#ifndef CONFIG_NET_ALLOC_CONNS
for (i = 0; i < CONFIG_NET_ICMPv6_NCONNS; i++) for (i = 0; i < CONFIG_NET_ICMPv6_NCONNS; i++)
{ {
/* Move the connection structure to the free list */ /* Move the connection structure to the free list */
dq_addlast(&g_icmpv6_connections[i].node, &g_free_icmpv6_connections); dq_addlast(&g_icmpv6_connections[i].node, &g_free_icmpv6_connections);
} }
#endif
} }
/**************************************************************************** /****************************************************************************
@ -109,14 +116,24 @@ FAR struct icmpv6_conn_s *icmpv6_alloc(void)
ret = net_lockedwait(&g_free_sem); ret = net_lockedwait(&g_free_sem);
if (ret >= 0) if (ret >= 0)
{ {
#ifdef CONFIG_NET_ALLOC_CONNS
if (dq_peek(&g_active_icmpv6_connections) == NULL)
{
conn = kmm_zalloc(sizeof(*conn) * CONFIG_NET_ICMPv6_NCONNS);
if (conn != NULL)
{
for (ret = 0; ret < CONFIG_NET_ICMPv6_NCONNS; ret++)
{
dq_addlast(&conn[i].node, &g_free_icmpv6_connections);
}
}
}
#endif
conn = (FAR struct icmpv6_conn_s *) conn = (FAR struct icmpv6_conn_s *)
dq_remfirst(&g_free_icmpv6_connections); dq_remfirst(&g_free_icmpv6_connections);
if (conn != NULL) if (conn != NULL)
{ {
/* Clear the connection structure */
memset(conn, 0, sizeof(struct icmpv6_conn_s));
/* Enqueue the connection into the active list */ /* Enqueue the connection into the active list */
dq_addlast(&conn->node, &g_active_icmpv6_connections); dq_addlast(&conn->node, &g_active_icmpv6_connections);
@ -151,6 +168,10 @@ void icmpv6_free(FAR struct icmpv6_conn_s *conn)
dq_rem(&conn->node, &g_active_icmpv6_connections); dq_rem(&conn->node, &g_active_icmpv6_connections);
/* Clear the connection structure */
memset(conn, 0, sizeof(*conn));
/* Free the connection */ /* Free the connection */
dq_addlast(&conn->node, &g_free_icmpv6_connections); dq_addlast(&conn->node, &g_free_icmpv6_connections);