Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp4192931pxj; Tue, 25 May 2021 02:25:31 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyYHch1Bezk/qXMIgQPw/drlNg1lQGartbyPXyt7uW5dguOueQ+UHEeVZCX2wQdIFncFR1L X-Received: by 2002:a92:6809:: with SMTP id d9mr17302242ilc.87.1621934731567; Tue, 25 May 2021 02:25:31 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1621934731; cv=none; d=google.com; s=arc-20160816; b=ZZxxC58cEopRUBJTc78pQAJdMP355jQ7tD5pc/269slEkbo16Zx2A9+WJWxggBrbgW Vlk+RBxDvUzXMsPIrJl0S+RZhRNjJPrFo6uJx4ZJ7BpYJLs4EEIxPPUo9llzU3o15qT1 NPlcKT0z56QJcm5r5+z3BlMJHzLi/+yhaxVq5cEqchnN0JGKZPtueWJwqpTE2sFmxrIG 3TEBh+Ha7AXr7TVB17gdClTbcz0cHVrm2ZVPwHh21yUkANaml4Hx1gEnHA0oI9//8N3t rH2/BPbcqLvCCuwROzYpxv/YC1dQPZwgPWHUo1R/vhjTfA0WCkHVEKfaj+b6Evxx0tIB eA1A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=p1dfoj+hgeWyqY+hZ8nGrm7+WYHUPScdLfJBOIdvS9A=; b=s0ruWD7ZdOG++VtENK7MWcfYk2aDXpwm5Xdvy6A5Rvg8DNlhau+ULPzlhnjKjSs1rO FMkwz/v/a+OUCzY5p/xxH2c8lEY/J+w70/Z7x5JaytlDq075b589ypsvpcQHsYfSKbAH hX56cKaC0rA3NyHz9WQmyQvXZVn6NqhZy7gQYkNN9R+3K86lETN335w96MdOOxvhpF+X va0tK1yevUzm9ON3IO3d8qJmoyXLw8bsQ03CJ7Td3PYn0V6EzXWjJ48BBTcW/RLDfIsy 0h2GgjTiYK+j3sodLU2IOxjCAX0sgfy4w9oeQI8XDY1Ve33mcqlspYc3odGfvFV/D9Hy tyhQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=CRgCOiqn; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id u15si19443551iot.55.2021.05.25.02.24.59; Tue, 25 May 2021 02:25:31 -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; dkim=pass header.i=@linaro.org header.s=google header.b=CRgCOiqn; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232431AbhEYJYl (ORCPT + 99 others); Tue, 25 May 2021 05:24:41 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33870 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232474AbhEYJYl (ORCPT ); Tue, 25 May 2021 05:24:41 -0400 Received: from mail-ed1-x534.google.com (mail-ed1-x534.google.com [IPv6:2a00:1450:4864:20::534]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 67575C061574 for ; Tue, 25 May 2021 02:23:11 -0700 (PDT) Received: by mail-ed1-x534.google.com with SMTP id df21so35331761edb.3 for ; Tue, 25 May 2021 02:23:11 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to; bh=p1dfoj+hgeWyqY+hZ8nGrm7+WYHUPScdLfJBOIdvS9A=; b=CRgCOiqnRl4RRcJuUmlKY+rZY9M88g9lKuv+V7rUgQUzRaN+6ebTZBmk9+LMckKYZC 9hDYI+jvdr2aG3qIE74lbKjPlNzaZYg7yLCD3DOeNet/BeH1cS3I7U9oKnpiMH7OTqXc DsKP2sz2t1h8KlFqYdjWp+nvowN5o5n55dKe+JhDZYz6JEPtPpNO9ERgiTznktw8riLx hv6haFwN4FIb3o8344spGtfBIbHAwtrYSXvILxxoCX6iOwNynLCVh3fPv1aX7C6FIWNt 6X+KOLgh76JRA+t7t5I6S/XveVDMOYRbPerFrPxJxZgpX5h+ztd5g3EFqVJaTsDUT9aE 6KSA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to; bh=p1dfoj+hgeWyqY+hZ8nGrm7+WYHUPScdLfJBOIdvS9A=; b=VwCms/q66FfRgwa+YVORgeZGKep41q9gkwBYmvCuo8xWG9EhQI/VfLLdU/0ViDIaWa hWxWOy3LbafPe5GnLGFz2lmAQna1bWSV2UtNlHvCbJJWvHmaOMzXVDYlnby5igMZ/Abt PaQU8DO+V2yUYKJdcYSEjcmVky9OSkfS/ZLyz/hpYVfzUoXVwWn0V8VDpYNrxqVAJE9j G7mHe4gboFRbv6ywicBdQXmA7d5r+j/RjLIKcjvAw6ysBFhuYAT/tS+AAaQx1T9NxVrp b02utgWLGVlb/W1WPux7PgEFCQF/4W2LexJzO7pZSe2r8JbByWXxPpX9m1fDkCEYAUXP kaCQ== X-Gm-Message-State: AOAM533fFsba8kjmURUBTdLPv5+eo2Xs+VHJvwkvtQCk55hMmkaJ8oRu 7tBwuhyZXiTmwW5I1LsBpBmrBN/9sU55aw== X-Received: by 2002:aa7:cf03:: with SMTP id a3mr30403284edy.314.1621934589998; Tue, 25 May 2021 02:23:09 -0700 (PDT) Received: from myrica (adsl-84-226-106-126.adslplus.ch. [84.226.106.126]) by smtp.gmail.com with ESMTPSA id g1sm8832463ejf.29.2021.05.25.02.23.09 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 25 May 2021 02:23:09 -0700 (PDT) Date: Tue, 25 May 2021 11:22:52 +0200 From: Jean-Philippe Brucker To: Marcel Holtmann Cc: linux-bluetooth@vger.kernel.org Subject: Re: [PATCH] Bluetooth: Add support for virtio transport driver Message-ID: References: <20210406141258.258544-1-marcel@holtmann.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20210406141258.258544-1-marcel@holtmann.org> Precedence: bulk List-ID: X-Mailing-List: linux-bluetooth@vger.kernel.org Hi Marcel, On Tue, Apr 06, 2021 at 04:12:58PM +0200, Marcel Holtmann wrote: > diff --git a/include/uapi/linux/virtio_bt.h b/include/uapi/linux/virtio_bt.h > new file mode 100644 > index 000000000000..0cedceaacf88 > --- /dev/null > +++ b/include/uapi/linux/virtio_bt.h > @@ -0,0 +1,31 @@ > +// SPDX-License-Identifier: BSD-3-Clause > + > +#ifndef _UAPI_LINUX_VIRTIO_BT_H > +#define _UAPI_LINUX_VIRTIO_BT_H > + > +#include > + > +/* Feature bits */ > +#define VIRTIO_BT_F_VND_HCI 0 /* Indicates vendor command support */ > +#define VIRTIO_BT_F_MSFT_EXT 1 /* Indicates MSFT vendor support */ > +#define VIRTIO_BT_F_AOSP_EXT 2 /* Indicates AOSP vendor support */ > + > +enum virtio_bt_config_type { > + VIRTIO_BT_CONFIG_TYPE_PRIMARY = 0, > + VIRTIO_BT_CONFIG_TYPE_AMP = 1, > +}; > + > +enum virtio_bt_config_vendor { > + VIRTIO_BT_CONFIG_VENDOR_NONE = 0, > + VIRTIO_BT_CONFIG_VENDOR_ZEPHYR = 1, > + VIRTIO_BT_CONFIG_VENDOR_INTEL = 2, > + VIRTIO_BT_CONFIG_VENDOR_REALTEK = 3, > +}; > + > +struct virtio_bt_config { > + __u8 type; > + __u16 vendor; > + __u16 msft_opcode; > +} __attribute__((packed)); Config fields should be naturally aligned, because the virtio spec says (4.1.3.1 Driver Requirements: PCI Device Layout). For device configuration access, the driver MUST use 8-bit wide accesses for 8-bit wide fields, 16-bit wide and aligned accesses for 16-bit wide fields and 32-bit wide and aligned accesses for 32-bit and 64-bit wide fields. > + > +#endif /* _UAPI_LINUX_VIRTIO_BT_H */ > diff --git a/include/uapi/linux/virtio_ids.h b/include/uapi/linux/virtio_ids.h > index bc1c0621f5ed..b4f468e9441d 100644 > --- a/include/uapi/linux/virtio_ids.h > +++ b/include/uapi/linux/virtio_ids.h > @@ -53,6 +53,7 @@ > #define VIRTIO_ID_MEM 24 /* virtio mem */ > #define VIRTIO_ID_FS 26 /* virtio filesystem */ > #define VIRTIO_ID_PMEM 27 /* virtio pmem */ > +#define VIRTIO_ID_BT 28 /* virtio bluetooth */ ID 28 is already reserved for virtio-rpmb: https://github.com/oasis-tcs/virtio-spec/issues/58 To avoid major compatibility pains going forward I think this should be changed to ID 40 before v5.13. It won't be easy to fix afterwards since it's UAPI. Probably a good idea to fix or revert virtio_bt.h as well before it's too late. Patches to the virtio headers should Cc virtualization@lists.linux-foundation.org and perhaps virtio-dev@lists.oasis-open.org because they can provide guidance about this. Thanks, Jean > #define VIRTIO_ID_MAC80211_HWSIM 29 /* virtio mac80211-hwsim */ > > #endif /* _LINUX_VIRTIO_IDS_H */ > -- > 2.30.2 >