From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from dpdk.org (dpdk.org [92.243.14.124]) by inbox.dpdk.org (Postfix) with ESMTP id 7B973A04B6; Tue, 22 Sep 2020 14:42:37 +0200 (CEST) Received: from [92.243.14.124] (localhost [127.0.0.1]) by dpdk.org (Postfix) with ESMTP id DA5D81D63A; Tue, 22 Sep 2020 14:42:36 +0200 (CEST) Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [216.205.24.124]) by dpdk.org (Postfix) with ESMTP id 0A1F91D612 for ; Tue, 22 Sep 2020 14:42:34 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1600778554; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=cFKrsnbrBziwfDDL8NdBLoG1xAFiXnZr+gf9q5YhvXg=; b=bZd6mbcP4hS26FikXtTlSfP+yT5766cXSNSver1m8y7JpyxgaCT8XSgeGqC1UVDL+/vd7T 3A5siNw06PXgDIbbj/FPTcd+Jg443ayfqv2TyLws1F37MTmlXQqaPfgPrOoMIHL59VkYZu CTsRnaUVJYEyHimuu+itmEDoCvSD4BY= Received: from mail-vs1-f71.google.com (mail-vs1-f71.google.com [209.85.217.71]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-515-592cyaTCMzaNI0m4Ye2J0g-1; Tue, 22 Sep 2020 08:42:32 -0400 X-MC-Unique: 592cyaTCMzaNI0m4Ye2J0g-1 Received: by mail-vs1-f71.google.com with SMTP id j9so2072594vsf.5 for ; Tue, 22 Sep 2020 05:42:32 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=cFKrsnbrBziwfDDL8NdBLoG1xAFiXnZr+gf9q5YhvXg=; b=W7mM6GVvzdD8KcfEPNVJkPYl3tkc8R4rH67gl1Yk6vHB3Php17Gbpmv/XAywhRYgBN nz388Dgd8+PGUD8ntqPjY+fqmSnbe3sEUgeVM8fV3jsj2EvcA5Hpe1/7mmka/vVvXn1c ch2B0EO40bODzhE31uNfbP11Eanu5RQV/Pp1qNsuF9ZVozSTVXJkiWUg53fo5HGh+g/8 WUE4QCtftp5aL8+QI2vFQKUpVA7oht3SV6Wm2Uob1c3T7OkobJpfFzP9vc1I3V0vOx8q 0hqKhR0LVDyS6LDBLpPTt16+HiI62z7Hf8JlRlLDFBQI0NT1j6mj2RgLmKPlOOmqOAF1 O6/A== X-Gm-Message-State: AOAM533EJS7C0yDR1LturGk+PVUQlxlpnNTtXSYr5eCQ7dUAqxZ9lCT4 G7+xN5sxJtVT7uHTLUEEf3npkr24g1sa9rI+QkyOaDxqUWGD8+dVL4r7w+F+r9TiBG0SNaKO1z3 AV6g2FUhd/NoaYmZIhP8= X-Received: by 2002:a05:6102:10c2:: with SMTP id t2mr3001223vsr.10.1600778552324; Tue, 22 Sep 2020 05:42:32 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy0WYQRVOX8thaTm4IDePBrJvVrcYJsd7xIzUXG0au8IGD8mebqg/9ErSWksCyi+aqyi60OvfbBpVyZXc25QTs= X-Received: by 2002:a05:6102:10c2:: with SMTP id t2mr3001208vsr.10.1600778552018; Tue, 22 Sep 2020 05:42:32 -0700 (PDT) MIME-Version: 1.0 References: <20200915193449.13310-1-l.wojciechow@partner.samsung.com> <20200915193449.13310-4-l.wojciechow@partner.samsung.com> In-Reply-To: <20200915193449.13310-4-l.wojciechow@partner.samsung.com> From: David Marchand Date: Tue, 22 Sep 2020 14:42:21 +0200 Message-ID: To: Lukasz Wojciechowski , David Hunt Cc: Bruce Richardson , dev , dpdk stable Authentication-Results: relay.mimecast.com; auth=pass smtp.auth=CUSA124A263 smtp.mailfrom=dmarchan@redhat.com X-Mimecast-Spam-Score: 0 X-Mimecast-Originator: redhat.com Content-Type: text/plain; charset="UTF-8" Subject: Re: [dpdk-dev] [PATCH v1 3/6] app/test: fix freeing mbufs in distributor tests X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Sender: "dev" Hello Lukasz, David, On Tue, Sep 15, 2020 at 9:35 PM Lukasz Wojciechowski wrote: > diff --git a/app/test/test_distributor.c b/app/test/test_distributor.c > index 0e49e3714..da13a9a3f 100644 > --- a/app/test/test_distributor.c > +++ b/app/test/test_distributor.c > @@ -277,24 +277,21 @@ handle_work_with_free_mbufs(void *arg) > struct rte_mbuf *buf[8] __rte_cache_aligned; > struct worker_params *wp = arg; > struct rte_distributor *d = wp->dist; > - unsigned int count = 0; > unsigned int i; > unsigned int num = 0; > unsigned int id = __atomic_fetch_add(&worker_idx, 1, __ATOMIC_RELAXED); > > for (i = 0; i < 8; i++) > buf[i] = NULL; > - num = rte_distributor_get_pkt(d, id, buf, buf, num); > + num = rte_distributor_get_pkt(d, id, buf, buf, 0); For my understanding, we pass an array even if we return 0 packet. Is this necessary? > while (!quit) { > - count += num; > __atomic_fetch_add(&worker_stats[id].handled_packets, num, > __ATOMIC_ACQ_REL); > for (i = 0; i < num; i++) > rte_pktmbuf_free(buf[i]); > num = rte_distributor_get_pkt(d, > - id, buf, buf, num); > + id, buf, buf, 0); Here, it gives the impression we have some potential use-after-free on buf[] content. And trying to pass NULL, I can see the distributor library dereferences oldpkt[] without checking retcount != 0. -- David Marchand