2012-05-03 18:11:23 +00:00
|
|
|
#include "test_pbuf.h"
|
|
|
|
|
|
|
|
#include "lwip/pbuf.h"
|
|
|
|
#include "lwip/stats.h"
|
|
|
|
|
|
|
|
#if !LWIP_STATS || !MEM_STATS ||!MEMP_STATS
|
|
|
|
#error "This tests needs MEM- and MEMP-statistics enabled"
|
|
|
|
#endif
|
|
|
|
#if LWIP_DNS
|
|
|
|
#error "This test needs DNS turned off (as it mallocs on init)"
|
|
|
|
#endif
|
2014-02-12 20:34:19 +00:00
|
|
|
#if !LWIP_TCP || !TCP_QUEUE_OOSEQ || !LWIP_WND_SCALE
|
|
|
|
#error "This test needs TCP OOSEQ queueing and window scaling enabled"
|
|
|
|
#endif
|
2012-05-03 18:11:23 +00:00
|
|
|
|
|
|
|
/* Setups/teardown functions */
|
|
|
|
|
|
|
|
static void
|
|
|
|
pbuf_setup(void)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
pbuf_teardown(void)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-02-12 20:34:19 +00:00
|
|
|
#define TESTBUFSIZE_1 65535
|
|
|
|
#define TESTBUFSIZE_2 65530
|
|
|
|
#define TESTBUFSIZE_3 50050
|
|
|
|
static u8_t testbuf_1[TESTBUFSIZE_1];
|
|
|
|
static u8_t testbuf_1a[TESTBUFSIZE_1];
|
|
|
|
static u8_t testbuf_2[TESTBUFSIZE_2];
|
|
|
|
static u8_t testbuf_2a[TESTBUFSIZE_2];
|
|
|
|
static u8_t testbuf_3[TESTBUFSIZE_3];
|
|
|
|
static u8_t testbuf_3a[TESTBUFSIZE_3];
|
|
|
|
|
2012-05-03 18:11:23 +00:00
|
|
|
/* Test functions */
|
|
|
|
|
|
|
|
/** Call pbuf_copy on a pbuf with zero length */
|
|
|
|
START_TEST(test_pbuf_copy_zero_pbuf)
|
|
|
|
{
|
|
|
|
struct pbuf *p1, *p2, *p3;
|
|
|
|
err_t err;
|
|
|
|
LWIP_UNUSED_ARG(_i);
|
|
|
|
|
|
|
|
fail_unless(lwip_stats.mem.used == 0);
|
|
|
|
fail_unless(lwip_stats.memp[MEMP_PBUF_POOL].used == 0);
|
|
|
|
|
|
|
|
p1 = pbuf_alloc(PBUF_RAW, 1024, PBUF_RAM);
|
|
|
|
fail_unless(p1 != NULL);
|
|
|
|
fail_unless(p1->ref == 1);
|
|
|
|
|
|
|
|
p2 = pbuf_alloc(PBUF_RAW, 2, PBUF_POOL);
|
|
|
|
fail_unless(p2 != NULL);
|
|
|
|
fail_unless(p2->ref == 1);
|
|
|
|
p2->len = p2->tot_len = 0;
|
|
|
|
|
|
|
|
pbuf_cat(p1, p2);
|
|
|
|
fail_unless(p1->ref == 1);
|
|
|
|
fail_unless(p2->ref == 1);
|
|
|
|
|
|
|
|
p3 = pbuf_alloc(PBUF_RAW, p1->tot_len, PBUF_POOL);
|
|
|
|
err = pbuf_copy(p3, p1);
|
|
|
|
fail_unless(err == ERR_VAL);
|
|
|
|
|
|
|
|
pbuf_free(p1);
|
|
|
|
pbuf_free(p3);
|
|
|
|
fail_unless(lwip_stats.mem.used == 0);
|
|
|
|
|
|
|
|
fail_unless(lwip_stats.mem.used == 0);
|
|
|
|
fail_unless(lwip_stats.memp[MEMP_PBUF_POOL].used == 0);
|
|
|
|
}
|
|
|
|
END_TEST
|
|
|
|
|
2014-02-12 20:34:19 +00:00
|
|
|
START_TEST(test_pbuf_split_64k_on_small_pbufs)
|
|
|
|
{
|
|
|
|
struct pbuf *p, *rest=NULL;
|
|
|
|
LWIP_UNUSED_ARG(_i);
|
|
|
|
|
|
|
|
p = pbuf_alloc(PBUF_RAW, 1, PBUF_POOL);
|
|
|
|
pbuf_split_64k(p, &rest);
|
|
|
|
fail_unless(p->tot_len == 1);
|
|
|
|
pbuf_free(p);
|
|
|
|
}
|
|
|
|
END_TEST
|
|
|
|
|
|
|
|
START_TEST(test_pbuf_queueing_bigger_than_64k)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
err_t err;
|
|
|
|
struct pbuf *p1, *p2, *p3, *rest2=NULL, *rest3=NULL;
|
|
|
|
LWIP_UNUSED_ARG(_i);
|
|
|
|
|
|
|
|
for(i = 0; i < TESTBUFSIZE_1; i++)
|
|
|
|
testbuf_1[i] = rand();
|
|
|
|
for(i = 0; i < TESTBUFSIZE_2; i++)
|
|
|
|
testbuf_2[i] = rand();
|
|
|
|
for(i = 0; i < TESTBUFSIZE_3; i++)
|
|
|
|
testbuf_3[i] = rand();
|
|
|
|
|
|
|
|
p1 = pbuf_alloc(PBUF_RAW, TESTBUFSIZE_1, PBUF_POOL);
|
|
|
|
fail_unless(p1 != NULL);
|
|
|
|
p2 = pbuf_alloc(PBUF_RAW, TESTBUFSIZE_2, PBUF_POOL);
|
|
|
|
fail_unless(p2 != NULL);
|
|
|
|
p3 = pbuf_alloc(PBUF_RAW, TESTBUFSIZE_3, PBUF_POOL);
|
|
|
|
fail_unless(p3 != NULL);
|
|
|
|
err = pbuf_take(p1, testbuf_1, TESTBUFSIZE_1);
|
|
|
|
fail_unless(err == ERR_OK);
|
|
|
|
err = pbuf_take(p2, testbuf_2, TESTBUFSIZE_2);
|
|
|
|
fail_unless(err == ERR_OK);
|
|
|
|
err = pbuf_take(p3, testbuf_3, TESTBUFSIZE_3);
|
|
|
|
fail_unless(err == ERR_OK);
|
|
|
|
|
|
|
|
pbuf_cat(p1, p2);
|
|
|
|
pbuf_cat(p1, p3);
|
|
|
|
|
|
|
|
pbuf_split_64k(p1, &rest2);
|
|
|
|
fail_unless(p1->tot_len == TESTBUFSIZE_1);
|
|
|
|
fail_unless(rest2->tot_len == (u16_t)((TESTBUFSIZE_2+TESTBUFSIZE_3) & 0xFFFF));
|
|
|
|
pbuf_split_64k(rest2, &rest3);
|
|
|
|
fail_unless(rest2->tot_len == TESTBUFSIZE_2);
|
|
|
|
fail_unless(rest3->tot_len == TESTBUFSIZE_3);
|
|
|
|
|
|
|
|
pbuf_copy_partial(p1, testbuf_1a, TESTBUFSIZE_1, 0);
|
|
|
|
pbuf_copy_partial(rest2, testbuf_2a, TESTBUFSIZE_2, 0);
|
|
|
|
pbuf_copy_partial(rest3, testbuf_3a, TESTBUFSIZE_3, 0);
|
|
|
|
for(i = 0; i < TESTBUFSIZE_1; i++)
|
|
|
|
fail_unless(testbuf_1[i] == testbuf_1a[i]);
|
|
|
|
for(i = 0; i < TESTBUFSIZE_2; i++)
|
|
|
|
fail_unless(testbuf_2[i] == testbuf_2a[i]);
|
|
|
|
for(i = 0; i < TESTBUFSIZE_3; i++)
|
|
|
|
fail_unless(testbuf_3[i] == testbuf_3a[i]);
|
|
|
|
|
|
|
|
pbuf_free(p1);
|
|
|
|
pbuf_free(rest2);
|
|
|
|
pbuf_free(rest3);
|
|
|
|
}
|
|
|
|
END_TEST
|
2012-05-03 18:11:23 +00:00
|
|
|
|
|
|
|
/** Create the suite including all tests for this module */
|
|
|
|
Suite *
|
|
|
|
pbuf_suite(void)
|
|
|
|
{
|
|
|
|
TFun tests[] = {
|
2014-02-12 20:34:19 +00:00
|
|
|
test_pbuf_copy_zero_pbuf,
|
|
|
|
test_pbuf_split_64k_on_small_pbufs,
|
|
|
|
test_pbuf_queueing_bigger_than_64k
|
2012-05-03 18:11:23 +00:00
|
|
|
};
|
|
|
|
return create_suite("PBUF", tests, sizeof(tests)/sizeof(TFun), pbuf_setup, pbuf_teardown);
|
|
|
|
}
|