Received: by 2002:a25:868d:0:0:0:0:0 with SMTP id z13csp324594ybk; Wed, 13 May 2020 00:53:13 -0700 (PDT) X-Google-Smtp-Source: APiQypKgbT95hnI0p0DLnwF0xHGoJGehnMyyEvHXnzmFD6H/qSRYPWDzD73E2DxGsowSgSswZ3Kd X-Received: by 2002:a50:c3c2:: with SMTP id i2mr22092083edf.227.1589356392956; Wed, 13 May 2020 00:53:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1589356392; cv=none; d=google.com; s=arc-20160816; b=uHdD2U8fArF7IAKMM00wZAageH38L5mcZdT7Nl6AYtkJ0ZsMeg/fkDVq4Uj0LqTSaJ jEwhTIgnVJa86oMN+IJ1LsScLP3BzWKOaoxPqaRJXh5VWhpmUBENvw/xC6ZaZ7t9Uz1z 9vmrgJT9zfPs+L93dDTDM/fnS+/fmv+XOWRPTfnqBXdRXsXmIFBxDMIMdOQP2TR5AS9O 21ZTj4lxha8XgRsppueXtpUhuAwyb3xj1Izm8F/faDkVzNgFSU3itRw0Ndab3jQU9Rsa aBS1YII86PjgHlZtTApJaTjxW6DU5rXNPTM5ZN0RRssLIbkKIUqTM2bNcKQ8SLdFp7bl 07ow== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:to:references:message-id :content-transfer-encoding:cc:date:in-reply-to:from:subject :mime-version; bh=TyNqb4uwaOIYLeoAT6T6OWoF/eAIscDjyoRIseKnCDA=; b=hH9CJb9OrnRrMDEn+BwXywv37yB6aqlxq8awfghuNi+em0dCJPTsSKoP2eEV9zS4on btCqIWht65PsAPHodhGqWos/7RzKJXeNtVgT2qGp7HEuoOy5iABsAN1rxpUz6fcQ6SN1 +X67W4DLpPD9fTUaxi8ipuIIHhDDEti6mOpMVL55gL/w4ZPirMIyyu/oQmQ8aYKVDrdQ UR4dBoKviwB8L0ULU9eg28VVTG8GuFJyXv266umbZ5HSi2kxdCWq6xS+CDXlgVuu67WM RPGgZ9V7sgMbjakShZf7s6TBnxnGm707W10tZwxbVjCO8furgZDOZVY+lYGdeMVNELH0 WArg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-bluetooth-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-bluetooth-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id p23si9075727eju.299.2020.05.13.00.52.15; Wed, 13 May 2020 00:53:12 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-bluetooth-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-bluetooth-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-bluetooth-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729106AbgEMHtE convert rfc822-to-8bit (ORCPT + 99 others); Wed, 13 May 2020 03:49:04 -0400 Received: from coyote.holtmann.net ([212.227.132.17]:50449 "EHLO mail.holtmann.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726138AbgEMHtE (ORCPT ); Wed, 13 May 2020 03:49:04 -0400 Received: from [192.168.1.91] (p4FEFC5A7.dip0.t-ipconnect.de [79.239.197.167]) by mail.holtmann.org (Postfix) with ESMTPSA id E7A35CED09; Wed, 13 May 2020 09:58:44 +0200 (CEST) Content-Type: text/plain; charset=us-ascii Mime-Version: 1.0 (Mac OS X Mail 13.4 \(3608.80.23.2.2\)) Subject: Re: [BlueZ PATCH v1] doc:adding definitions for load default params mgmt op From: Marcel Holtmann In-Reply-To: Date: Wed, 13 May 2020 09:48:31 +0200 Cc: Alain Michaud , BlueZ Content-Transfer-Encoding: 8BIT Message-Id: <4EAD51F7-D123-4489-9327-1B5E9CC52DF8@holtmann.org> References: <20200504142625.213143-1-alainm@chromium.org> <7610937E-424D-4968-B8D9-378E44773088@holtmann.org> To: Alain Michaud X-Mailer: Apple Mail (2.3608.80.23.2.2) Sender: linux-bluetooth-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-bluetooth@vger.kernel.org Hi Alain, >>> This change adds the definition for the load default parameter command. >>> In particular, this command is used to load default parameters for >>> various operations in the kernel. This mechanism is also expandable to >>> future knobs that may be necessary. >>> >>> This will allow bluetoothd to load parameters from a conf file that may >>> be customized for the specific requirements of each platforms. >>> >>> --- >>> >>> doc/mgmt-api.txt | 59 ++++++++++++++++++++++++++++++++++++++++++++++++ >>> 1 file changed, 59 insertions(+) >>> >>> diff --git a/doc/mgmt-api.txt b/doc/mgmt-api.txt >>> index 39f23c456..71d528706 100644 >>> --- a/doc/mgmt-api.txt >>> +++ b/doc/mgmt-api.txt >>> @@ -3137,6 +3137,65 @@ Read Security Information Command >>> Possible errors: Invalid Parameters >>> Invalid Index >>> >>> +Load Default Parameter Command >>> +============================= >> >> I think that Load Controller Default Parameters is a better name. > I wanted to avoid using "controller" in the name as some of these are > not really "controller" parameters but instead just general > parameters. fair enough. Now the question is if we might want to split between controller defaults and host defaults. >>> + >>> + Command Code: 0x0049 >>> + Controller Index: >>> + Command Parameters: Parameter_Count (2 Octets) >>> + Parameter1 { >>> + Parameter_Type (2 Octet) >>> + Value_Length (1 Octet) >>> + Value (0-255 Octets) >>> + } >>> + Parameter2 { } >>> + ... >>> + Return Parameters: >>> + >>> + This command is used to feed the kernel a list of default parameters. >>> + >>> + Currently defined Parameter_Type values are: >>> + >>> + 0x0000 BR/EDR Page Scan Type >>> + 0x0001 BR/EDR Page Scan Interval >>> + 0x0002 BR/EDR Page Scan Window >>> + 0x0003 BR/EDR Inquiry Scan Type >>> + 0x0004 BR/EDR Inquiry Scan Interval >>> + 0x0005 BR/EDR Inquiry Scan Window >>> + 0x0006 BR/EDR Link Supervision Timeout >>> + 0x0007 BR/EDR Page Timeout >>> + 0x0008 BR/EDR Min Sniff Interval >>> + 0x0009 BR/EDR Max Sniff Interval >>> + 0x0080 LE Advertisement Min Interval >>> + 0x0081 LE Advertisement Max Interval >>> + 0x0082 LE Multi Advertisement Rotation Interval >>> + 0x0083 LE Scanning Interval for auto connect >>> + 0x0084 LE Scanning Window for auto connect >>> + 0x0085 LE Scanning Interval for HID only >>> + 0x0086 LE Scanning Window for HID only >>> + 0x0087 LE Scanning Interval for wake scenarios >>> + 0x0088 LE Scanning Window for wake scenarios >>> + 0x0089 LE Scanning Interval for discovery >>> + 0x008a LE Scanning Window for discovery >>> + 0x008b LE Scanning Interval for adv monitoring >>> + 0x008c LE Scanning Window for adv monitoring >>> + 0x008d LE Scanning Interval for connect >>> + 0x008e LE Scanning Window for connect >>> + 0x008f LE Min Connection Interval >>> + 0x0090 LE Max Connection Interval >>> + 0x0091 LE Connection Connection Latency >>> + 0x0092 LE Connection Supervision Timeout >> >> I would just enumerate these and not try to split between 0x000 and 0x008 for BR/EDR and LE. Also I would just start with a few values that we currently want to change. > The goal was to try to keep BR and LE parameters together, but if you > prefer, I don't mind collapsing them. Note that we intend to use all > of these, so I'd prefer not break this into a smaller subset. My OCD wants to do that as well, but my experience has been that this never actually works out. And we will have parameters that apply to both transports. Like for example the minimum encryption key size. >>> + >>> + This command can be used any time, but will not take effect until the >>> + next activity requiring the parameters. In the case the parameters are >>> + used during initialization of the adapter, it is expected that the >>> + parameters be set before the adapter is powered. >> >> Hmmm. This one, I might want to limit this controllers powered down. Otherwise you get into the conflict case that we would expect parameters taking affect and I think that is just too complicated. > Things like connection intervals and scan defaults actually apply the > next time the activity is started. We need to be able to change these > without completely powering down the controller and tearing down all > connections etc. Things that are obviously only used during > initialization, then I would expect they would require a power cycles. Now we might actually better split this into a command for system default parameters and one for runtime default parameters. I think it would make the code a lot simpler since we can have clear error codes. Thoughts? Regards Marcel