From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mail-wi0-f179.google.com (mail-wi0-f179.google.com [209.85.212.179]) by dpdk.org (Postfix) with ESMTP id 45D24C3C2 for ; Tue, 21 Apr 2015 11:55:57 +0200 (CEST) Received: by wizk4 with SMTP id k4so132508717wiz.1 for ; Tue, 21 Apr 2015 02:55:57 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20130820; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=Hh9FB6ZGnOepYpzDDJL6POC/csVzKeiHDV43kfAqW4M=; b=KbyuLwjiud4OflZmRolWVOfRn0Kt+nBUrHT0gdnbdlz8zBNB+CZtpdTZxvM7vg5Vev dm+k0TcB/UaW+eR81kiFa1UtSAxAK2dwmlsfvLLHruc8z7yyXgwC65dz9uSgyq0TKatZ aXHYstVuJR4gbXXkwB1/iUsefftR3gLHu26QB8zN6lZ3OOH9Ag9F4j/Rf7tmBnRM356K IVIZqa/f7fiADWhJzHg3GBhQwFuP+m3Zh3EJn2ecDGySl8yHm2k75I9uqx5VzS0m7ObP F92cPgIfdzr75Bf3cDHSMP5FFKapov06XQ72ebEpdEhx0DCBkR3rjGjVB84eWKgSlIrl tI+w== X-Gm-Message-State: ALoCoQlKtpSgF9VdN6S5ij3OiNQN9tGVfot7E4n9Thxo4NsMr+Ly6AJ73v/InLnPYrQC97Xm4goH X-Received: by 10.194.47.231 with SMTP id g7mr38655606wjn.140.1429610157177; Tue, 21 Apr 2015 02:55:57 -0700 (PDT) Received: from glumotte.dev.6wind.com (6wind.net2.nerim.net. [213.41.180.237]) by mx.google.com with ESMTPSA id i6sm1855867wjf.29.2015.04.21.02.55.56 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Tue, 21 Apr 2015 02:55:56 -0700 (PDT) From: Olivier Matz To: dev@dpdk.org Date: Tue, 21 Apr 2015 11:55:21 +0200 Message-Id: <1429610122-30943-12-git-send-email-olivier.matz@6wind.com> X-Mailer: git-send-email 2.1.4 In-Reply-To: <1429610122-30943-1-git-send-email-olivier.matz@6wind.com> References: <1429544496-22532-1-git-send-email-olivier.matz@6wind.com> <1429610122-30943-1-git-send-email-olivier.matz@6wind.com> Subject: [dpdk-dev] [PATCH v5 11/12] test/mbuf: enhance mbuf refcnt test X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: patches and discussions about DPDK List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 21 Apr 2015 09:55:57 -0000 Check that the data in the cloned mbuf is the same than in the reference mbuf. Check that the reference counter is incremented for each segment. Signed-off-by: Olivier Matz --- app/test/test_mbuf.c | 37 +++++++++++++++++++++++++++++++++++++ 1 file changed, 37 insertions(+) diff --git a/app/test/test_mbuf.c b/app/test/test_mbuf.c index 2614598..01838c6 100644 --- a/app/test/test_mbuf.c +++ b/app/test/test_mbuf.c @@ -75,6 +75,8 @@ #define REFCNT_MBUF_NUM 64 #define REFCNT_RING_SIZE (REFCNT_MBUF_NUM * REFCNT_MAX_REF) +#define MAGIC_DATA 0x42424242 + #define MAKE_STRING(x) # x static struct rte_mempool *pktmbuf_pool = NULL; @@ -322,6 +324,7 @@ testclone_testupdate_testdetach(void) { struct rte_mbuf *m = NULL; struct rte_mbuf *clone = NULL; + uint32_t *data; /* alloc a mbuf */ m = rte_pktmbuf_alloc(pktmbuf_pool); @@ -331,21 +334,53 @@ testclone_testupdate_testdetach(void) if (rte_pktmbuf_pkt_len(m) != 0) GOTO_FAIL("Bad length"); + rte_pktmbuf_append(m, sizeof(uint32_t)); + data = rte_pktmbuf_mtod(m, uint32_t *); + *data = MAGIC_DATA; /* clone the allocated mbuf */ clone = rte_pktmbuf_clone(m, pktmbuf_pool); if (clone == NULL) GOTO_FAIL("cannot clone data\n"); + + data = rte_pktmbuf_mtod(clone, uint32_t *); + if (*data != MAGIC_DATA) + GOTO_FAIL("invalid data in clone\n"); + + if (rte_mbuf_refcnt_read(m) != 2) + GOTO_FAIL("invalid refcnt in m\n"); + + /* free the clone */ rte_pktmbuf_free(clone); + clone = NULL; + /* same test with a chained mbuf */ m->next = rte_pktmbuf_alloc(pktmbuf_pool); if (m->next == NULL) GOTO_FAIL("Next Pkt Null\n"); + rte_pktmbuf_append(m->next, sizeof(uint32_t)); + data = rte_pktmbuf_mtod(m->next, uint32_t *); + *data = MAGIC_DATA; + clone = rte_pktmbuf_clone(m, pktmbuf_pool); if (clone == NULL) GOTO_FAIL("cannot clone data\n"); + data = rte_pktmbuf_mtod(clone, uint32_t *); + if (*data != MAGIC_DATA) + GOTO_FAIL("invalid data in clone\n"); + + data = rte_pktmbuf_mtod(clone->next, uint32_t *); + if (*data != MAGIC_DATA) + GOTO_FAIL("invalid data in clone->next\n"); + + if (rte_mbuf_refcnt_read(m) != 2) + GOTO_FAIL("invalid refcnt in m\n"); + + if (rte_mbuf_refcnt_read(m->next) != 2) + GOTO_FAIL("invalid refcnt in m->next\n"); + /* free mbuf */ rte_pktmbuf_free(m); rte_pktmbuf_free(clone); @@ -356,6 +391,8 @@ testclone_testupdate_testdetach(void) fail: if (m) rte_pktmbuf_free(m); + if (clone) + rte_pktmbuf_free(clone); return -1; } #undef GOTO_FAIL -- 2.1.4