This post is older than 2 years and might not be relevant anymore
More Info: Consider searching for newer posts

Make Nordic NRF52840DK as Server while other BLE Transmitter as client.

Hi Team,

We are trying to make Nordic NRF52840DK board to act as a server (BLE ) where as we are trying to connect other board (Not the Nordic chip) has only transmitter but unable to do it.

Tried with example "ble_app_gatts" by changing MAC address with other device's MAC (Peripheral-Device Identification Unique 48 Bit Device ID).

Kindly suggest best possible steps.

Parents
  • We need some more information.

    1. What is it that you're trying to do exactly? Can you rephrase your use-case?

    2. What is it that you have done to achieve said use-case?

    3. What behavior do you expect to see, and what behavior do you observe? 
  • Hi 

    We have NRF52840DK board, trying to make it as Server; acting as bluetooth gateway that will connect to many clients; these clients will have only transmitter (neither have receiver, nor have Nordic Chip-set).   

    As soon as Client transmit first message (only message)(e.g. advertise), this message shall be enough to indicate that an event has occurred  to the NRF52840DK board that is acting as bluetooth gateway(server), No other handshake message (scan response etc.) shall be triggered or received. Because client has only transmitter.

    How can we configure  NRF52840DK board as server that shall give a call-back function when first message (e.g.advertise) is received by stack and server can extract payload of first message.

    Hope it has cleared the use-case and requirements.

Reply
  • Hi 

    We have NRF52840DK board, trying to make it as Server; acting as bluetooth gateway that will connect to many clients; these clients will have only transmitter (neither have receiver, nor have Nordic Chip-set).   

    As soon as Client transmit first message (only message)(e.g. advertise), this message shall be enough to indicate that an event has occurred  to the NRF52840DK board that is acting as bluetooth gateway(server), No other handshake message (scan response etc.) shall be triggered or received. Because client has only transmitter.

    How can we configure  NRF52840DK board as server that shall give a call-back function when first message (e.g.advertise) is received by stack and server can extract payload of first message.

    Hope it has cleared the use-case and requirements.

