From 50488ac8f38b439dcfc389ccce1a9ea13b785099 Mon Sep 17 00:00:00 2001 From: zhanghongyu Date: Thu, 23 Mar 2023 11:58:00 +0800 Subject: [PATCH] sim: multi netdevice forward issue when ll_guardsize not 14 Signed-off-by: zhanghongyu --- arch/sim/src/sim/sim_netdriver.c | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/arch/sim/src/sim/sim_netdriver.c b/arch/sim/src/sim/sim_netdriver.c index 68ffaa2ae9..d932955a60 100644 --- a/arch/sim/src/sim/sim_netdriver.c +++ b/arch/sim/src/sim/sim_netdriver.c @@ -77,7 +77,7 @@ * when netpkt's buffer is long enough. */ -#if NETPKT_BUFLEN >= SIM_NETDEV_BUFSIZE +#if NETPKT_BUFLEN - CONFIG_NET_LL_GUARDSIZE >= SIM_NETDEV_BUFSIZE - ETH_HDRLEN # define SIM_NETDEV_RECV_OFFLOAD #endif @@ -160,7 +160,7 @@ static netpkt_t *netdriver_recv(struct netdev_lowerhalf_s *dev) */ #ifdef SIM_NETDEV_RECV_OFFLOAD - len = sim_netdev_read(DEVIDX(dev), netpkt_getbase(pkt), + len = sim_netdev_read(DEVIDX(dev), netpkt_getdata(dev, pkt), SIM_NETDEV_BUFSIZE); #else len = sim_netdev_read(DEVIDX(dev), DEVBUF(dev), SIM_NETDEV_BUFSIZE); @@ -172,7 +172,6 @@ static netpkt_t *netdriver_recv(struct netdev_lowerhalf_s *dev) } #ifdef SIM_NETDEV_RECV_OFFLOAD - netpkt_reset_reserved(dev, pkt, 0); /* No overhead before data. */ netpkt_setdatalen(dev, pkt, len); #else netpkt_copyin(dev, pkt, DEVBUF(dev), len, 0);