[qca-nss-drv] Fix IPv6 connection sync issue with new APIs.
- Do not return in the switch/case loop after calling the conn sync function.
At the end of the function IPv6 netdev callback is called to upadte the
ECM and conntrack connections.
- Fix some boundry type checks in both IPv4 and IPv6 files.
Change-Id: I995ab91e3b3327626277724a565e81604eb40a6a
Signed-off-by: Murat Sezgin <msezgin@codeaurora.org>
diff --git a/nss_ipv4.c b/nss_ipv4.c
index 6984bfa..d6e811f 100644
--- a/nss_ipv4.c
+++ b/nss_ipv4.c
@@ -15,7 +15,7 @@
*/
/*
- * nss_tx_rx_ipv4.c
+ * nss_ipv4.c
* NSS IPv4 APIs
*/
#include <linux/ppp_channel.h>
@@ -115,7 +115,7 @@
/*
* Sanity check the message type
*/
- if (ncm->type > NSS_IPV4_MAX_MSG_TYPES) {
+ if (ncm->type >= NSS_IPV4_MAX_MSG_TYPES) {
nss_warning("%p: message type out of range: %d", nss_ctx, ncm->type);
return;
}
@@ -206,7 +206,7 @@
return NSS_TX_FAILURE;
}
- if (ncm->type > NSS_IPV4_MAX_MSG_TYPES) {
+ if (ncm->type >= NSS_IPV4_MAX_MSG_TYPES) {
nss_warning("%p: message type out of range: %d", nss_ctx, ncm->type);
return NSS_TX_FAILURE;
}
diff --git a/nss_ipv6.c b/nss_ipv6.c
index 6437932..c1cd4c1 100644
--- a/nss_ipv6.c
+++ b/nss_ipv6.c
@@ -64,7 +64,6 @@
dev_put(pppoe_dev);
}
}
-
}
/*
@@ -116,7 +115,7 @@
/*
* Is this a valid request/response packet?
*/
- if (nim->cm.type >= NSS_IPV6_MAX_MSG_TYPES) {
+ if (ncm->type >= NSS_IPV6_MAX_MSG_TYPES) {
nss_warning("%p: received invalid message %d for IPv6 interface", nss_ctx, nim->cm.type);
return;
}
@@ -151,7 +150,7 @@
* Update driver statistics on connection sync.
*/
nss_ipv6_driver_conn_sync_update(nss_ctx, &nim->msg.conn_stats);
- return nss_rx_ipv6_sync(nss_ctx, &nim->msg.conn_stats);
+ nss_rx_ipv6_sync(nss_ctx, &nim->msg.conn_stats);
break;
case NSS_IPV6_TX_CREATE_RULE_MSG:
@@ -207,7 +206,7 @@
return NSS_TX_FAILURE;
}
- if (ncm->type > NSS_IPV6_MAX_MSG_TYPES) {
+ if (ncm->type >= NSS_IPV6_MAX_MSG_TYPES) {
nss_warning("%p: message type out of range: %d", nss_ctx, ncm->type);
return NSS_TX_FAILURE;
}