Children
  • If you only need to receive BLE advertisements then you need to start a scan with sd_ble_gap_scan_start and wait for an BLE_GAP_EVT_ADV_REPORT

  • Hi 

    Can you share a test stub on how to implement  sd_ble_gap_scan_start. or refer to any example. 

    As i have tried to implement sd_ble_gap_scan_start on ble_app_gatts example

    got <error> app: Fatal error
    <warning> app: System reset

    Program control reaches to NRF_BREAKPOINT_COND; in app_weak_error.c file.

  • You can view any of the BLE client examples in the SDK for how to use scanning.

  • Hi 

    As we are working to achieve client server architecture with client (transmitter only) i have edited following code.

    Now i want your input on two points.

    1) we have observed BLE_GAP_EVT_ADV_REPORT  as soon as scan starts while client has not initiated any message. Kindly help me to debug from where this event is received. 

    2) After receiving BLE_GAP_EVT_ADV_REPORT  till TIMEOUT event no other advertise message is observed while client is sending advertise.  Kindly help to know data associated with it or how to extract MAC or any unique id to know that advertise is received with desired client. Or list of client trying to connect to server.

    OUTPUT::

    [2019-11-19_17:24:02:062]<info> app_timer: RTC: initialized.
    [2019-11-19_17:24:02:062]<info> app: [ ::393] --> ble_stack_init
    [2019-11-19_17:24:02:062]<info> app: [ ::678] --> gatt_init
    [2019-11-19_17:24:02:062]<info> app: Start scanning...
    [2019-11-19_17:24:02:062]<info> app: [ ::810] --> scanning_start
    [2019-11-19_17:24:02:062]<info> app: [ ::821] --> scanning_start :: scan_start
    [2019-11-19_17:24:02:062]<info> app: [ ::613] --> scan_start
    [2019-11-19_17:24:02:085]<debug> ble_scan: Scanning parameters have been changed successfully
    [2019-11-19_17:24:02:085]<info> app: [ ::233] --> ble_evt_handler
    [2019-11-19_17:24:02:085]<info> app: [ ::238] --> Switch Case :: 29
    [2019-11-19_17:24:02:085]<info> app: [ ::292] --> BLE_GAP_EVT_ADV_REPORT
    [2019-11-19_17:24:02:085]<info> app: [ ::294] --> Buffer Value
    [2019-11-19_17:24:02:108]<info> app: 1E
    [2019-11-19_17:24:02:108]<info> app: FF ÿ
    [2019-11-19_17:24:02:108]<info> app: 06
    [2019-11-19_17:24:02:108]<info> app: 00
    [2019-11-19_17:24:02:108]<info> app: 01
    [2019-11-19_17:24:02:108]<info> app: 09
    [2019-11-19_17:24:02:108]<info> app: 20
    [2019-11-19_17:24:02:108]<info> app: 02
    [2019-11-19_17:24:02:108]<info> app: A6 ¦
    [2019-11-19_17:24:02:108]<info> app: 38 8
    [2019-11-19_17:24:02:108]<info> app: 7D }
    [2019-11-19_17:24:02:131]<info> app: 32 2
    [2019-11-19_17:24:02:131]<info> app: DE Þ
    [2019-11-19_17:24:02:131]<info> app: FB û
    [2019-11-19_17:24:02:131]<info> app: 86 †
    [2019-11-19_17:24:02:131]<info> app: A4 ¤
    [2019-11-19_17:24:02:131]<info> app: A9 ©
    [2019-11-19_17:24:02:131]<info> app: 05
    [2019-11-19_17:24:02:131]<info> app: BE ¾
    [2019-11-19_17:24:02:131]<info> app: A4 ¤
    [2019-11-19_17:24:02:131]<info> app: 4A J
    [2019-11-19_17:24:02:131]<info> app: B9 ¹
    [2019-11-19_17:24:02:181]<info> app: 0F
    [2019-11-19_17:24:02:181]<info> app: 2F /
    [2019-11-19_17:24:02:181]<info> app: C8 È
    [2019-11-19_17:24:02:181]<info> app: 88 ˆ
    [2019-11-19_17:24:02:181]<info> app: A1 ¡
    [2019-11-19_17:24:02:181]<info> app: 7C |
    [2019-11-19_17:24:02:181]<info> app: 1A
    [2019-11-19_17:24:02:181]<info> app: 6F o
    [2019-11-19_17:24:02:181]<info> app: 8D 
    [2019-11-19_17:24:32:015]<debug> ble_scan: BLE_GAP_SCAN_TIMEOUT
    [2019-11-19_17:24:32:015]<info> app: [ ::233] --> ble_evt_handler
    [2019-11-19_17:24:32:015]<info> app: [ ::238] --> Switch Case :: 27
    [2019-11-19_17:24:32:015]<info> app: [ ::258] --> BLE_GAP_EVT_TIMEOUT
    [2019-11-19_17:24:32:015]<info> app: [ ::613] --> scan_start
    [2019-11-19_17:24:32:015]<debug> ble_scan: Scanning parameters have been changed successfully
    [2019-11-19_17:24:32:038]<info> app: [ ::233] --> ble_evt_handler
    [2019-11-19_17:24:32:038]<info> app: [ ::238] --> Switch Case :: 29
    [2019-11-19_17:24:32:038]<info> app: [ ::292] --> BLE_GAP_EVT_ADV_REPORT
    [2019-11-19_17:24:32:038]<info> app: [ ::294] --> Buffer Value
    [2019-11-19_17:24:32:038]<info> app: 1E
    [2019-11-19_17:24:32:038]<info> app: FF ÿ
    [2019-11-19_17:24:32:061]<info> app: 06
    [2019-11-19_17:24:32:061]<info> app: 00
    [2019-11-19_17:24:32:061]<info> app: 01
    [2019-11-19_17:24:32:061]<info> app: 09
    [2019-11-19_17:24:32:061]<info> app: 20
    [2019-11-19_17:24:32:061]<info> app: 02
    [2019-11-19_17:24:32:061]<info> app: F3 ó
    [2019-11-19_17:24:32:061]<info> app: 3B ;
    [2019-11-19_17:24:32:061]<info> app: E3 ã
    [2019-11-19_17:24:32:061]<info> app: 62 b
    [2019-11-19_17:24:32:061]<info> app: E0 à
    [2019-11-19_17:24:32:061]<info> app: A3 £
    [2019-11-19_17:24:32:084]<info> app: 2D -
    [2019-11-19_17:24:32:084]<info> app: B1 ±
    [2019-11-19_17:24:32:084]<info> app: 49 I
    [2019-11-19_17:24:32:084]<info> app: 56 V
    [2019-11-19_17:24:32:084]<info> app: EC ì
    [2019-11-19_17:24:32:084]<info> app: 37 7
    [2019-11-19_17:24:32:084]<info> app: 28 (
    [2019-11-19_17:24:32:084]<info> app: 9A š
    [2019-11-19_17:24:32:084]<info> app: 63 c
    [2019-11-19_17:24:32:084]<info> app: 5E ^
    [2019-11-19_17:24:32:084]<info> app: 17
    [2019-11-19_17:24:32:084]<info> app: EE î
    [2019-11-19_17:24:32:128]<info> app: 09
    [2019-11-19_17:24:32:128]<info> app: 64 d
    [2019-11-19_17:24:32:128]<info> app: 78 x
    [2019-11-19_17:24:32:128]<info> app: B8 ¸
    [2019-11-19_17:24:32:128]<info> app: D7 ×

    Fullscreen
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    /**
    * Copyright (c) 2017 - 2019, Nordic Semiconductor ASA
    *
    * All rights reserved.
    *
    * Redistribution and use in source and binary forms, with or without modification,
    * are permitted provided that the following conditions are met:
    *
    * 1. Redistributions of source code must retain the above copyright notice, this
    * list of conditions and the following disclaimer.
    *
    * 2. Redistributions in binary form, except as embedded into a Nordic
    * Semiconductor ASA integrated circuit in a product or a software update for
    * such product, must reproduce the above copyright notice, this list of
    * conditions and the following disclaimer in the documentation and/or other
    * materials provided with the distribution.
    *
    * 3. Neither the name of Nordic Semiconductor ASA nor the names of its
    * contributors may be used to endorse or promote products derived from this
    * software without specific prior written permission.
    *
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

  • 1. You will receive an advertising report from any BLE device that is advertising. In a regular office environment that usually means a few devices. You can use the Filters or Whitelist feature of the Scanning Module to only get advertisements from a specific Advertising Name, BLE Address(MAC), UUIDs, or Appearance. 

    2. Here's the type description of the BLE_GAP_EVT_ADV_REPORT: ble_gap_evt_adv_report_t
    This is used by the Scanning Module, but you can ofc use the information how you please.