From mboxrd@z Thu Jan 1 00:00:00 1970 From: David Marchand Subject: Re: [PATCH 2/2] virtio: change io privilege level as early as possible Date: Wed, 30 Sep 2015 10:28:53 +0200 Message-ID: References: <1425912999-13118-1-git-send-email-david.marchand@6wind.com> <1425912999-13118-3-git-send-email-david.marchand@6wind.com> <20150310131428.GB7873@hmsreliant.think-freely.org> <20150929122542.419781cc@urahara> Mime-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Cc: "dev@dpdk.org" To: Stephen Hemminger Return-path: Received: from mail-oi0-f52.google.com (mail-oi0-f52.google.com [209.85.218.52]) by dpdk.org (Postfix) with ESMTP id 669448D91 for ; Wed, 30 Sep 2015 10:28:54 +0200 (CEST) Received: by oixx17 with SMTP id x17so18240240oix.0 for ; Wed, 30 Sep 2015 01:28:53 -0700 (PDT) In-Reply-To: <20150929122542.419781cc@urahara> List-Id: patches and discussions about DPDK List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Sender: "dev" On Tue, Sep 29, 2015 at 9:25 PM, Stephen Hemminger < stephen@networkplumber.org> wrote: > On Tue, 10 Mar 2015 09:14:28 -0400 > Neil Horman wrote: > > > > > I don't see how this works for all cases. The constructor is called > once when > > the library is first loaded. What if you have multiple independent > (i.e. not > > forked children) processes that are using the dpdk in parallel? Only the > > process that triggered the library load will have io permissions set > > appropriately. I think what you need is to have every application that > expects > > to call through the transmit path or poll the receive path call iopl, > which I > > think speaks to having this requirement documented, so each application > can call > > iopl prior to calling fork/daemonize/etc. > > > > I am still seeing this problem with DPDK 2.0 and 2.1. > It seems to me that doing the iopl init in eal_init is the only safe way. > Other workaround is to have application calling iopl_init before eal_init > but that kind of violates the current method of all things being > initialized > by eal_init > Putting it in the virtio pmd constructor is my preferred solution and we don't need to pollute the eal for virtio (specific to x86, btw). -- David Marchand