Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp7157921ybi; Mon, 8 Jul 2019 15:49:38 -0700 (PDT) X-Google-Smtp-Source: APXvYqwEQELDyt0o+AFi6DZCBu7veku50fhJh+qTARJf+G3Li5EIsxkAPEL0So+XurnpUzRMhf00 X-Received: by 2002:a17:902:70c3:: with SMTP id l3mr20730445plt.92.1562626177966; Mon, 08 Jul 2019 15:49:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1562626177; cv=none; d=google.com; s=arc-20160816; b=npOxeY1PSE5KTiVXU9G+AKaQrORNkz8aFTYgNsxCfjn0h2zU51nEhXqgv3Y10rLHsr NnSK7P7P77sMjuHn02pqmZ59la9sPsxECZ/wZQfHYxnehxe8tJIaF8Pc7XBEmUGG5AJB fFuXSUQxjL6442hR9JJQfmBenhbKGwIAbXhRIYbpW+6PtaEz6OSH85Y+aq/q5mKo8+34 9hpBGuBbAS4pWTu4A4v63/V8BatXW2L7lrVr2gDCm/dQz3iY4c0OQQyetgCgeNVPY9ou bUPP+XuLKtWnCEK0ftRzQbr6J/BJgZCy0FZdhQHW+nC8OlN85J+s0mqIZlJu24urGwL3 nY7Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=m2l1BuVm+BVCPf/vP9mLjZQgXBRaW/She7CJyqnRx4A=; b=QHhAPnZG3ZrBWwBEzIJXWuiHdrfUNENPYAArqhTvEQdnI2EK+DmNQh+KjCXxgojVhN +dwPAR2re81MyW7em0HjsvWbkN5rW6V65sr0B47zCxIQxB27BtQltjOHL3x+Hsob1+IA m3H0W8K7q105afiDiX8gWNFhCtD9bX9CIaBNb8qIo0kDZ+2Vlm7NyWr9KhEdzFjsXcqA 6Yn91cHqJ33XJ3NUujPefNz1andj7aosehQodbBIVo1UJAc84ePpGJOTD9M3FCrVhIMJ fimPJTlVlCcLxOPdLiN59kfdP2Y40mJzPA9a27fQLEgzjNvyY3h2HETCCDlU81KxDJmU eFOA== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h18si723466pjt.9.2019.07.08.15.49.23; Mon, 08 Jul 2019 15:49:37 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2404965AbfGHUWY (ORCPT + 99 others); Mon, 8 Jul 2019 16:22:24 -0400 Received: from mx2.suse.de ([195.135.220.15]:45638 "EHLO mx1.suse.de" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1725869AbfGHUWY (ORCPT ); Mon, 8 Jul 2019 16:22:24 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.220.254]) by mx1.suse.de (Postfix) with ESMTP id E1050AD85; Mon, 8 Jul 2019 20:22:21 +0000 (UTC) Received: by unicorn.suse.cz (Postfix, from userid 1000) id EFFA4E00B7; Mon, 8 Jul 2019 22:22:19 +0200 (CEST) Date: Mon, 8 Jul 2019 22:22:19 +0200 From: Michal Kubecek To: netdev@vger.kernel.org Cc: Jiri Pirko , David Miller , Jakub Kicinski , Andrew Lunn , Florian Fainelli , John Linville , Stephen Hemminger , Johannes Berg , linux-kernel@vger.kernel.org Subject: Re: [PATCH net-next v6 04/15] ethtool: introduce ethtool netlink interface Message-ID: <20190708202219.GE24474@unicorn.suse.cz> References: <20190702122521.GN2250@nanopsycho> <20190702145241.GD20101@unicorn.suse.cz> <20190703084151.GR2250@nanopsycho> <20190708172729.GC24474@unicorn.suse.cz> <20190708192629.GD2282@nanopsycho.orion> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20190708192629.GD2282@nanopsycho.orion> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Jul 08, 2019 at 09:26:29PM +0200, Jiri Pirko wrote: > Mon, Jul 08, 2019 at 07:27:29PM CEST, mkubecek@suse.cz wrote: > > > >There are two reasons for this design. First is to reduce the number of > >requests needed to get the information. This is not so much a problem of > >ethtool itself; the only existing commands that would result in multiple > >request messages would be "ethtool " and "ethtool -s ". Maybe > >also "ethtool -x/-X " but even if the indirection table and hash > >key have different bits assigned now, they don't have to be split even > >if we split other commands. It may be bigger problem for daemons wanting > >to keep track of system configuration which would have to issue many > >requests whenever a new device appears. > > > >Second reason is that with 8-bit genetlink command/message id, the space > >is not as infinite as it might seem. I counted quickly, right now the > >full series uses 14 ids for kernel messages, with split you propose it > >would most likely grow to 44. For full implementation of all ethtool > >functionality, we could get to ~60 ids. It's still only 1/4 of the > >available space but it's not clear what the future development will look > >like. We would certainly need to be careful not to start allocating new > >commands for single parameters and try to be foreseeing about what can > >be grouped together. But we will need to do that in any case. > > > >On kernel side, splitting existing messages would make some things a bit > >easier. It would also reduce the number of scenarios where only part of > >requested information is available or only part of a SET request fails. > > Okay, I got your point. So why don't we look at if from the other angle. > Why don't we have only single get/set command that would be in general > used to get/set ALL info from/to the kernel. Where we can have these > bits (perhaps rather varlen bitfield) to for user to indicate which data > is he interested in? This scales. The other commands would be > just for action. > > Something like RTM_GETLINK/RTM_SETLINK. Makes sense? It's certainly an option but at the first glance it seems as just moving what I tried to avoid one level lower. It would work around the u8 issue (but as Johannes pointed out, we can handle it with genetlink when/if the time comes). We would almost certainly have to split the replies into multiple messages to keep the packet size reasonable. I'll have to think more about the consequences for both kernel and userspace. My gut feeling is that out of the two extreme options (one universal message type and message types corresponding to current infomask bits), the latter is more appealing. After all, ethtool has been gathering features that would need those ~60 message types for 20 years. Michal