Received: by 2002:a25:c593:0:0:0:0:0 with SMTP id v141csp692998ybe; Mon, 2 Sep 2019 07:47:22 -0700 (PDT) X-Google-Smtp-Source: APXvYqwq/H8toqBviPPEcn5fSf5uLvshpQkgCPI9WnNlY6TMwcDjyzEXdCCOXW3B8wrYqkiZ4zwU X-Received: by 2002:a17:902:1e3:: with SMTP id b90mr30742886plb.82.1567435642094; Mon, 02 Sep 2019 07:47:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1567435642; cv=none; d=google.com; s=arc-20160816; b=CmySbU4gaUN/LakGgTnO45GbJyDY3qkYlXNBCNT4cryO3OBdg+1nDKQlylTd3X45UL 3XYmpwwvTmg9JnpdVBHfvAEW9Rm55a+HRGbbX8ppxM20Xx0NAKfNTwNvpKqGykC/0rPK HPHYTY05y9SxDAEQ2W1XRgq6YeIgfXbuPded5D/OF7xUcfnchfaMINCjCUKQdyajpw0N VkkDbveDW0pVVOyUbrK7umgqrqFRh0XK16pe22zih0pZYeIqOw/u2MbJBuPTeuMnGmJn eslb8w3KbYRYoCfC3QVrqGpyhlJpSBbIjBIVeK4kHKXx0B3SsVAQdChvOmhulo7QUq3A ebcQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :organization:references:in-reply-to:message-id:subject:cc:to:from :date; bh=oEFTcH81Lp9c0TQQyK6gSgklHVrwe2CjyZ1QUS+fwdY=; b=Ji7ynEpEgtvtrDG0Tg48HjzQpaIpWylKJ3FWoLqGtMM1XrA31X7tNpr7xSUNc4RJkP ACb6bubwyT1fDHi0hAYP0PgSY7ejXpPa/VrEaP0A7K4UOgrx7vXQuy95+HBKrCLNmPc+ dW7cuxU2lTCQ7kURILw9TT7vZOSTb/3GQd/Q1lucDLTLleyMeeYbtK0zEkO2bPtm+bcB cnF9hK0hau4dw0bzh84p/hbVPk7hYQxYsvNrPbcWY2e1Af7VNPnN7A9QCnAzvq5hwcta d74xJ4xCC1eaN2EcwPpLpiOeBaMQdmeXUBSfOiQ6b0Kqd7wcOODfdQ+emEhiuNwYGa2L 8hSw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id e10si12585905pjw.30.2019.09.02.07.47.06; Mon, 02 Sep 2019 07:47:22 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731698AbfIBOqL (ORCPT + 99 others); Mon, 2 Sep 2019 10:46:11 -0400 Received: from mx1.redhat.com ([209.132.183.28]:60948 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726382AbfIBOqL (ORCPT ); Mon, 2 Sep 2019 10:46:11 -0400 Received: from smtp.corp.redhat.com (int-mx08.intmail.prod.int.phx2.redhat.com [10.5.11.23]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 907FF10F23ED; Mon, 2 Sep 2019 14:46:10 +0000 (UTC) Received: from gondolin (dhcp-192-222.str.redhat.com [10.33.192.222]) by smtp.corp.redhat.com (Postfix) with ESMTP id 02F89196B2; Mon, 2 Sep 2019 14:46:06 +0000 (UTC) Date: Mon, 2 Sep 2019 16:46:04 +0200 From: Cornelia Huck To: Parav Pandit Cc: "alex.williamson@redhat.com" , Jiri Pirko , "kwankhede@nvidia.com" , "davem@davemloft.net" , "kvm@vger.kernel.org" , "linux-kernel@vger.kernel.org" , "netdev@vger.kernel.org" Subject: Re: [PATCH v2 1/6] mdev: Introduce sha1 based mdev alias Message-ID: <20190902164604.1d04614f.cohuck@redhat.com> In-Reply-To: References: <20190826204119.54386-1-parav@mellanox.com> <20190829111904.16042-1-parav@mellanox.com> <20190829111904.16042-2-parav@mellanox.com> <20190830111720.04aa54e9.cohuck@redhat.com> <20190830143927.163d13a7.cohuck@redhat.com> <20190830160223.332fd81f.cohuck@redhat.com> Organization: Red Hat GmbH MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit X-Scanned-By: MIMEDefang 2.84 on 10.5.11.23 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.6.2 (mx1.redhat.com [10.5.110.66]); Mon, 02 Sep 2019 14:46:10 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, 30 Aug 2019 15:45:13 +0000 Parav Pandit wrote: > > > > > > This detour via the local variable looks weird to me. Can you > > > > > > either create the alias directly in the mdev (would need to > > > > > > happen later in the function, but I'm not sure why you generate > > > > > > the alias before checking for duplicates anyway), or do an explicit copy? > > > > > Alias duplicate check is done after generating it, because > > > > > duplicate alias are > > > > not allowed. > > > > > The probability of collision is rare. > > > > > So it is speculatively generated without hold the lock, because > > > > > there is no > > > > need to hold the lock. > > > > > It is compared along with guid while mutex lock is held in single loop. > > > > > And if it is duplicate, there is no need to allocate mdev. > > > > > > > > > > It will be sub optimal to run through the mdev list 2nd time after > > > > > mdev > > > > creation and after generating alias for duplicate check. > > > > > > > > Ok, but what about copying it? I find this "set local variable to > > > > NULL after ownership is transferred" pattern a bit unintuitive. > > > > Copying it to the mdev (and then unconditionally freeing it) looks more > > obvious to me. > > > Its not unconditionally freed. > > > > That's not what I have been saying :( > > > Ah I see. You want to allocate alias memory twice; once inside mdev device and another one in _create() function. > _create() one you want to free unconditionally. > > Well, passing pointer is fine. It's not that it doesn't work, but it feels fragile due to its non-obviousness. > mdev_register_device() has similar little tricky pattern that makes parent = NULL on __find_parent_device() finds duplicate one. I don't think that the two are comparable. > > Ownership transfer is more straight forward code. I have to disagree here. > > It is similar to device_initialize(), device init sequence code, where once device_initialize is done, freeing the device memory will be left to the put_device(), we don't call kfree() on mdev device. This does not really look similar to me: devices are refcounted structures, while strings aren't; you transfer a local pointer to a refcounted structure and then discard the local reference.