[PATCH 13/17] test: dm: eth: Add csum_ipv6_magic test
Simon Glass
sjg at chromium.org
Thu Sep 1 04:27:18 CEST 2022
Hi Viacheslav,
On Tue, 30 Aug 2022 at 07:03, Viacheslav Mitrofanov
<v.v.mitrofanov at yadro.com> wrote:
>
> Test checksum computation. csum_ipv6_magic() uses in upper layer
> protocols as TCP/UDP/ICMPv6/etc to calculate payload checksum.
>
> Signed-off-by: Viacheslav Mitrofanov <v.v.mitrofanov at yadro.com>
> ---
> test/dm/eth.c | 29 +++++++++++++++++++++++++++++
> 1 file changed, 29 insertions(+)
Reviewed-by: Simon Glass <sjg at chromium.org>
>
> diff --git a/test/dm/eth.c b/test/dm/eth.c
> index 4cc90cf514..bbfa14ef6d 100644
> --- a/test/dm/eth.c
> +++ b/test/dm/eth.c
> @@ -70,6 +70,35 @@ static int dm_test_string_to_ip6(struct unit_test_state *uts)
> }
> DM_TEST(dm_test_string_to_ip6, 0);
>
> +static int dm_test_csum_ipv6_magic(struct unit_test_state *uts)
> +{
> + unsigned short csum = 0xBEEF;
lower-case hex consistently
> + /* Predefined correct parameters */
> + unsigned short correct_csum = 0xD8AC;
> + struct in6_addr saddr = {.s6_addr32[0] = 0x000080fe,
> + .s6_addr32[1] = 0x00000000,
> + .s6_addr32[2] = 0xffe9f242,
> + .s6_addr32[3] = 0xe8f66dfe};
> + struct in6_addr daddr = {.s6_addr32[0] = 0x000080fe,
> + .s6_addr32[1] = 0x00000000,
> + .s6_addr32[2] = 0xffd5b372,
> + .s6_addr32[3] = 0x3ef692fe};
> + u16 len = 1460;
> + unsigned short proto = 17;
> + unsigned int head_csum = 0x91f0;
> +
> + csum = csum_ipv6_magic(&saddr, &daddr, len, proto, head_csum);
> + ut_assert(csum == correct_csum);
ut_asserteq
> +
> + /* Broke a parameter */
> + proto--;
> + csum = csum_ipv6_magic(&saddr, &daddr, len, proto, head_csum);
> + ut_assert(csum != correct_csum);
> +
> + return 0;
> +}
> +DM_TEST(dm_test_csum_ipv6_magic, 0);
> +
> static int dm_test_eth(struct unit_test_state *uts)
> {
> net_ping_ip = string_to_ip("1.1.2.2");
> --
> 2.25.1
>
Regards,
Simon
More information about the U-Boot
mailing list