Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp9740949ybi; Wed, 10 Jul 2019 16:09:00 -0700 (PDT) X-Google-Smtp-Source: APXvYqw4T2m3r6Y9sqbNYsaO67AvsEUidpwdnuaa09GIslTyYZgtNcs+KShMPxGsbF/uupEDPwe0 X-Received: by 2002:a17:90a:bd0b:: with SMTP id y11mr887527pjr.141.1562800140134; Wed, 10 Jul 2019 16:09:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1562800140; cv=none; d=google.com; s=arc-20160816; b=PNccUn634t0GzH2uWmo3oK9oEmwjGBjP/X3ugZUvJE5AqsBcIcvfhOdhE7a+kuSjj6 oQAXM4ZVKSnLUFHgxtIK1X8MWsdohBiTbF8sqoxM/W+Fc5STG0mIdPiGvgRbU3jZa++j EvPWL4HX4/i+YrQXmDzpd0hcvRNkFlDx5ejPf+4yHXJSeoldz3tiofRrUx0bcGC7uar9 PDkt1LTRfnzejdyHgbq2sfa4fUjTeUIBC2d3jbTf1vTvEjtTfB0UsrfwOMJzCMfiKAgA bgamewjP9U+OJaVwbbfIEpMGyY0qBuCP+zCONO+VXXhwMpNHrTiuwFmBJW7I72vSGEC+ u40Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=U9GZA5c7tEhPZWUILZMdwvKCXKe9Av8xOuX5sfliAEI=; b=uQt5a0R6v/L+/+fxCDfU/1VYEJ/05i7KvyzmiNYWamFSe68GoYc5xPU6tzRuwyOmb4 q4djG+OfLPGnjhzGnFdq4Y2VdsXfHBYaJcybX5U/m3y21vjRxHJ2SloMy2KoXnPBMMtK oQhKg0NuYwEBfrOy/lT4IR3GPiASBmSFgaZVoMRi3LoSTfDNkxC4vFfnIBv1rEovEdg1 HM7Wku/eccTdAs1CEEoLDxJHXIuhxJlMVON9ebeWWUfGLwfY6apr5hwTZgU9pd7MmsqG sbaQ/uNOEtR01ULAmIFwKQPr5xAsryOFRzozvRUmudRJ8q+NDBgDbDHPF6PPZUj+PJ9w jpGg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-bluetooth-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-bluetooth-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id be11si2955276plb.218.2019.07.10.16.08.45; Wed, 10 Jul 2019 16:09:00 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-bluetooth-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-bluetooth-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-bluetooth-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727381AbfGJXIW (ORCPT + 99 others); Wed, 10 Jul 2019 19:08:22 -0400 Received: from mga14.intel.com ([192.55.52.115]:52368 "EHLO mga14.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726708AbfGJXIW (ORCPT ); Wed, 10 Jul 2019 19:08:22 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga001.fm.intel.com ([10.253.24.23]) by fmsmga103.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 10 Jul 2019 16:08:22 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.63,476,1557212400"; d="scan'208";a="186250396" Received: from bgix-dell-lap.sea.intel.com ([10.255.80.129]) by fmsmga001.fm.intel.com with ESMTP; 10 Jul 2019 16:08:21 -0700 From: Brian Gix To: linux-bluetooth@vger.kernel.org Cc: inga.stotland@intel.com, michal.lowas-rzechonek@silvair.com, brian.gix@intel.com Subject: [PATCH BlueZ 3/8] mesh: Add special Beacon handler for Provisioning Date: Wed, 10 Jul 2019 16:07:52 -0700 Message-Id: <20190710230757.8425-4-brian.gix@intel.com> X-Mailer: git-send-email 2.14.5 In-Reply-To: <20190710230757.8425-1-brian.gix@intel.com> References: <20190710230757.8425-1-brian.gix@intel.com> Sender: linux-bluetooth-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-bluetooth@vger.kernel.org Provisioning uses the same AD type for Provisioning that is also used by the Secure Network Beacon, but their usage is distinct from each other. This change allows us to enable/disable Unprovisioned Device Beacon capture without disrupting SNB handling. --- mesh/mesh-io-generic.c | 2 +- mesh/mesh-io.c | 6 ++++-- mesh/mesh-io.h | 7 ++++--- 3 files changed, 9 insertions(+), 6 deletions(-) diff --git a/mesh/mesh-io-generic.c b/mesh/mesh-io-generic.c index 42aaa0947..576c5df1b 100644 --- a/mesh/mesh-io-generic.c +++ b/mesh/mesh-io-generic.c @@ -40,7 +40,7 @@ struct mesh_io_private { struct l_timeout *tx_timeout; struct l_queue *rx_regs; struct l_queue *tx_pkts; - uint8_t filters[3]; /* Simple filtering on AD type only */ + uint8_t filters[4]; bool sending; struct tx_pkt *tx; uint16_t interval; diff --git a/mesh/mesh-io.c b/mesh/mesh-io.c index 62a8c0e2c..94a92e885 100644 --- a/mesh/mesh-io.c +++ b/mesh/mesh-io.c @@ -86,12 +86,14 @@ struct mesh_io *mesh_io_new(enum mesh_io_type type, void *opts) if (api->set) { uint8_t pkt = MESH_AD_TYPE_NETWORK; - uint8_t bec = MESH_AD_TYPE_BEACON; uint8_t prv = MESH_AD_TYPE_PROVISION; + uint8_t snb[2] = {MESH_AD_TYPE_BEACON, 0x01}; + uint8_t prvb[2] = {MESH_AD_TYPE_BEACON, 0x00}; - api->set(io, 1, &bec, 1, NULL, NULL); + api->set(io, 1, snb, sizeof(snb), NULL, NULL); api->set(io, 2, &prv, 1, NULL, NULL); api->set(io, 3, &pkt, 1, NULL, NULL); + api->set(io, 4, prvb, sizeof(prvb), NULL, NULL); } if (l_queue_push_head(io_list, io)) diff --git a/mesh/mesh-io.h b/mesh/mesh-io.h index 6585205c7..1c10779aa 100644 --- a/mesh/mesh-io.h +++ b/mesh/mesh-io.h @@ -19,9 +19,10 @@ struct mesh_io; -#define MESH_IO_FILTER_BEACON 1 -#define MESH_IO_FILTER_PROV 2 -#define MESH_IO_FILTER_NET 3 +#define MESH_IO_FILTER_BEACON 1 +#define MESH_IO_FILTER_PROV 2 +#define MESH_IO_FILTER_NET 3 +#define MESH_IO_FILTER_PROV_BEACON 4 #define MESH_IO_TX_COUNT_UNLIMITED 0 -- 2.14.5