[U-Boot] [PATCH 1/4] net: Always align tx packets

Joe Hershberger joe.hershberger at ni.com
Thu Mar 29 03:50:01 UTC 2018


On Wed, Mar 28, 2018 at 7:38 AM, Mario Six <mario.six at gdsys.cc> wrote:
> Make sure that TX packets are always cache-aligned.
>
> Signed-off-by: Mario Six <mario.six at gdsys.cc>
> ---
>  net/arp.c  | 3 ++-
>  net/ping.c | 3 ++-
>  2 files changed, 4 insertions(+), 2 deletions(-)
>
> diff --git a/net/arp.c b/net/arp.c
> index 4c79e09ccb..191434f5e2 100644
> --- a/net/arp.c
> +++ b/net/arp.c
> @@ -182,7 +182,8 @@ void arp_receive(struct ethernet_hdr *et, struct ip_udp_hdr *ip, int len)
>                     (net_read_ip(&arp->ar_spa).s_addr & net_netmask.s_addr))
>                         udelay(5000);
>  #endif
> -               net_send_packet((uchar *)et, eth_hdr_size + ARP_HDR_SIZE);
> +               memcpy(net_tx_packet, et, eth_hdr_size + ARP_HDR_SIZE);
> +               net_send_packet(net_tx_packet, eth_hdr_size + ARP_HDR_SIZE);

Rather than always incurring a copy here, why not have the device
driver that requires this do the copy?

>                 return;
>
>         case ARPOP_REPLY:               /* arp reply */
> diff --git a/net/ping.c b/net/ping.c
> index 9508cf1160..db14209bf6 100644
> --- a/net/ping.c
> +++ b/net/ping.c
> @@ -107,7 +107,8 @@ void ping_receive(struct ethernet_hdr *et, struct ip_udp_hdr *ip, int len)
>                 icmph->type = ICMP_ECHO_REPLY;
>                 icmph->checksum = 0;
>                 icmph->checksum = compute_ip_checksum(icmph, len - IP_HDR_SIZE);
> -               net_send_packet((uchar *)et, eth_hdr_size + len);
> +               memcpy(net_tx_packet, et, eth_hdr_size + len);
> +               net_send_packet(net_tx_packet, eth_hdr_size + len);
>                 return;
>  /*     default:
>                 return;*/
> --
> 2.16.1
>
> _______________________________________________
> U-Boot mailing list
> U-Boot at lists.denx.de
> https://lists.denx.de/listinfo/u-boot


More information about the U-Boot mailing list