diff --git a/accessories/cables.rst b/accessories/cables.rst
index 5a742f198702dc5831d38f847eeca8f5c3fc7f5f..f1c121693a32782574a18d4228e8af1ecb57d729 100644
--- a/accessories/cables.rst
+++ b/accessories/cables.rst
@@ -167,7 +167,7 @@ JTAG debug Cables
 TagConnect (JTAG)
 ==================
 
-Boards like :ref:`beagleconnect_freedom_home`, :ref:`beaglev-ahead-home`, :ref:`beaglev-fire-home`, and :ref:`beagleplay-home` use the TagConnect 
+Boards like :ref:`beagleconnect-freedom-home`, :ref:`beaglev-ahead-home`, :ref:`beaglev-fire-home`, and :ref:`beagleplay-home` use the TagConnect 
 interface which allows you to perform firmware updates and JTAG hardware debugging. To use the interface, the the parts below from 
 `tag-connect <https://www.tag-connect.com>`_  are required.
 
diff --git a/boards/beagleconnect/freedom/index.rst b/boards/beagleconnect/freedom/index.rst
index 8140c51849d926c26b7fb4b309a0001bee911aac..1705ff013ed4bd075b0892518de9a3b4fad081dd 100644
--- a/boards/beagleconnect/freedom/index.rst
+++ b/boards/beagleconnect/freedom/index.rst
@@ -1,4 +1,4 @@
-.. _beagleconnect_freedom_home:
+.. _beagleconnect-freedom-home:
 
 BeagleConnect Freedom
 #####################
diff --git a/boards/beagleconnect/index.rst b/boards/beagleconnect/index.rst
index e30eba3fa2d656a5c5670261f7d78e331e94ea57..f1d6e693b93844a3409446870b4b2632af037d24 100644
--- a/boards/beagleconnect/index.rst
+++ b/boards/beagleconnect/index.rst
@@ -1,97 +1,21 @@
 .. _beagleconnect-home:
 
-BeagleConnect
+BeagleConnectâ„¢
 ###############
 
 .. important::
 
    Currently under development
 
-BeagleConnectâ„¢ is a revolutionary technology virtually eliminating low-level 
-software development for `IoT <https://en.wikipedia.org/wiki/Internet_of_things>`_ 
-and `IIoT <https://en.wikipedia.org/wiki/Industrial_internet_of_things>`_ 
-applications, such as building automation, factory automation, home automation,
-and scientific data acquisition. While numerous IoT and IIoT solutions 
-available today provide massive software libraries for microcontrollers 
-supporting a limited body of `sensors <https://en.wikipedia.org/wiki/Sensor>`_,
-`actuators <https://en.wikipedia.org/wiki/Actuator>`_ and `indicators <https://en.wikipedia.org/wiki/Indicator_(distance_amplifying_instrument)>`_ 
-as well as libraries for communicating over various networks, BeagleConnect 
-simply eliminates the need for these libraries by shifting the burden into the 
-most massive and collaborative software project of all time, the `Linux kernel <https://en.wikipedia.org/wiki/Linux_kernel>`_.
-
-These are the tools used to automate things in 
-`scientific data collection <https://en.wikipedia.org/wiki/Data_collection_system>`_, 
-`data science <https://en.wikipedia.org/wiki/Data_science>`_, 
-`mechatronics <https://en.wikipedia.org/wiki/Mechatronics>`_, 
-and `IoT <https://en.wikipedia.org/wiki/Internet_of_things>`_.
-
-BeagleConnectâ„¢ technology solves:
-
-* The need to write software to add a large set of diverse devices to your system,
-* The need to maintain the software with security updates,
-* The need to rapidly prototype using off-the-shelf software and hardware without wiring,
-* The need to connect to devices using long-range, low-power wireless, and
-* The need to produce high-volume custom hardware cost-optimized for your requirements.
-
-See:
-
-* :ref:`beagleconnect-overview`
-* :ref:`beagleconnect-story`
-
-BeagleConnect Experience
-*************************
-
-BeagleConnectâ„¢ provides a scalable experience for interacting with the physical world.
-
-.. note:: 
-   The term BeagleConnectâ„¢ refers to a technology comprising of a family of 
-   boards, a collection of Linux kernel drivers, microcontroller firmware, a 
-   communication protocol, and system-level integration to automation software 
-   tools. More specific terms will be applied in the architecture details. The 
-   term is also used here to represent the experience introduced to users through 
-   the initial BeagleConnectâ„¢ Freedom product consisting of a board and case which
-   ships programmed and ready to be used. 
-
-For scientists, we are integrating `Jupyter Notebook <https://jupyter.org/>`_ 
-with the data streams from any of hundreds of sensor options, including 
-`vibration <https://www.mikroe.com/click/sensors/force>`_, 
-`gas detection <https://www.mikroe.com/click/sensors/gas>`_, 
-`biometrics <https://www.mikroe.com/click/sensors/biometrics>`_ and 
-`more <https://www.mikroe.com/click/sensors>`_. These data streams can be 
-stored in simple `data files <https://en.wikipedia.org/wiki/Comma-separated_values>` 
-or processed and visualized.
-
-.. todo::
-
-   provide images demonstrating Jupyter Notebook visualization
-
-For embedded systems developers, data is easily extracted using the standard IIO
-interface provided by the Linux kernel running on the gateway using any of 
-hundreds of programming languages and environments, without writing a line of 
-microcontroller firmware. The Linux environment provides opportunities for 
-high-level remote management using tools like Balena with applications deployed
-in Docker containers.
-
-.. todo:: provide image illustrating remote management
-
-The hardware and software are fully open source, providing for scalability and a lack of vendor lock-in.
-
-For DevOps…
-
-For home automaters, integration into WebThings…
-
-.. todo::
-
-   think a bit more about this section with some feedback from Cathy.
+BeagleConnectâ„¢ is a family of boards that provides mikroBUS connections to Linux machines over :ref:`beagleconnect-technology` as Zephyr-supported MCU-based boards.
 
 .. image:: freedom/images/BeagleConnect-Boards-Angled.*
    :width: 598
    :align: center
    :alt: BeagleConnect Freedom
 
+BeagleConnectâ„¢ boards
+**********************
 
-BeagleConnect boards
-********************
-
-* :ref:`beagleconnect_freedom_home`
+* :ref:`beagleconnect-freedom-home`
 
diff --git a/boards/beagleplay/demos-and-tutorials/zephyr-cc1352-development.rst b/boards/beagleplay/demos-and-tutorials/zephyr-cc1352-development.rst
index 6e29e9c0bc03023bd96b0cb583f76307e41059ce..06d2065863588903d6043bc0e9df190780cfbfb5 100644
--- a/boards/beagleplay/demos-and-tutorials/zephyr-cc1352-development.rst
+++ b/boards/beagleplay/demos-and-tutorials/zephyr-cc1352-development.rst
@@ -14,7 +14,7 @@ source design. If you are one of those people, this is a good place to get
 started.
 
 Further, BeaglePlay is a reasonable development platform for creating Zephyr-based
-applications for :ref:`beagleconnect_freedom_home`. The same Zephyr development
+applications for :ref:`beagleconnect-freedom-home`. The same Zephyr development
 environment setup here is also described for targeting applications on that board.
 
 Install the latest software image for BeaglePlay
@@ -83,7 +83,7 @@ Background
 This `WPANUSB` application was originally developed for radio devices with a USB interface. The CC1352P7
 does not have a USB device, so the application was modified to communicate over a UART serial interface.
 
-For the :ref:`beagleconnect_freedom_home`, a USB-to-UART bridge device was used and the USB endpoints
+For the :ref:`beagleconnect-freedom-home`, a USB-to-UART bridge device was used and the USB endpoints
 were made compatible with the `WPANUSB linux driver <https://github.com/finikorg/wpanusb>`_ which we
 `augmented <https://git.beagleboard.org/beagleconnect/linux/wpanusb/>`_ to support this board. To utilize
 the existing `WPANUSB` Zephyr application and this Linux driver, we chose to encode our UART traffic with
diff --git a/glossary.rst b/glossary.rst
index 51f3725feb2da4c495ee67c403cfef7ef66127a7..4ff7676c9ac624fe3b3b58eb5a9fb7b4b8be0cf9 100644
--- a/glossary.rst
+++ b/glossary.rst
@@ -18,3 +18,9 @@ Glossary of Terms
    BeagleBone
       A family of BeagleBoard.org boards from the original mint-tin sized computer and registered
       trademark of the BeagleBoard.org Foundation.
+
+   BeagleConnect AP
+      It refers to the host CPUs, i.e., CPUs running Linux in most cases. It is responsible for administrating the Greybus network via the SVC.
+
+   BeagleConnect SVC
+      The SVC represents an entity within the Greybus network that configures and controls the Greybus (UniPro) network, mostly based on the instructions from the AP. All module insertion and removal events are first reported to the SVC, which in turn informs the AP about them using the SVC protocol.
diff --git a/index.rst b/index.rst
index 3426d7c3f6748bf0471117c50920185d47a115eb..450cd1a71e5477af0016478abce736a55e3a27b4 100644
--- a/index.rst
+++ b/index.rst
@@ -52,7 +52,7 @@ from source using appropriate design tools.
 
 * Check out our easy-to-use Linux-based board at: :ref:`beagleplay-home`
 * Check out our highest performance (8 TOPs) board at: :ref:`bbai64-home`
-* Check out our first Zephyr-based board at: :ref:`beagleconnect_freedom_home`
+* Check out our first Zephyr-based board at: :ref:`beagleconnect-freedom-home`
 * Find all of our boards at: :ref:`boards`
 
 .. grid:: 1 1 2 3
@@ -87,7 +87,7 @@ from source using appropriate design tools.
       to the connected world.
 
    .. grid-item-card::
-      :link: beagleconnect_freedom_home
+      :link: beagleconnect-freedom-home
       :link-type: ref
 
       **BeagleConnectâ„¢ Freedom**
diff --git a/projects/beagleconnect/beaglebone-bcf.rst b/projects/beagleconnect/beaglebone-bcf.rst
new file mode 100644
index 0000000000000000000000000000000000000000..e0ad921b6ae1fe0abfd75aa2f094c1e4fc503d79
--- /dev/null
+++ b/projects/beagleconnect/beaglebone-bcf.rst
@@ -0,0 +1,1126 @@
+.. role:: strike
+   :class: strike
+
+.. _beagleconnect-technology-beaglebone-bcf:
+
+BeagleBone + BeagleConnect Freedom
+##################################
+
+.. important::
+
+    This demo was the old way of doing things. Anyone new and inexperienced should look at beagleplay + beagleconnect freedom instead.
+
+.. _beagleconnect-software-architecture:
+
+Software architecture
+*********************
+
+.. _beagleconnect-software-architecture-diagram:
+
+.. graphviz::
+        :caption: BeagleConnect Software Architecture Diagram
+
+    	// Software architecture
+    	digraph S {
+    		node [color=white shape=box]
+    		subgraph cluster_0 {
+    			color=black label="Linux PC"
+    			subgraph cluster_1 {
+    				node [color=green style=filled]
+    				color=lightgrey label="Linux userspace" style=filled
+    				A [label="User Application" tooltip="Primary developer entry point"]
+    				g [label="gbridge**" tooltip="Bridge Greybus to networked devices"]
+    			}
+    			subgraph cluster_2 {
+    				node [color=green style=filled]
+    				color=lightgrey label="Linux kernel" style=filled
+    				I [label="IIO Drivers" tooltip="Hundreds of drivers for sensors and acutators"]
+    				r [label=greybus tooltip="Dynamic RPC-like bus interface for I2C, SPI, UART, etc."]
+    				n [label="gb-netlink**" tooltip="Extend Greybus over netlink to userspace"]
+    				m [label="mikrobus**" tooltip="Board-level abstraction to identify sensor connections"]
+    				w [label="wpanusb**" tooltip="USB-interface to IEEE802.15.4 radio"]
+    				i [label=ieee802154 tooltip="Standards-based radio interface"]
+    				6 [label=lowpan tooltip="IPv6 for low-power wireless networks"]
+    			}
+    		}
+    		subgraph cluster_3 {
+    			color=black label="BCF gateway"
+    			subgraph cluster_4 {
+    				node [color=green style=filled]
+    				color=lightgrey label=CC1352 style=filled
+    				z [label="gateway**" tooltip="Zephyr-based IEEE802.15.4 radio accepting HDLC over UART transactions"]
+    			}
+    			subgraph cluster_5 {
+    				node [color=green style=filled]
+    				color=lightgrey label=MSP430 style=filled
+    				b [label="usb_uart_bridge**" tooltip="USB interace to access CC1352 UART that encapulates WPANUSB in HDLC"]
+    			}
+    		}
+    		subgraph cluster_6 {
+    			color=black label="BCF node"
+    			subgraph cluster_7 {
+    				node [color=green style=filled]
+    				color=lightgrey label=CC1352 style=filled
+    				k [label="greybus-mikrobus**" tooltip="Zephyr-based applies Greybus transactions from IPv6/IEEE802154 to physical I2C, SPI, UART, etc."]
+    			}
+    			subgraph cluster_8 {
+    				node [color=green style=filled]
+    				color=lightgrey label="mikroBUS add-on board" style=filled
+    				e [label="manifest 1-wire EEPROM**" tooltip="Manifest for mikroBUS driver"]
+    				s [label=sensor tooltip="Over 1,000 different sensor, actuator and indicator options"]
+    			}
+    		}
+    		A -> I
+    		I -> m
+    		m -> r
+    		r -> n
+    		n -> g
+    		g -> 6
+    		6 -> i
+    		i -> w
+    		w -> b
+    		b -> z
+    		z -> k
+    		k -> s
+    		k -> e
+    	}
+
+
+TODO items
+**********
+
+.. todo::  Click Board plug-ins for node-red for the same 100 or so Click Boards
+
+.. todo:: BeagleConnectâ„¢ Freedom System Reference Manual and FAQs
+
+
+Associated pre-work
+*******************
+
+* Click Board support for Node-RED can be executed with native connections on 
+  PocketBeagle+TechLab and BeagleBone Black with mikroBUS Cape
+
+* Device tree fragments and driver updates can be provided via 
+  https://bbb.io/click
+
+* The Kconfig style provisioning can be implemented for those solutions, which 
+  will require a reboot. We need to centralize edits to /boot/uEnv.txt to be 
+  programmatic. As I think through this, I don't think BeagleConnect is 
+  impacted, because the Greybus-style discovery along with Click EEPROMS will 
+  eliminate any need to edit /boot/uEnv.txt.
+
+User experience concerns
+************************
+
+* Make sure no reboots are required
+
+* Plugging BeagleConnect into host should trigger host configuration
+
+* Click EEPROMs should trigger loading whatever drivers are needed and 
+  provisioning should load any new drivers
+
+* Userspace (spidev, etc.) drivers should unload cleanly when 2nd phase 
+  provisioning is completed
+
+BeagleConnectâ„¢ Greybus demo using BeagleConnectâ„¢ Freedom
+********************************************************
+BeagleConnectâ„¢ Freedom runs a subGHz IEEE 802.15.4 network. This BeagleConnectâ„¢
+Greybus demo shows how to interact with GPIO, I2C and mikroBUS add-on boards 
+remotely connected over a BeagleConnectâ„¢ Freedom.
+
+This section starts with the steps required to use 
+`Linux <https://en.wikipedia.org/wiki/Linux>`_ embedded computer 
+(`BeagleBone Green Gateway <https://wiki.seeedstudio.com/BeagleBone-Green-Gateway/>`_) 
+and the `Greybus <https://lwn.net/Articles/715955/>`_ protocol, over an 
+IEEE 802.15.4 wireless link, to blink an LED on a 
+`Zephyr <https://zephyrproject.org/>`_ device.
+
+Introduction
+============
+
+*Why??*
+
+Good question. Blinking an LED is kind of the 
+`Hello, World <https://en.wikipedia.org/wiki/%22Hello,_World!%22_program>`_ of 
+the hardware community. In this case, we're less interested in the mechanics 
+of switching a GPIO to drive some current through an LED and more interested in
+how that happens with the 
+`Internet of Things (IoT) <https://en.wikipedia.org/wiki/Internet_of_things>`_.
+
+There are several existing network and application layers that are driven by 
+corporate heavyweights and industry consortiums, but relatively few that are 
+community driven and, more specifically, even fewer that have the ability to 
+integrate so tightly with the Linux kernel.
+
+The goal here is to provide a community-maintained, developer-friendly, and 
+open-source protocol for the Internet of Things using the Greybus Protocol, and
+blinking an LED using Greybus is the simplest proof-of-concept for that. All 
+that is required is a reliable transport.
+
+#. Power a BeagleConnect Freedom that has not yet been programmed via a USB 
+   power source, not the BeagleBone Green Gateway. You'll hear a click every 
+   1-2 seconds along with seeing 4 of the LEDs turn off and on.
+
+#. In an isolated terminal window, :code:`sudo beagleconnect-start-gateway`
+
+#. :code:`sensortest-rx.py`
+
+Every 1-2 minutes, you should see something like:
+
+.. code-block:: bash
+
+    ('fe80::3111:7a22:4b:1200%lowpan0', 52213, 0, 13)  '2l:7.79;'
+    ('fe80::3111:7a22:4b:1200%lowpan0', 52213, 0, 13)  '4h:43.75;4t:23.11;'
+
+The value after "2l:" is the amount of light in lux. The value after "4h:" is 
+the relative humidity and after "4t:" is the temperature in Celsius.
+
+Flash BeagleConnectâ„¢ Freedom node device with Greybus firmware
+==============================================================
+
+#TODO: How can we add a step in here to show the network is connected without needing gbridge to be fully functional?
+
+Do this from the BeagleBone® Green Gateway board that was previously used to 
+program the BeagleConnectâ„¢ Freedom gateway device:
+
+#. Disconnect the BeagleConnectâ„¢ Freedom **gateway** device
+
+#. Connect a new BeagleConnectâ„¢ Freedom board via USB
+
+#. :code:`sudo systemctl stop lowpan.service`
+
+#. :code:`cc2538-bsl.py /usr/share/beagleconnect/cc1352/greybus_mikrobus_beagleconnect.bin /dev/ttyACM0`
+
+#. After it finishes programming successfully, disconnect the BeagleConnect Freedom node device
+
+#. Power the newly programmed BeagleConnect Freedom node device from an alternate USB power source
+
+#. Reconnect the BeagleConnect Freedom **gateway** device to the BeagleBone Green Gateway
+
+#. :code:`sudo systemctl start lowpan.service`
+
+#. :code:`sudo beagleconnect-start-gateway`
+
+.. code-block:: bash
+
+    debian@beaglebone:~$ sudo beagleconnect-start-gateway
+    [sudo] password for debian:
+    setting up wpanusb gateway for IEEE 802154 CHANNEL 1(906 Mhz)
+    ping6: Warning: source address might be selected on device other than lowpan0.
+    PING 2001:db8::1(2001:db8::1) from ::1 lowpan0: 56 data bytes
+    64 bytes from 2001:db8::1: icmp_seq=2 ttl=64 time=185 ms
+    64 bytes from 2001:db8::1: icmp_seq=3 ttl=64 time=40.9 ms
+    64 bytes from 2001:db8::1: icmp_seq=4 ttl=64 time=40.9 ms
+    64 bytes from 2001:db8::1: icmp_seq=5 ttl=64 time=40.6 ms
+
+    --- 2001:db8::1 ping statistics ---
+    5 packets transmitted, 4 received, 20% packet loss, time 36ms
+    rtt min/avg/max/mdev = 40.593/76.796/184.799/62.356 ms
+    debian@beaglebone:~$ iio_info
+    Library version: 0.19 (git tag: v0.19)
+    Compiled with backends: local xml ip usb serial
+    IIO context created with local backend.
+    Backend version: 0.19 (git tag: v0.19)
+    Backend description string: Linux beaglebone 5.14.18-bone20 #1buster PREEMPT Tue Nov 16 20:47:19 UTC 2021 armv7l
+    IIO context has 1 attributes:
+        local,kernel: 5.14.18-bone20
+    IIO context has 3 devices:
+        iio:device0: TI-am335x-adc.0.auto (buffer capable)
+            8 channels found:
+                voltage0:  (input, index: 0, format: le:u12/16>>0)
+                1 channel-specific attributes found:
+                    attr  0: raw value: 1412
+                voltage1:  (input, index: 1, format: le:u12/16>>0)
+                1 channel-specific attributes found:
+                    attr  0: raw value: 2318
+                voltage2:  (input, index: 2, format: le:u12/16>>0)
+                1 channel-specific attributes found:
+                    attr  0: raw value: 2631
+                voltage3:  (input, index: 3, format: le:u12/16>>0)
+                1 channel-specific attributes found:
+                    attr  0: raw value: 817
+                voltage4:  (input, index: 4, format: le:u12/16>>0)
+                1 channel-specific attributes found:
+                    attr  0: raw value: 881
+                voltage5:  (input, index: 5, format: le:u12/16>>0)
+                1 channel-specific attributes found:
+                    attr  0: raw value: 0
+                voltage6:  (input, index: 6, format: le:u12/16>>0)
+                1 channel-specific attributes found:
+                    attr  0: raw value: 0
+                voltage7:  (input, index: 7, format: le:u12/16>>0)
+                1 channel-specific attributes found:
+                    attr  0: raw value: 1180
+            2 buffer-specific attributes found:
+                    attr  0: data_available value: 0
+                    attr  1: watermark value: 1
+        iio:device1: hdc2010
+            3 channels found:
+                humidityrelative:  (input)
+                3 channel-specific attributes found:
+                    attr  0: peak_raw value: 52224
+                    attr  1: raw value: 52234
+                    attr  2: scale value: 1.525878906
+                current:  (output)
+                2 channel-specific attributes found:
+                    attr  0: heater_raw value: 0
+                    attr  1: heater_raw_available value: 0 1
+                temp:  (input)
+                4 channel-specific attributes found:
+                    attr  0: offset value: -15887.515151
+                    attr  1: peak_raw value: 25600
+                    attr  2: raw value: 25628
+                    attr  3: scale value: 2.517700195
+        iio:device2: opt3001
+            1 channels found:
+                illuminance:  (input)
+                2 channel-specific attributes found:
+                    attr  0: input value: 79.040000
+                    attr  1: integration_time value: 0.800000
+            2 device-specific attributes found:
+                    attr  0: current_timestamp_clock value: realtime
+
+                    attr  1: integration_time_available value: 0.1 0.8
+    debian@beaglebone:~$ dmesg | grep -e mikrobus -e greybus
+    [  100.491253] greybus 1-2.2: Interface added (greybus)
+    [  100.491294] greybus 1-2.2: GMP VID=0x00000126, PID=0x00000126
+    [  100.491306] greybus 1-2.2: DDBL1 Manufacturer=0x00000126, Product=0x00000126
+    [  100.737637] greybus 1-2.2: excess descriptors in interface manifest
+    [  102.475168] mikrobus:mikrobus_port_gb_register: mikrobus gb_probe , num cports= 2, manifest_size 192
+    [  102.475206] mikrobus:mikrobus_port_gb_register: protocol added 3
+    [  102.475214] mikrobus:mikrobus_port_gb_register: protocol added 2
+    [  102.475239] mikrobus:mikrobus_port_register: registering port mikrobus-1
+    [  102.475400] mikrobus_manifest:mikrobus_state_get: mikrobus descriptor not found
+    [  102.475417] mikrobus_manifest:mikrobus_manifest_attach_device: parsed device 1, driver=opt3001, protocol=3, reg=44
+    [  102.494516] mikrobus_manifest:mikrobus_manifest_attach_device: parsed device 2, driver=hdc2010, protocol=3, reg=41
+    [  102.494567] mikrobus_manifest:mikrobus_manifest_parse:  (null) manifest parsed with 2 devices
+    [  102.494592] mikrobus mikrobus-1: registering device : opt3001
+    [  102.495096] mikrobus mikrobus-1: registering device : hdc2010
+    debian@beaglebone:~$
+
+
+#TODO: update the below for the built-in sensors
+
+#TODO: can we also handle the case where these sensors are included and recommend them? Same firmware?
+
+#TODO: the current demo is for the built-in sensors, not the Click boards mentioned below
+
+Currently only a limited number of add-on boards have been tested to work over Greybus, simple add-on boards without interrupt requirement are the ones that work currently. The example is for Air Quality 2 Click and Weather Click attached to the mikroBUS ports on the device side.
+
+/var/log/gbridge will have the gbridge log, and if the mikroBUS port has been instantiated successfully the kernel log will show the devices probe messages:
+
+#TODO: this log needs to be updated
+
+.. code-block::
+
+    greybus 1-2.2: GMP VID=0x00000126, PID=0x00000126
+    greybus 1-2.2: DDBL1 Manufacturer=0x00000126, Product=0x00000126
+    greybus 1-2.2: excess descriptors in interface manifest
+    mikrobus:mikrobus_port_gb_register: mikrobus gb_probe , num cports= 3, manifest_size 252
+    mikrobus:mikrobus_port_gb_register: protocol added 11
+    mikrobus:mikrobus_port_gb_register: protocol added 3
+    mikrobus:mikrobus_port_gb_register: protocol added 2
+    mikrobus:mikrobus_port_register: registering port mikrobus-0
+    mikrobus_manifest:mikrobus_manifest_attach_device: parsed device 1, driver=bme280, protocol=3, reg=76
+    mikrobus_manifest:mikrobus_manifest_attach_device: parsed device 2, driver=ams-iaq-core, protocol=3, reg=5a
+    mikrobus_manifest:mikrobus_manifest_parse:  Greybus Service Sample Application manifest parsed with 2 devices
+    mikrobus mikrobus-0: registering device : bme280
+    mikrobus mikrobus-0: registering device : ams-iaq-core
+
+
+#TODO: bring in the GPIO toggle and I2C explorations for greater understanding
+
+Flashing via a Linux Host
+-------------------------
+
+If flashing the Freedom board via the BeagleBone fails here's a trick you can try to flash from a Linux host.
+
+Use :code:`sshfs` to mount the Bone's files on the Linux host. This assumes the
+Bone is plugged in the USB and appears at :code:`192.168.7.2`:
+
+.. code-block:: bash
+
+    host$ cd
+    host$ sshfs 192.168.7.2:/ bone
+    host$ cd bone; ls
+    bin   dev  home    lib         media  opt   root  sbin  sys  usr
+    boot  etc  ID.txt  lost+found  mnt    proc  run   srv   tmp  var
+    host$ ls /dev/ttyACM*
+    /dev/ttyACM1
+
+
+
+The Bone's files now appear as local files. Notice there is already a 
+:code:`/dev/ACM*` appearing. Now plug the Connect into the Linux host's USB 
+port and run the command again.
+
+.. code-block:: bash
+
+    host$ ls /dev/ttyACM*
+    /dev/ttyACM0  /dev/ttyACM1
+
+The :code:`/dev/ttyACM` that just appeared is the one associated with the 
+Connect. In my case it's :code:`/dev/ttyACM0`. That's what I'll use in this 
+example.
+
+Now change directories to where the binaries are and load:
+
+.. code-block:: bash
+
+    host$ cd ~/bone/usr/share/beagleconnect/cc1352;ls
+    greybus_mikrobus_beagleconnect.bin     sensortest_beagleconnect.dts
+    greybus_mikrobus_beagleconnect.config  wpanusb_beagleconnect.bin
+    greybus_mikrobus_beagleconnect.dts     wpanusb_beagleconnect.config
+    sensortest_beagleconnect.bin           wpanusb_beagleconnect.dts
+    sensortest_beagleconnect.config
+
+    host$ ~/bone/usr/bin/cc2538-bsl.py sensortest_beagleconnect.bin /dev/ttyACM0
+    8-bsl.py sensortest_beagleconnect.bin /dev/ttyACM0
+    Opening port /dev/ttyACM0, baud 50000
+    Reading data from sensortest_beagleconnect.bin
+    Cannot auto-detect firmware filetype: Assuming .bin
+    Connecting to target...
+    CC1350 PG2.0 (7x7mm): 352KB Flash, 20KB SRAM, CCFG.BL_CONFIG at 0x00057FD8
+    Primary IEEE Address: 00:12:4B:00:22:7A:10:46
+        Performing mass erase
+    Erasing all main bank flash sectors
+        Erase done
+    Writing 360448 bytes starting at address 0x00000000
+    Write 104 bytes at 0x00057F988
+        Write done
+    Verifying by comparing CRC32 calculations.
+        Verified (match: 0x0f6bdf0f)
+
+Now you are ready to continue the instructions above after the cc2528 command.
+
+Trying for different add-on boards
+==================================
+
+See `mikroBUS over Greybus <https://github.com/vaishnav98/greybus-for-zephyr/tree/mikrobus#trying-out-different-add-on-boardsdevices-over-mikrobus>`_ 
+for trying out the same example for different mikroBUS add-on boards/ on-board devices.
+
+Observe the node device
+=======================
+
+Connect BeagleConnect Freedom node device to an Ubuntu laptop to observe the 
+Zephyr console.
+
+
+Console (:code:`tio`)
+---------------------
+In order to see diagnostic messages or to run certain commands on the Zephyr 
+device we will require a terminal open to the device console. In this case, we
+use `tio <https://tio.github.io/>`_ due how its usage simplifies the 
+instructions.
+
+#. Install :code:`tio`
+   :code:`sudo apt install -y tio`
+
+#. Run :code:`tio`
+   :code:`tio /dev/ttyACM0`
+
+ To exit :code:`tio` (later), enter :code:`ctrl+t, q`. 
+
+
+The Zephyr Shell
+----------------
+
+After flashing, you should observe the something matching the following output in :code:`tio`.
+
+.. code-block:: bash
+
+    uart:~$ *** Booting Zephyr OS build 9c858c863223  ***
+    [00:00:00.009,735] <inf> greybus_transport_tcpip: CPort 0 mapped to TCP/IP port 4242
+    [00:00:00.010,131] <inf> greybus_transport_tcpip: CPort 1 mapped to TCP/IP port 4243
+    [00:00:00.010,528] <inf> greybus_transport_tcpip: CPort 2 mapped to TCP/IP port 4244
+    [00:00:00.010,742] <inf> greybus_transport_tcpip: Greybus TCP/IP Transport initialized
+    [00:00:00.010,864] <inf> greybus_manifest: Registering CONTROL greybus driver.
+    [00:00:00.011,230] <inf> greybus_manifest: Registering GPIO greybus driver.
+    [00:00:00.011,596] <inf> greybus_manifest: Registering I2C greybus driver.
+    [00:00:00.011,871] <inf> greybus_service: Greybus is active
+    [00:00:00.026,092] <inf> net_config: Initializing network
+    [00:00:00.134,063] <inf> net_config: IPv6 address: 2001:db8::1
+
+
+
+The line beginning with :code:`***` is the Zephyr boot banner.
+
+Lines beginning with a timestamp of the form :code:`[H:m:s.us]` are Zephyr 
+kernel messages.
+
+Lines beginning with :code:`uart:~$` indicates that the Zephyr shell is 
+prompting you to enter a command.
+
+From the informational messages shown, we observe the following.
+
+* Zephyr is configured with the following 
+  `link-local IPv6 address <https://en.wikipedia.org/wiki/Link-local_address#IPv6>`_ :code:`fe80::3177:a11c:4b:1200`
+
+* It is listening for (both) TCP and UDP traffic on port 4242
+
+However, what the log messages do not show (which will come into play later), 
+are 2 critical pieces of information:
+
+#. **The RF Channel**: As you may have guessed, IEEE 802.15.4 devices are only 
+   able to communicate with each other if they are using the same frequency to 
+   transmit and receive data. This information is part of the Physical Layer.
+
+#. The `PAN identifier <https://www.silabs.com/community/wireless/proprietary/knowledge-base.entry.html/2019/10/04/connect_tutorial6-ieee802154addressing-rapc>`_: 
+   IEEE 802.15.4 devices are only be able to communicate with one another if 
+   they use the same PAN ID. This permits multiple networks (PANs) on the same 
+   frequency. This information is part of the Data Link Layer.
+
+If we type :code:`help` in the shell and hit Enter, we're prompted with the 
+following:
+
+.. code-block::
+
+    Please press the <Tab> button to see all available commands.
+    You can also use the <Tab> button to prompt or auto-complete all commands or its subcommands.
+    You can try to call commands with <-h> or <--help> parameter for more information.
+    Shell supports following meta-keys:
+
+    Ctrl+a, Ctrl+b, Ctrl+c, Ctrl+d, Ctrl+e, Ctrl+f, Ctrl+k, Ctrl+l, Ctrl+n, Ctrl+p, Ctrl+u, Ctrl+w
+    Alt+b, Alt+f.
+    Please refer to shell documentation for more details.
+
+So after hitting Tab, we see that there are several interesting commands we can
+use for additional information.
+
+.. code-block::
+
+    uart:~$
+    clear       help        history     ieee802154  log         net
+    resize      sample      shell
+
+Zephyr Shell: IEEE 802.15.4 commands
+------------------------------------
+
+Entering :code:`ieee802154 help`, we see
+
+.. code-block::
+
+    uart:~$ ieee802154 help
+    ieee802154 - IEEE 802.15.4 commands
+    Subcommands:
+    ack             :<set/1 | unset/0> Set auto-ack flag
+    associate       :<pan_id> <PAN coordinator short or long address (EUI-64)>
+    disassociate    :Disassociate from network
+    get_chan        :Get currently used channel
+    get_ext_addr    :Get currently used extended address
+    get_pan_id      :Get currently used PAN id
+    get_short_addr  :Get currently used short address
+    get_tx_power    :Get currently used TX power
+    scan            :<passive|active> <channels set n[:m:...]:x|all> <per-channel
+                    duration in ms>
+    set_chan        :<channel> Set used channel
+    set_ext_addr    :<long/extended address (EUI-64)> Set extended address
+    set_pan_id      :<pan_id> Set used PAN id
+    set_short_addr  :<short address> Set short address
+    set_tx_power    :<-18/-7/-4/-2/0/1/2/3/5> Set TX power
+
+
+We get the missing Channel number (frequency) with the command :code:`ieee802154 get_chan`.
+
+.. code-block::
+
+    uart:~$ ieee802154 get_chan
+    Channel 26
+
+We get the missing PAN ID with the command :code:`ieee802154 get_pan_id`.
+
+.. code-block::
+
+    uart:~$ ieee802154 get_pan_id
+    PAN ID 43981 (0xabcd)
+
+Zephyr Shell: Network Commands
+------------------------------
+
+Additionally, we may query the IPv6 information of the Zephyr device.
+
+.. code-block::
+
+    uart:~$ net iface
+
+    Interface 0x20002b20 (IEEE 802.15.4) [1]
+    ========================================
+    Link addr : CD:99:A1:1C:00:4B:12:00
+    MTU       : 125
+    IPv6 unicast addresses (max 3):
+            fe80::cf99:a11c:4b:1200 autoconf preferred infinite
+            2001:db8::1 manual preferred infinite
+    IPv6 multicast addresses (max 4):
+            ff02::1
+            ff02::1:ff4b:1200
+            ff02::1:ff00:1
+    IPv6 prefixes (max 2):
+            <none>
+    IPv6 hop limit           : 64
+    IPv6 base reachable time : 30000
+    IPv6 reachable time      : 16929
+    IPv6 retransmit timer    : 0
+
+
+
+And we see that the static IPv6 address (:code:`2001:db8::1`) from 
+:code:`samples/net/sockets/echo_server/prj.conf` is present and configured. 
+While the statically configured IPv6 address is useful, it isn't 100% necessary.
+
+Rebuilding from source
+======================
+
+#TODO: revisit everything below here
+
+Prerequisites
+-------------
+
+* Zephyr environment is set up according to the 
+  `Getting Started Guide <https://docs.zephyrproject.org/latest/getting_started/index.html>`_
+
+    * Please use the Zephyr SDK when installing a toolchain above
+
+* `Zephyr SDK <https://docs.zephyrproject.org/latest/getting_started/index.html#install-a-toolchain>`_ 
+  is installed at ~/zephyr-sdk-0.11.2 (any later version should be fine as well)
+
+* Zephyr board is connected via USB
+
+Cloning the repository
+----------------------
+
+This repository utilizes `git submodules <https://git-scm.com/book/en/v2/Git-Tools-Submodules>`_ 
+to keep track of all of the projects required to reproduce the ongoing work. 
+The instructions here only cover checking out the :code:`demo` branch which 
+should stay in a tested state. ongoing development will be on the 
+:code:`master` branch.
+
+Note: The parent directory :code:`~` is simply used as a placeholder for testing. 
+Please use whatever parent directory you see fit. 
+
+Clone specific tag
+^^^^^^^^^^^^^^^^^^
+
+.. code-block:: bash
+
+    cd ~
+    git clone --recurse-submodules --branch demo https://github.com/jadonk/beagleconnect
+
+Zephyr
+------
+
+Add the Fork
+^^^^^^^^^^^^
+
+For the time being, Greybus must remain outside of the main Zephyr repository. 
+Currently, it is just in a Zephyr fork, but it should be converted to a 
+proper `Module (External Project) <https://docs.zephyrproject.org/latest/guides/modules.html>`_. 
+This is for a number of reasons, but mainly there must be:
+
+* specifications for authentication and encryption
+
+* specifications for joining and rejoining wireless networks
+
+* specifications for discovery
+
+Therefore, in order to reproduce this example, please run the following.
+
+.. code-block:: bash
+
+    cd ~/beagleconnect/sw/zephyrproject/zephyr
+    west update
+
+Build and Flash Zephyr
+^^^^^^^^^^^^^^^^^^^^^^
+
+Here, we will build and flash the Zephyr 
+`greybus_net sample <https://github.com/cfriedt/zephyr/tree/greybus-sockets/samples/subsys/greybus/net>`_ 
+to our device.
+
+#. Edit the file :code:`~/.zephyrrc` and place the following text inside of it
+
+.. code-block:: bash
+
+    export ZEPHYR_TOOLCHAIN_VARIANT=zephyr
+    export ZEPHYR_SDK_INSTALL_DIR=~/zephyr-sdk-0.11.2
+
+#. Set up the required Zephyr environment variables via
+
+.. code-block:: bash
+
+    source zephyr-env.sh
+
+#. Build the project
+
+.. code-block:: bash
+
+    BOARD=cc1352r1_launchxl west build samples/subsys/greybus/net --pristine \
+    --build-dir build/greybus_launchpad -- -DCONF_FILE="prj.conf overlay-802154.conf"
+
+#. Ensure that the last part of the build process looks somewhat like this:
+
+.. code-block:: bash
+
+    ...
+    [221/226] Linking C executable zephyr/zephyr_prebuilt.elf
+    Memory region         Used Size  Region Size  %age Used
+            FLASH:      155760 B     360360 B     43.22%
+        FLASH_CCFG:          88 B         88 B    100.00%
+                SRAM:       58496 B        80 KB     71.41%
+            IDT_LIST:         184 B         2 KB      8.98%
+    [226/226] Linking C executable zephyr/zephyr.elf
+
+#. Flash the firmware to your device using
+
+.. code-block:: bash
+
+    BOARD=cc1352r1_launchxl west flash --build-dir build/greybus_launchpad
+
+Linux
+-----
+
+Warning: If you aren't comfortable building and installing a Linux kernel on 
+your computer, you should probably just stop here. I'll assume you know the 
+basics of building and installing a Linux kernel from here on out. 
+
+Clone, patch, and build the kernel
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+For this demo, I used the 5.8.4 stable kernel. Also, I've applied the 
+:code:`mikrobus` kernel driver, though it isn't strictly required for greybus.
+
+Note: The parent directory :code:`~` is simply used as a placeholder for testing. 
+Please use whatever parent directory you see fit. 
+
+TODO: The patches for gb-netlink will eventually be applied here until pushed into mainline.
+
+.. code-block:: bash
+
+    cd ~
+    git clone --branch v5.8.4 --single-branch git://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
+    cd linux
+    git checkout -b v5.8.4-greybus
+    git am ~/beagleconnect/sw/linux/v2-0001-RFC-mikroBUS-driver-for-add-on-boards.patch
+    git am ~/beagleconnect/sw/linux/0001-mikroBUS-build-fixes.patch
+    cp /boot/config-`uname -r` .config
+    yes "" | make oldconfig
+    ./scripts/kconfig/merge_config.sh .config ~/beagleconnect/sw/linux/mikrobus.config
+    ./scripts/kconfig/merge_config.sh .config ~/beagleconnect/sw/linux/atusb.config
+    make -j`nproc --all`
+    sudo make modules_install
+    sudo make install
+
+Reboot and select your new kernel.
+
+Probe the IEEE 802.15.4 Device Driver
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+On the Linux machine, make sure the :code:`atusb` driver is loaded. This should
+happen automatically when the adapter is inserted or when the machine is booted
+while the adapter is installed.
+
+.. code-block:: bash
+
+    $ dmesg | grep -i ATUSB
+    [    6.512154] usb 1-1: ATUSB: AT86RF231 version 2
+    [    6.512492] usb 1-1: Firmware: major: 0, minor: 3, hardware type: ATUSB (2)
+    [    6.525357] usbcore: registered new interface driver atusb
+    ...
+
+
+
+We should now be able to see the IEEE 802.15.4 network device by entering :code:`ip a show wpan0`.
+
+.. code-block:: bash
+
+    $ ip a show wpan0
+    36: wpan0: <BROADCAST,NOARP,UP,LOWER_UP> mtu 123 qdisc fq_codel state UNKNOWN group default qlen 300
+        link/ieee802.15.4 3e:7d:90:4d:8f:00:76:a2 brd ff:ff:ff:ff:ff:ff:ff:ff
+
+
+But wait, that is not an IP address! It's the hardware address of the 802.15.4 
+device. So, in order to associate it with an IP address, we need to run a 
+couple of other commands (thanks to wpan.cakelab.org).
+
+Set the 802.15.4 Physical and Link-Layer Parameters
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+#. First, get the phy number for the :code:`wpan0` device
+
+.. code-block:: bash
+
+    $ iwpan list
+        wpan_phy phy0
+        supported channels:
+            page 0: 11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26
+        current_page: 0
+        current_channel: 26,  2480 MHz
+        cca_mode: (1) Energy above threshold
+        cca_ed_level: -77
+        tx_power: 3
+        capabilities:
+            iftypes: node,monitor
+            channels:
+                page 0:
+                    [11]  2405 MHz, [12]  2410 MHz, [13]  2415 MHz,
+                    [14]  2420 MHz, [15]  2425 MHz, [16]  2430 MHz,
+                    [17]  2435 MHz, [18]  2440 MHz, [19]  2445 MHz,
+                    [20]  2450 MHz, [21]  2455 MHz, [22]  2460 MHz,
+                    [23]  2465 MHz, [24]  2470 MHz, [25]  2475 MHz,
+                    [26]  2480 MHz
+            tx_powers:
+                    3 dBm, 2.8 dBm, 2.3 dBm, 1.8 dBm, 1.3 dBm, 0.7 dBm,
+                    0 dBm, -1 dBm, -2 dBm, -3 dBm, -4 dBm, -5 dBm,
+                    -7 dBm, -9 dBm, -12 dBm, -17 dBm,
+            cca_ed_levels:
+                    -91 dBm, -89 dBm, -87 dBm, -85 dBm, -83 dBm, -81 dBm,
+                    -79 dBm, -77 dBm, -75 dBm, -73 dBm, -71 dBm, -69 dBm,
+                    -67 dBm, -65 dBm, -63 dBm, -61 dBm,
+            cca_modes:
+                (1) Energy above threshold
+                (2) Carrier sense only
+                (3, cca_opt: 0) Carrier sense with energy above threshold (logical operator is 'and')
+                (3, cca_opt: 1) Carrier sense with energy above threshold (logical operator is 'or')
+            min_be: 0,1,2,3,4,5,6,7,8
+            max_be: 3,4,5,6,7,8
+            csma_backoffs: 0,1,2,3,4,5
+            frame_retries: 3
+            lbt: false
+
+#. Next, set the Channel for the 802.15.4 device on the Linux machine
+
+.. code-block:: bash
+
+    sudo iwpan phy phy0 set channel 0 26
+
+#. Then, set the PAN identifier for the 802.15.4 device on the Linux machine :code:`sudo iwpan dev wpan0 set pan_id 0xabcd`
+
+#. Associate the :code:`wpan0` device to a new, 6lowpan network interface
+
+.. code-block:: bash
+
+    sudo ip link add link wpan0 name lowpan0 type lowpan
+
+#. Finally, set the links up for both :code:`wpan0` and :code:`lowpan0`
+
+.. code-block:: bash
+
+    sudo ip link set wpan0 up
+    sudo ip link set lowpan0 up
+
+
+
+We should observe something like the following when we run :code:`ip a show lowpan0`.
+
+.. code-block:: bash
+
+    ip a show lowpan0
+    37: lowpan0@wpan0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1280 qdisc noqueue state UNKNOWN group default qlen 1000
+        link/6lowpan 9e:0b:a4:e8:00:d3:45:53 brd ff:ff:ff:ff:ff:ff:ff:ff
+        inet6 fe80::9c0b:a4e8:d3:4553/64 scope link
+        valid_lft forever preferred_lft forever
+
+Ping Pong
+=========
+
+Broadcast Ping
+--------------
+
+Now, perform a broadcast ping to see what else is listening on :code:`lowpan0`.
+
+.. code-block::
+
+    $ ping6 -I lowpan0 ff02::1
+    PING ff02::1(ff02::1) from fe80::9c0b:a4e8:d3:4553%lowpan0 lowpan0: 56 data bytes
+    64 bytes from fe80::9c0b:a4e8:d3:4553%lowpan0: icmp_seq=1 ttl=64 time=0.099 ms
+    64 bytes from fe80::9c0b:a4e8:d3:4553%lowpan0: icmp_seq=2 ttl=64 time=0.125 ms
+    64 bytes from fe80::cf99:a11c:4b:1200%lowpan0: icmp_seq=2 ttl=64 time=17.3 ms (DUP!)
+    64 bytes from fe80::9c0b:a4e8:d3:4553%lowpan0: icmp_seq=3 ttl=64 time=0.126 ms
+    64 bytes from fe80::cf99:a11c:4b:1200%lowpan0: icmp_seq=3 ttl=64 time=9.60 ms (DUP!)
+    64 bytes from fe80::9c0b:a4e8:d3:4553%lowpan0: icmp_seq=4 ttl=64 time=0.131 ms
+    64 bytes from fe80::cf99:a11c:4b:1200%lowpan0: icmp_seq=4 ttl=64 time=14.9 ms (DUP!)
+
+Yay! We have pinged (pung?) the Zephyr device over IEEE 802.15.4 using 6LowPAN!
+
+Ping Zephyr
+-----------
+
+We can ping the Zephyr device directly without a broadcast ping too, of course.
+
+.. code-block::
+
+    $ ping6 -I lowpan0 fe80::cf99:a11c:4b:1200
+    PING fe80::cf99:a11c:4b:1200(fe80::cf99:a11c:4b:1200) from fe80::9c0b:a4e8:d3:4553%lowpan0 lowpan0: 56 data bytes
+    64 bytes from fe80::cf99:a11c:4b:1200%lowpan0: icmp_seq=1 ttl=64 time=16.0 ms
+    64 bytes from fe80::cf99:a11c:4b:1200%lowpan0: icmp_seq=2 ttl=64 time=13.8 ms
+    64 bytes from fe80::cf99:a11c:4b:1200%lowpan0: icmp_seq=3 ttl=64 time=9.77 ms
+    64 bytes from fe80::cf99:a11c:4b:1200%lowpan0: icmp_seq=5 ttl=64 time=11.5 ms
+
+Ping Linux
+----------
+
+Similarly, we can ping the Linux host from the Zephyr shell.
+
+.. code-block:: bash
+
+    uart:~$ net ping --help
+    ping - Ping a network host.
+    Subcommands:
+    --help  :'net ping [-c count] [-i interval ms] <host>' Send ICMPv4 or ICMPv6
+            Echo-Request to a network host.
+    $ net ping -c 5 fe80::9c0b:a4e8:d3:4553
+    PING fe80::9c0b:a4e8:d3:4553
+    8 bytes from fe80::9c0b:a4e8:d3:4553 to fe80::cf99:a11c:4b:1200: icmp_seq=0 ttl=64 rssi=110 time=11 ms
+    8 bytes from fe80::9c0b:a4e8:d3:4553 to fe80::cf99:a11c:4b:1200: icmp_seq=1 ttl=64 rssi=126 time=9 ms
+    8 bytes from fe80::9c0b:a4e8:d3:4553 to fe80::cf99:a11c:4b:1200: icmp_seq=2 ttl=64 rssi=128 time=13 ms
+    8 bytes from fe80::9c0b:a4e8:d3:4553 to fe80::cf99:a11c:4b:1200: icmp_seq=3 ttl=64 rssi=126 time=10 ms
+    8 bytes from fe80::9c0b:a4e8:d3:4553 to fe80::cf99:a11c:4b:1200: icmp_seq=4 ttl=64 rssi=126 time=7 ms
+
+Assign a Static Address
+=======================
+
+So far, we have been using IPv6 Link-Local addressing. However, the Zephyr 
+application is configured to use a statically configured IPv6 address as well 
+which is, namely :code:`2001:db8::1`.
+
+If we add a similar static IPv6 address to our Linux IEEE 802.15.4 network 
+interface, :code:`lowpan0`, then we should expect to be able to reach that as 
+well.
+
+In Linux, run the following
+
+.. code-block:: bash
+
+    sudo ip -6 addr add 2001:db8::2/64 dev lowpan0
+
+We can verify that the address has been set by examining the :code:`lowpan0` 
+network interface again.
+
+.. code-block:: bash
+
+    $ ip a show lowpan0
+    37: lowpan0@wpan0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1280 qdisc noqueue state UNKNOWN group default qlen 1000
+        link/6lowpan 9e:0b:a4:e8:00:d3:45:53 brd ff:ff:ff:ff:ff:ff:ff:ff
+        inet6 2001:db8::2/64 scope global
+        valid_lft forever preferred_lft forever
+        inet6 fe80::9c0b:a4e8:d3:4553/64 scope link
+        valid_lft forever preferred_lft forever
+
+Lastly, ping the statically configured IPv6 address of the Zephyr device.
+
+.. code-block::
+
+    $ ping6 2001:db8::1
+    PING 2001:db8::1(2001:db8::1) 56 data bytes
+    64 bytes from 2001:db8::1: icmp_seq=2 ttl=64 time=53.7 ms
+    64 bytes from 2001:db8::1: icmp_seq=3 ttl=64 time=13.1 ms
+    64 bytes from 2001:db8::1: icmp_seq=4 ttl=64 time=22.0 ms
+    64 bytes from 2001:db8::1: icmp_seq=5 ttl=64 time=22.7 ms
+    64 bytes from 2001:db8::1: icmp_seq=6 ttl=64 time=18.4 ms
+
+Now that we have set up a reliable transport, let's move on to the application 
+layer.
+
+
+Greybus
+=======
+
+Hopefully the videos listed earlier provide a sufficient foundation to 
+understand what will happen shortly. However, there is still a bit more 
+preparation required.
+
+Build and probe Greybus Kernel Modules
+--------------------------------------
+
+Greybus was originally intended to work exclusively on the UniPro physical 
+layer. However, we're using RF as our physical layer and TCP/IP as our 
+transport. As such, there was need to be able to communicate with the Linux 
+Greybus facilities through userspace, and out of that need arose gb-netlink. 
+The Netlink Greybus module actually does not care about the physical layer, but
+is happy to usher Greybus messages back and forth between the kernel and 
+userspace.
+
+Build and probe the gb-netlink modules (as well as the other Greybus modules) 
+with the following:
+
+.. code-block:: bash
+
+    cd ${WORKSPACE}/sw/greybus
+    make -j`nproc --all`
+    sudo make install
+    ../load_gb_modules.sh
+
+Build and Run Gbridge
+---------------------
+
+The gbridge utility was created as a proof of concept to abstract the Greybus 
+Netlink datapath among several reliable transports. For the purposes of this 
+tutorial, we'll be using it as a TCP/IP bridge.
+
+To run :code:`gbridge`, perform the following:
+
+.. code-block:: bash
+
+    sudo apt install -y libnl-3-dev libnl-genl-3-dev libbluetooth-dev libavahi-client-dev
+    cd gbridge
+    autoreconf -vfi
+    GBNETLINKDIR=${PWD}/../greybus \
+    ./configure --enable-uart --enable-tcpip --disable-gbsim --enable-netlink --disable-bluetooth
+    make -j`nproc --all`
+    sudo make install
+    gbridge
+
+
+Blinky!
+=======
+
+Now that we have set up a reliable TCP transport, and set up the Greybus 
+modules in the Linux kernel, and used Gbridge to connect a Greybus node to the 
+Linux kernel via TCP/IP, we can now get to the heart of the demonstration!
+
+First, save the following script as :code:`blinky.sh`.
+
+.. code-block:: bash
+
+    #!/bin/bash
+    
+    # Blinky Demo for CC1352R SensorTag
+    
+    # /dev/gpiochipN that Greybus created
+    CHIP="$(gpiodetect | grep greybus_gpio | head -n 1 | awk '{print $1}')"
+    
+    # red, green, blue LED pins
+    RED=6
+    GREEN=7
+    BLUE=21
+    
+    # Bash array for pins and values
+    PINS=($RED $GREEN $BLUE)
+    NPINS=${#PINS[@]}
+    
+    for ((;;)); do
+        for i in ${!PINS[@]}; do
+            # turn off previous pin
+            if [ $i -eq 0 ]; then
+                PREV=2
+            else
+                PREV=$((i-1))
+            fi
+            gpioset $CHIP ${PINS[$PREV]}=0
+    
+            # turn on current pin
+            gpioset $CHIP ${PINS[$i]}=1
+    
+            # wait a sec
+            sleep 1
+        done
+    done
+
+
+Second, run the script with root privileges: :code:`sudo bash blinky.sh`
+
+The output of your minicom session should resemble the following.
+
+.. code-block::
+
+    $ *** Booting Zephyr OS build zephyr-v2.3.0-1435-g40c0ed940d71  ***
+    [00:00:00.011,932] <inf> net_config: Initializing network
+    [00:00:00.111,938] <inf> net_config: IPv6 address: fe80::6c42:bc1c:4b:1200
+    [00:00:00.112,121] <dbg> greybus_service.greybus_service_init: Greybus initializing..
+    [00:00:00.112,426] <dbg> greybus_transport_tcpip.gb_transport_backend_init: Greybus TCP/IP Transport initializing..
+    [00:00:00.112,579] <dbg> greybus_transport_tcpip.netsetup: created server socket 0 for cport 0
+    [00:00:00.112,579] <dbg> greybus_transport_tcpip.netsetup: setting socket options for socket 0
+    [00:00:00.112,609] <dbg> greybus_transport_tcpip.netsetup: binding socket 0 (cport 0) to port 4242
+    [00:00:00.112,640] <dbg> greybus_transport_tcpip.netsetup: listening on socket 0 (cport 0)
+    [00:00:00.112,823] <dbg> greybus_transport_tcpip.netsetup: created server socket 1 for cport 1
+    [00:00:00.112,823] <dbg> greybus_transport_tcpip.netsetup: setting socket options for socket 1
+    [00:00:00.112,854] <dbg> greybus_transport_tcpip.netsetup: binding socket 1 (cport 1) to port 4243
+    [00:00:00.112,854] <dbg> greybus_transport_tcpip.netsetup: listening on socket 1 (cport 1)
+    [00:00:00.113,037] <inf> net_config: IPv6 address: fe80::6c42:bc1c:4b:1200
+    [00:00:00.113,250] <dbg> greybus_transport_tcpip.netsetup: created server socket 2 for cport 2
+    [00:00:00.113,250] <dbg> greybus_transport_tcpip.netsetup: setting socket options for socket 2
+    [00:00:00.113,281] <dbg> greybus_transport_tcpip.netsetup: binding socket 2 (cport 2) to port 4244
+    [00:00:00.113,311] <dbg> greybus_transport_tcpip.netsetup: listening on socket 2 (cport 2)
+    [00:00:00.113,494] <dbg> greybus_transport_tcpip.netsetup: created server socket 3 for cport 3
+    [00:00:00.113,494] <dbg> greybus_transport_tcpip.netsetup: setting socket options for socket 3
+    [00:00:00.113,525] <dbg> greybus_transport_tcpip.netsetup: binding socket 3 (cport 3) to port 4245
+    [00:00:00.113,555] <dbg> greybus_transport_tcpip.netsetup: listening on socket 3 (cport 3)
+    [00:00:00.113,861] <inf> greybus_transport_tcpip: Greybus TCP/IP Transport initialized
+    [00:00:00.116,149] <inf> greybus_service: Greybus is active
+    [00:00:00.116,546] <dbg> greybus_transport_tcpip.accept_loop: calling poll
+    [00:45:08.397,399] <dbg> greybus_transport_tcpip.accept_loop: poll returned 1
+    [00:45:08.397,399] <dbg> greybus_transport_tcpip.accept_loop: socket 0 (cport 0) has traffic
+    [00:45:08.397,491] <dbg> greybus_transport_tcpip.accept_loop: accepted connection from [2001:db8::2]:39638 as fd 4
+    [00:45:08.397,491] <dbg> greybus_transport_tcpip.accept_loop: spawning client thread..
+    [00:45:08.397,735] <dbg> greybus_transport_tcpip.accept_loop: calling poll
+    [00:45:08.491,363] <dbg> greybus_transport_tcpip.accept_loop: poll returned 1
+    [00:45:08.491,363] <dbg> greybus_transport_tcpip.accept_loop: socket 3 (cport 3) has traffic
+    [00:45:08.491,455] <dbg> greybus_transport_tcpip.accept_loop: accepted connection from [2001:db8::2]:39890 as fd 5
+    [00:45:08.491,455] <dbg> greybus_transport_tcpip.accept_loop: spawning client thread..
+    [00:45:08.491,699] <dbg> greybus_transport_tcpip.accept_loop: calling poll
+    [00:45:08.620,056] <dbg> greybus_transport_tcpip.accept_loop: poll returned 1
+    [00:45:08.620,086] <dbg> greybus_transport_tcpip.accept_loop: socket 2 (cport 2) has traffic
+    [00:45:08.620,147] <dbg> greybus_transport_tcpip.accept_loop: accepted connection from [2001:db8::2]:42422 as fd 6
+    [00:45:08.620,147] <dbg> greybus_transport_tcpip.accept_loop: spawning client thread..
+    [00:45:08.620,422] <dbg> greybus_transport_tcpip.accept_loop: calling poll
+    [00:45:08.679,504] <dbg> greybus_transport_tcpip.accept_loop: poll returned 1
+    [00:45:08.679,534] <dbg> greybus_transport_tcpip.accept_loop: socket 1 (cport 1) has traffic
+    [00:45:08.679,595] <dbg> greybus_transport_tcpip.accept_loop: accepted connection from [2001:db8::2]:48286 as fd 7
+    [00:45:08.679,595] <dbg> greybus_transport_tcpip.accept_loop: spawning client thread..
+    [00:45:08.679,870] <dbg> greybus_transport_tcpip.accept_loop: calling poll
+    ...
+
+Read I2C Registers
+==================
+
+The SensorTag comes with an opt3001 ambient light sensor as well as an hdc2080 
+temperature & humidity sensor.
+
+First, find which i2c device corresponds to the SensorTag:
+
+.. code-block:: bash
+
+    ls -la /sys/bus/i2c/devices/* | grep "greybus"
+    lrwxrwxrwx 1 root root 0 Aug 15 11:24 /sys/bus/i2c/devices/i2c-8 -> ../../../devices/virtual/gb_nl/gn_nl/greybus1/1-2/1-2.2/1-2.2.2/gbphy2/i2c-8
+
+On my machine, the i2c device node that Greybus creates is :code:`/dev/i2c-8`.
+
+Read the ID registers (at the i2c register address 0x7e) of the opt3001 sensor 
+(at i2c bus address 0x44) as shown below:
+
+.. code-block:: bash
+
+    i2cget -y 8 0x44 0x7e w
+    0x4954
+
+Read the ID registers (at the i2c register address 0xfc) of the hdc2080 sensor 
+(at i2c bus address 0x41) as shown below:
+
+.. code-block:: bash
+
+    i2cget -y 8 0x41 0xfc w
+    0x5449
+
+Conclusion
+**********
+
+The blinking LED can and poking i2c registers can be a somewhat anticlimactic, 
+but hopefully it illustrates the potential for Greybus as an IoT application layer 
+protocol.
+
+What is nice about this demo, is that we're using Device Tree to describe our 
+Greybus Peripheral declaratively, they Greybus Manifest is automatically 
+generated, and the Greybus Service is automatically started in Zephyr.
+
+In other words, all that is required to replicate this for other IoT devices is
+simply an appropriate Device Tree overlay file.
+
+The proof-of-concept involving Linux, Zephyr, and IEEE 802.15.4 was actually 
+fairly straight forward and was accomplished with mostly already-upstream 
+source.
+
+For Greybus in Zephyr, there is still a considerable amount of integration work
+to be done, including * converting the fork to a proper Zephyr module * adding 
+security and authentication * automatic detection, joining, and rejoining of 
+devices.
+
+Thanks for reading, and we hope you've enjoyed this tutorial.
diff --git a/projects/beagleconnect/beagleplay-bcf.rst b/projects/beagleconnect/beagleplay-bcf.rst
new file mode 100644
index 0000000000000000000000000000000000000000..a780648fa157060320e83ba5a2db85256dcf942b
--- /dev/null
+++ b/projects/beagleconnect/beagleplay-bcf.rst
@@ -0,0 +1,318 @@
+.. _beagleconnect-technology-beagleplay-bcf:
+
+BeaglePlay + BeagleConnect Freedom
+##################################
+
+:ref:`BeaglePlay <beagleplay-home>` and :ref:`BeagleConnect Freedom <beagleconnect-freedom-home>` are the first boards with the aim to provide seamless BeagleConnectâ„¢ Technology support over 6lowpan network which can have a range upto 1km. The support for `mikroBUS`_ add-on boards on :ref:`BeagleConnect Freedom <beagleconnect-freedom-home>` provide endless possibilties of peripherals. Let us go over some of the internal details that might be useful for developers who would like to get involved.
+
+Architecture
+************
+
+.. note::
+
+    This section assumes that you are familiar with terminology introduced in :ref:`beagleconnect-overview`.
+
+:ref:`BeaglePlay <beagleplay-home>` single-board computer contains 2 processors, an AM62x running Debian Linux and a CC1352P7 co-processor. The AM62x processor acts as the :term:`AP <BeagleConnect AP>` in Greybus architecture while CC1352P7 acts as the :term:`SVC <BeagleConnect SVC>`. The sub-1 ghz networking present in CC1352P7 is used as transport. This means all greybus messages between :term:`AP <BeagleConnect AP>` and Node are routed through CC1352P7.
+
+BeagleConnect Freedom serves as the Greybus module, running ZephyrRTOS. It has 2 `mikroBUS` ports which enables compatibility with over 1,000 mikroBUS add-on sensors, acutators, indicators and additional connectivity and storage options.
+
+Here is a visual representation of the architecture:
+
+.. image:: images/beagleplay_bcf_architecture.svg
+   :align: center
+   :alt: BeaglePlay + BeagleConnect Freedom BeagleConnet Setup
+
+
+Demo
+****
+
+.. important::
+
+    The current setup is in heavy development. In case of any problems feel free to reach out to us at `Discord <https://discordapp.com/channels/1108795636956024986/1189277127590289469>`_ or `BeagleBoard Forum <https://forum.beagleboard.org/>`_.
+
+:ref:`greybus-host`
+
+Here is a video of BeaglePlay + BeagleConnect Freedom in action:
+
+.. youtube:: O5coD55JvGU
+   :align: center
+
+Components Involved
+*******************
+
+* `gb-beagleplay Linux Driver <https://elixir.bootlin.com/linux/latest/source/drivers/greybus/gb-beagleplay.c>`_: Mainline Linux Kernel since v6.7.0
+* `mikroBUS Linux Driver <https://openbeagle.org/RobertCNelson/ti-linux-kernel-dev/-/tree/ti-linux-arm64-6.1.y/patches/mikrobus?ref_type=heads>`_: Out of tree
+* `greybus-node-firmware <https://openbeagle.org/beagleconnect/zephyr/greybus-for-zephyr>`_: Out of tree
+* `greybus-host-firmware <https://openbeagle.org/gsoc/greybus/cc1352-firmware>`_: Out of tree
+
+
+Demo
+****
+
+Using Pre-built Images
+=======================
+
+The pre-built images for both BeaglePlay and BeagleConnect Freedom are available at `here <https://openbeagle.org/ayush1325/zephyr/-/jobs/23728/artifacts/download>`_.
+
+
+Build Images from Source
+========================
+
+.. note::
+
+    The following steps are for building the images from source. If you want to use pre-built images, you can skip this section.
+
+.. todo::
+
+    Use upstream Zephyr. The current support in Zephyr upstream has some performance problems which are being worked on. For now, we are using a custom fork based on Zephyr v3.4
+
+
+Setup Zephyr
+------------
+
+.. note::
+
+     Checkout `Zephyr Getting Started Guide <https://docs.zephyrproject.org/latest/develop/getting_started/index.html>`_ for more up to date instructions.
+
+#. Install the required packages:
+
+   .. code-block:: shell-session
+
+     sudo apt install --no-install-recommends git cmake ninja-build gperf \
+       ccache dfu-util device-tree-compiler wget \
+       python3-dev python3-pip python3-setuptools python3-tk python3-wheel xz-utils file \
+       make gcc gcc-multilib g++-multilib libsdl2-dev libmagic1 python3-venv
+
+#. Create a new virtual environment:
+
+   .. code-block:: shell-session
+
+      python3 -m venv ~/zephyrproject/.venv
+
+#. Activate the virtual environment:
+
+   .. code-block:: shell-session
+
+      source ~/zephyrproject/.venv/bin/activate
+
+#. Install west:
+
+   .. code-block:: shell-session
+
+        pip install west
+
+#. Get the Zephyr source code:
+
+   .. code-block:: shell-session
+
+      west init -m https://openbeagle.org/ayush1325/zephyr.git --mr demo-new ~/zephyrproject
+      cd ~/zephyrproject
+      west update
+
+#. Export a Zephyr CMake package. This allows CMake to automatically load boilerplate code required for building Zephyr applications.
+
+   .. code-block:: shell-session
+
+      west zephyr-export
+
+#. Zephyr’s scripts/requirements.txt file declares additional Python dependencies. Install them with pip.
+
+   .. code-block:: shell-session
+
+      pip install -r ~/zephyrproject/zephyr/scripts/requirements.txt
+
+#. Download and verify the Zephyr SDK bundle:
+
+   .. code-block:: shell-session
+
+      cd ~/.local/opt
+      wget https://github.com/zephyrproject-rtos/sdk-ng/releases/download/v0.16.5-1/zephyr-sdk-0.16.5-1_linux-x86_64.tar.xz
+      wget -O - https://github.com/zephyrproject-rtos/sdk-ng/releases/download/v0.16.5-1/sha256.sum | shasum --check --ignore-missing
+
+#. Extract the Zephyr SDK bundle archive:
+
+   .. code-block:: shell-session
+
+        tar xf zephyr-sdk-0.16.5-1_linux-x86_64.tar.xz
+        rm zephyr-sdk-0.16.5-1_linux-x86_64.tar.xz
+
+.. note::
+
+    If trying to build on BeaglePlay, use `zephyr-sdk-0.16.5-1_linux-aarch64_minimal.tar.xz` instead of full Zephyr SDK.
+
+#. Run the Zephyr SDK bundle setup script:
+
+   .. code-block:: shell-session
+
+      cd zephyr-sdk-0.16.5-1
+      ./setup.sh
+
+#. Install udev rules, which allow you to flash most Zephyr boards as a regular user:
+
+   .. code-block:: shell-session
+
+      sudo cp ~/zephyr-sdk-0.16.5-1/sysroots/x86_64-pokysdk-linux/usr/share/openocd/contrib/60-openocd.rules /etc/udev/rules.d
+      sudo udevadm control --reload
+
+#. Install `cc1352-flasher <https://pypi.org/project/cc1352-flasher/>`_
+
+   .. code-block:: shell-session
+
+      pip install cc1352-flasher
+
+
+Build and Flash BeagleConnect Freedom
+-------------------------------------
+
+#. Build Greybus for node
+
+   .. code-block:: shell-session
+
+      west build -b beagleconnect_freedom modules/greybus/samples/subsys/greybus/net/ -p -- -DOVERLAY_CONFIG=overlay-802154-subg.conf
+
+#. Connect Beagleconnect Freedom and flash the firmware
+
+   .. code-block:: shell-session
+
+      west flash
+
+
+Build and Flash BeaglePlay CC1352
+---------------------------------
+
+#. Build Greybus for host
+
+   .. code-block:: shell-session
+
+      west build -b beagleplay_cc1352 modules/greybus-host/ -p
+
+#. Start BeaglePlay with bcfserial overlay. If you are using USB to UART cable to connect to BeaglePlay, you can select `BeaglePlay eMMC disable BCFSERIAL` option. Else run the following command and reboot.
+
+   .. code-block:: shell-session
+
+      sed -i '5d' /boot/firmware/extlinux/extlinux.conf
+      sed -i '5idefault BeaglePlay eMMC disable BCFSERIAL' temp2 
+
+#. Copy compiled image to BeaglePlay:
+
+   .. code-block:: shell-session
+
+      scp build/zephyr/zephyr.bin debian@beagleplay.local:~/greybus/zephyr/zephyr.bin
+
+#. Install `cc1352-flasher <https://pypi.org/project/cc1352-flasher/>`_ on BeaglePlay
+
+   .. code-block:: shell-session
+
+      pip install cc1352-flasher
+
+#. Flash the firmware
+
+   .. code-block:: shell-session
+
+      cc1352-flasher --play ~/greybus
+
+#. Enable bcfserial overlay. (Skip this step if you used Uboot menu in step 2):
+
+   .. code-block:: shell-session
+
+      sed -i '5d' /boot/firmware/extlinux/extlinux.conf
+      sed -i '5idefault BeaglePlay eMMC (default)' temp2 
+
+#. Blacklist bcfserial Linux driver. This is required only in 5.x kernels:
+
+   .. code-block:: shell-session
+
+      sed -i '28s/$/ modprobe.blacklist=mikrobus/' /boot/firmware/extlinux/extlinux.conf
+
+#. Reboot
+
+BeaglePlay Driver
+-----------------
+
+.. note::
+
+    This section is only required for 5.x kernels.
+
+#. Clone the driver:
+
+   .. code-block:: shell-session
+
+      git clone https://git.beagleboard.org/gsoc/greybus/beagleplay-greybus-driver.git
+      cd beagleplay-greybus-driver
+
+#. Install kernel headers:
+
+   .. code-block:: shell-session
+
+       sudo apt install linux-headers-$(uname -r)
+
+#. Build `gb-beagleplay` driver:
+
+   .. code-block:: shell-session
+
+       debian@BeaglePlay:~/beagleplay-greybus-driver$ make
+       make -C /lib/modules/5.10.168-ti-arm64-r111/build M=/home/debian/beagleplay-greybus-driver modules
+       make[1]: Entering directory '/usr/src/linux-headers-5.10.168-ti-arm64-r111'
+         CC [M]  /home/debian/beagleplay-greybus-driver/gb-beagleplay.o
+         MODPOST /home/debian/beagleplay-greybus-driver/Module.symvers
+         CC [M]  /home/debian/beagleplay-greybus-driver/gb-beagleplay.mod.o
+         LD [M]  /home/debian/beagleplay-greybus-driver/gb-beagleplay.ko
+       make[1]: Leaving directory '/usr/src/linux-headers-5.10.168-ti-arm64-r111'
+
+#. Load the driver:
+
+   .. code-block:: shell-session
+
+      sudo insmod gb-beagleplay.ko
+
+#. Check `iio_info`. Sensors from beagleconnect freedom should show up here:
+
+   .. code-block:: shell-session
+
+       debian@BeaglePlay:~$ iio_info
+       Library version: 0.24 (git tag: v0.24)
+       Compiled with backends: local xml ip usb
+       IIO context created with local backend.
+       Backend version: 0.24 (git tag: v0.24)
+       Backend description string: Linux BeaglePlay 5.10.168-ti-arm64-r111 #1bullseye SMP Tue Sep 26 14:22:20 UTC 2023 aarch64
+       IIO context has 2 attributes:
+               local,kernel: 5.10.168-ti-arm64-r111
+               uri: local:
+       IIO context has 2 devices:
+               iio:device0: adc102s051
+                       2 channels found:
+                               voltage1:  (input)
+                               2 channel-specific attributes found:
+                                       attr  0: raw value: 4068
+                                       attr  1: scale value: 0.805664062
+                               voltage0:  (input)
+                               2 channel-specific attributes found:
+                                       attr  0: raw value: 0
+                                       attr  1: scale value: 0.805664062
+                       No trigger on this device
+               iio:device1: hdc2010
+                       3 channels found:
+                               temp:  (input)
+                               4 channel-specific attributes found:
+                                       attr  0: offset value: -15887.515151
+                                       attr  1: peak_raw value: 28928
+                                       attr  2: raw value: 28990
+                                       attr  3: scale value: 2.517700195
+                               humidityrelative:  (input)
+                               3 channel-specific attributes found:
+                                       attr  0: peak_raw value: 43264
+                                       attr  1: raw value: 41892
+                                       attr  2: scale value: 1.525878906
+                               current:  (output)
+                               2 channel-specific attributes found:
+                                       attr  0: heater_raw value: 0
+                                       attr  1: heater_raw_available value: 0 1
+                       No trigger on this device
+
+
+Conclusion
+**********
+
+While BeagleConnectâ„¢ technology is still in development, we are excited to see the possibilities it brings to the table. We are continuously working on improving the technology and adding more features. Fee free to reach out to us at `Discord <https://discordapp.com/channels/1108795636956024986/1189277127590289469>`_ or `BeagleBoard Forum <https://forum.beagleboard.org/>`_.
+
+.. _mikroBUS: https://www.mikroe.com/mikrobus
diff --git a/projects/beagleconnect/images/beagleplay_bcf_architecture.svg b/projects/beagleconnect/images/beagleplay_bcf_architecture.svg
new file mode 100644
index 0000000000000000000000000000000000000000..10d388772ccc515ac4b0ec7cacbf4d2b799555c7
--- /dev/null
+++ b/projects/beagleconnect/images/beagleplay_bcf_architecture.svg
@@ -0,0 +1,4 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!-- Do not edit this file with editors other than draw.io -->
+<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
+<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" width="1085px" height="805px" viewBox="-0.5 -0.5 1085 805" class="ge-export-svg-dark" content="&lt;mxfile host=&quot;app.diagrams.net&quot; modified=&quot;2024-04-20T19:29:18.218Z&quot; agent=&quot;Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/124.0.0.0 Safari/537.36&quot; etag=&quot;hzEVmMtcW8s_QiL00vSz&quot; version=&quot;24.2.7&quot; type=&quot;google&quot; scale=&quot;1&quot; border=&quot;0&quot;&gt;&#10;  &lt;diagram name=&quot;Page-1&quot; id=&quot;uY0COTEc3WUXCl7wPsDq&quot;&gt;&#10;    &lt;mxGraphModel dx=&quot;2523&quot; dy=&quot;2022&quot; grid=&quot;1&quot; gridSize=&quot;10&quot; guides=&quot;1&quot; tooltips=&quot;1&quot; connect=&quot;1&quot; arrows=&quot;1&quot; fold=&quot;1&quot; page=&quot;1&quot; pageScale=&quot;1&quot; pageWidth=&quot;850&quot; pageHeight=&quot;1100&quot; math=&quot;0&quot; shadow=&quot;0&quot;&gt;&#10;      &lt;root&gt;&#10;        &lt;mxCell id=&quot;0&quot; /&gt;&#10;        &lt;mxCell id=&quot;1&quot; parent=&quot;0&quot; /&gt;&#10;        &lt;mxCell id=&quot;MhAmP5u9P9BtMRrkWhtU-4&quot; value=&quot;&quot; style=&quot;rounded=0;whiteSpace=wrap;html=1;strokeWidth=5;fillColor=#003366;fontColor=#ffffff;strokeColor=#3399FF;&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry x=&quot;-40&quot; y=&quot;-40&quot; width=&quot;1080&quot; height=&quot;800&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;jhmO5CJgM7XCL80eNb6_-4&quot; value=&quot;&amp;lt;font size=&amp;quot;1&amp;quot; style=&amp;quot;&amp;quot;&amp;gt;&amp;lt;b style=&amp;quot;font-size: 18px;&amp;quot;&amp;gt;BeaglePlay&amp;lt;/b&amp;gt;&amp;lt;/font&amp;gt;&quot; style=&quot;rounded=0;whiteSpace=wrap;html=1;fillColor=#001933;verticalAlign=top;strokeColor=#006EAF;strokeWidth=6;fontColor=#ffffff;gradientColor=#007FFF;gradientDirection=radial;glass=0;shadow=0;&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry width=&quot;570&quot; height=&quot;720&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;gyTpI4vv8gO5FbXfWERa-26&quot; value=&quot;CC1352 (Zephyr)&quot; style=&quot;rounded=1;whiteSpace=wrap;html=1;fillColor=#008a00;verticalAlign=bottom;fontColor=#ffffff;strokeColor=#005700;strokeWidth=4;fontSize=16;fontStyle=1&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry x=&quot;350&quot; y=&quot;570&quot; width=&quot;200&quot; height=&quot;120&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;gyTpI4vv8gO5FbXfWERa-13&quot; value=&quot;AM62 (Linux)&quot; style=&quot;rounded=1;whiteSpace=wrap;html=1;fillColor=#008a00;verticalAlign=top;fontColor=#ffffff;strokeColor=#005700;strokeWidth=5;fontSize=16;fontStyle=1&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry x=&quot;40&quot; y=&quot;40&quot; width=&quot;280&quot; height=&quot;650&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;gyTpI4vv8gO5FbXfWERa-19&quot; value=&quot;&amp;lt;font style=&amp;quot;font-size: 18px;&amp;quot;&amp;gt;&amp;lt;b&amp;gt;BeagleConnect Freedom (Zephyr)&amp;lt;/b&amp;gt;&amp;lt;/font&amp;gt;&quot; style=&quot;rounded=0;whiteSpace=wrap;html=1;fillColor=#001933;verticalAlign=top;strokeWidth=6;strokeColor=#006EAF;fontColor=#ffffff;gradientColor=#3399FF;gradientDirection=radial;&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry x=&quot;610&quot; width=&quot;390&quot; height=&quot;260&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;cnFOZKSyKm-ARbksO7xH-4&quot; value=&quot;&quot; style=&quot;edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;&quot; parent=&quot;1&quot; source=&quot;gyTpI4vv8gO5FbXfWERa-12&quot; target=&quot;gyTpI4vv8gO5FbXfWERa-1&quot; edge=&quot;1&quot;&gt;&#10;          &lt;mxGeometry relative=&quot;1&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;gyTpI4vv8gO5FbXfWERa-12&quot; value=&quot;&amp;lt;div style=&amp;quot;font-size: 14px;&amp;quot;&amp;gt;Linux Kernel&amp;lt;br style=&amp;quot;font-size: 14px;&amp;quot;&amp;gt;&amp;lt;/div&amp;gt;&quot; style=&quot;rounded=1;whiteSpace=wrap;html=1;fillColor=#60a917;align=left;verticalAlign=top;fontStyle=1;spacingLeft=10;fontColor=#ffffff;strokeColor=#2D7600;strokeWidth=4;fontSize=14;&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry x=&quot;80&quot; y=&quot;220&quot; width=&quot;200&quot; height=&quot;450&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;gyTpI4vv8gO5FbXfWERa-11&quot; value=&quot;Linux Userspace&quot; style=&quot;rounded=1;whiteSpace=wrap;fillColor=#60a917;labelPosition=center;verticalLabelPosition=middle;align=left;verticalAlign=top;html=1;spacingTop=0;textDirection=ltr;spacingLeft=10;fontColor=#ffffff;strokeColor=#2D7600;strokeWidth=4;fontSize=14;fontStyle=1&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry x=&quot;80&quot; y=&quot;80&quot; width=&quot;200&quot; height=&quot;120&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;gyTpI4vv8gO5FbXfWERa-7&quot; style=&quot;edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;entryX=0.5;entryY=0;entryDx=0;entryDy=0;strokeWidth=3;startArrow=classic;startFill=1;&quot; parent=&quot;1&quot; source=&quot;gyTpI4vv8gO5FbXfWERa-1&quot; target=&quot;gyTpI4vv8gO5FbXfWERa-2&quot; edge=&quot;1&quot;&gt;&#10;          &lt;mxGeometry relative=&quot;1&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;gyTpI4vv8gO5FbXfWERa-1&quot; value=&quot;User Application&quot; style=&quot;rounded=1;whiteSpace=wrap;html=1;fillColor=#d80073;fontColor=#ffffff;strokeColor=#A50040;strokeWidth=3;fontSize=13;&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry x=&quot;120&quot; y=&quot;110&quot; width=&quot;120&quot; height=&quot;60&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;gyTpI4vv8gO5FbXfWERa-8&quot; style=&quot;edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;entryX=0.5;entryY=0;entryDx=0;entryDy=0;strokeWidth=3;startArrow=classic;startFill=1;&quot; parent=&quot;1&quot; source=&quot;gyTpI4vv8gO5FbXfWERa-2&quot; target=&quot;gyTpI4vv8gO5FbXfWERa-3&quot; edge=&quot;1&quot;&gt;&#10;          &lt;mxGeometry relative=&quot;1&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;gyTpI4vv8gO5FbXfWERa-2&quot; value=&quot;IIO Drivers&quot; style=&quot;rounded=1;whiteSpace=wrap;html=1;fillColor=#d80073;fontColor=#ffffff;strokeColor=#A50040;strokeWidth=3;fontSize=13;&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry x=&quot;120&quot; y=&quot;260&quot; width=&quot;120&quot; height=&quot;60&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;gyTpI4vv8gO5FbXfWERa-9&quot; style=&quot;edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;entryX=0.5;entryY=0;entryDx=0;entryDy=0;strokeWidth=3;startArrow=classic;startFill=1;&quot; parent=&quot;1&quot; source=&quot;gyTpI4vv8gO5FbXfWERa-3&quot; target=&quot;gyTpI4vv8gO5FbXfWERa-4&quot; edge=&quot;1&quot;&gt;&#10;          &lt;mxGeometry relative=&quot;1&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;gyTpI4vv8gO5FbXfWERa-3&quot; value=&quot;mikroBUS**&quot; style=&quot;rounded=1;whiteSpace=wrap;html=1;fillColor=#d80073;fontColor=#ffffff;strokeColor=#A50040;strokeWidth=3;fontSize=13;&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry x=&quot;120&quot; y=&quot;370&quot; width=&quot;120&quot; height=&quot;60&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;gyTpI4vv8gO5FbXfWERa-10&quot; style=&quot;edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;strokeWidth=3;startArrow=classic;startFill=1;&quot; parent=&quot;1&quot; source=&quot;gyTpI4vv8gO5FbXfWERa-4&quot; target=&quot;gyTpI4vv8gO5FbXfWERa-5&quot; edge=&quot;1&quot;&gt;&#10;          &lt;mxGeometry relative=&quot;1&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;gyTpI4vv8gO5FbXfWERa-4&quot; value=&quot;Greybus&quot; style=&quot;rounded=1;whiteSpace=wrap;html=1;fillColor=#d80073;fontColor=#ffffff;strokeColor=#A50040;strokeWidth=3;fontSize=13;&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry x=&quot;120&quot; y=&quot;480&quot; width=&quot;120&quot; height=&quot;60&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;jhmO5CJgM7XCL80eNb6_-2&quot; value=&quot;&quot; style=&quot;edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;startArrow=classic;startFill=1;shape=flexArrow;strokeWidth=3;fillColor=#663300;strokeColor=#FF9933;&quot; parent=&quot;1&quot; source=&quot;gyTpI4vv8gO5FbXfWERa-5&quot; target=&quot;gyTpI4vv8gO5FbXfWERa-22&quot; edge=&quot;1&quot;&gt;&#10;          &lt;mxGeometry relative=&quot;1&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;gyTpI4vv8gO5FbXfWERa-5&quot; value=&quot;Platform Driver&quot; style=&quot;rounded=1;whiteSpace=wrap;html=1;fillColor=#d80073;fontColor=#ffffff;strokeColor=#A50040;strokeWidth=3;fontSize=13;&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry x=&quot;120&quot; y=&quot;590&quot; width=&quot;120&quot; height=&quot;60&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;gyTpI4vv8gO5FbXfWERa-14&quot; value=&quot;Sensor&quot; style=&quot;rounded=1;whiteSpace=wrap;html=1;fillColor=#6a00ff;fontColor=#ffffff;strokeColor=#3700CC;strokeWidth=3;fontSize=13;&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry x=&quot;640&quot; y=&quot;60&quot; width=&quot;120&quot; height=&quot;60&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;gyTpI4vv8gO5FbXfWERa-15&quot; value=&quot;Clickboard&quot; style=&quot;rounded=1;whiteSpace=wrap;html=1;fillColor=#6a00ff;fontColor=#ffffff;strokeColor=#3700CC;strokeWidth=3;fontSize=13;&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry x=&quot;820&quot; y=&quot;60&quot; width=&quot;150&quot; height=&quot;60&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;jhmO5CJgM7XCL80eNb6_-5&quot; style=&quot;edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;exitX=0;exitY=0.5;exitDx=0;exitDy=0;strokeWidth=3;startArrow=classic;startFill=1;&quot; parent=&quot;1&quot; source=&quot;gyTpI4vv8gO5FbXfWERa-16&quot; target=&quot;gyTpI4vv8gO5FbXfWERa-14&quot; edge=&quot;1&quot;&gt;&#10;          &lt;mxGeometry relative=&quot;1&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;cu3M_EhpxhxdDDDf_Vu2-1&quot; style=&quot;edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;entryX=0.5;entryY=1;entryDx=0;entryDy=0;exitX=1;exitY=0.5;exitDx=0;exitDy=0;strokeWidth=3;startArrow=classic;startFill=1;&quot; parent=&quot;1&quot; source=&quot;gyTpI4vv8gO5FbXfWERa-16&quot; target=&quot;gyTpI4vv8gO5FbXfWERa-15&quot; edge=&quot;1&quot;&gt;&#10;          &lt;mxGeometry relative=&quot;1&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;gyTpI4vv8gO5FbXfWERa-16&quot; value=&quot;Greybus Firmware (Zephyr)&quot; style=&quot;rounded=1;whiteSpace=wrap;html=1;strokeColor=#005700;strokeWidth=3;fillColor=#008a00;fontColor=#ffffff;fontSize=13;fontStyle=1&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry x=&quot;730&quot; y=&quot;160&quot; width=&quot;140&quot; height=&quot;60&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;gyTpI4vv8gO5FbXfWERa-22&quot; value=&quot;APBridge + SVC&quot; style=&quot;rounded=1;whiteSpace=wrap;html=1;fillColor=#d80073;fontColor=#ffffff;strokeColor=#A50040;strokeWidth=3;fontSize=13;&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry x=&quot;390&quot; y=&quot;590&quot; width=&quot;120&quot; height=&quot;60&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;cnFOZKSyKm-ARbksO7xH-1&quot; value=&quot;&quot; style=&quot;shape=flexArrow;endArrow=classic;startArrow=classic;html=1;rounded=0;entryX=0.5;entryY=1;entryDx=0;entryDy=0;exitX=1;exitY=0.5;exitDx=0;exitDy=0;strokeWidth=3;fillColor=#663300;strokeColor=#FF9933;&quot; parent=&quot;1&quot; source=&quot;gyTpI4vv8gO5FbXfWERa-22&quot; target=&quot;gyTpI4vv8gO5FbXfWERa-16&quot; edge=&quot;1&quot;&gt;&#10;          &lt;mxGeometry width=&quot;100&quot; height=&quot;100&quot; relative=&quot;1&quot; as=&quot;geometry&quot;&gt;&#10;            &lt;mxPoint x=&quot;510&quot; y=&quot;400&quot; as=&quot;sourcePoint&quot; /&gt;&#10;            &lt;mxPoint x=&quot;815&quot; y=&quot;290&quot; as=&quot;targetPoint&quot; /&gt;&#10;            &lt;Array as=&quot;points&quot;&gt;&#10;              &lt;mxPoint x=&quot;800&quot; y=&quot;620&quot; /&gt;&#10;            &lt;/Array&gt;&#10;          &lt;/mxGeometry&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;cnFOZKSyKm-ARbksO7xH-2&quot; value=&quot;UART&quot; style=&quot;text;html=1;strokeColor=none;fillColor=none;align=center;verticalAlign=middle;whiteSpace=wrap;rounded=0;fontColor=#FFFFFF;fontStyle=1;fontSize=18;&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry x=&quot;290&quot; y=&quot;580&quot; width=&quot;60&quot; height=&quot;30&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;cnFOZKSyKm-ARbksO7xH-3&quot; value=&quot;6lowpan&quot; style=&quot;text;html=1;strokeColor=none;fillColor=none;align=center;verticalAlign=middle;whiteSpace=wrap;rounded=0;fontSize=18;fontStyle=1;fontColor=#FFFFFF;&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry x=&quot;720&quot; y=&quot;580&quot; width=&quot;60&quot; height=&quot;30&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;      &lt;/root&gt;&#10;    &lt;/mxGraphModel&gt;&#10;  &lt;/diagram&gt;&#10;&lt;/mxfile&gt;&#10;"><defs><radialGradient x1="0%" y1="0%" x2="0%" y2="0%" id="mx-gradient-001933-1-007fff-1-r-0"><stop offset="0%" style="stop-color: rgb(0, 25, 51); stop-opacity: 1;"/><stop offset="100%" style="stop-color: rgb(0, 127, 255); stop-opacity: 1;"/></radialGradient><radialGradient x1="0%" y1="0%" x2="0%" y2="0%" id="mx-gradient-001933-1-3399ff-1-r-0"><stop offset="0%" style="stop-color: rgb(0, 25, 51); stop-opacity: 1;"/><stop offset="100%" style="stop-color: rgb(51, 153, 255); stop-opacity: 1;"/></radialGradient><style type="text/css">svg.ge-export-svg-dark { filter: invert(100%) hue-rotate(180deg); }&#xa;svg.ge-export-svg-dark foreignObject img,&#xa;svg.ge-export-svg-dark image:not(svg.ge-export-svg-dark switch image),&#xa;svg.ge-export-svg-dark svg { filter: invert(100%) hue-rotate(180deg) }</style></defs><g><g><rect x="2" y="2" width="1080" height="800" fill="#003366" stroke="#3399ff" stroke-width="5" pointer-events="all"/></g><g><rect x="42" y="42" width="570" height="720" fill="url(#mx-gradient-001933-1-007fff-1-r-0)" stroke="#006eaf" stroke-width="6" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe flex-start; justify-content: unsafe center; width: 568px; height: 1px; padding-top: 49px; margin-left: 43px;"><div data-drawio-colors="color: #ffffff; " style="box-sizing: border-box; font-size: 0px; text-align: center;"><div style="display: inline-block; font-size: 12px; font-family: Helvetica; color: rgb(255, 255, 255); line-height: 1.2; pointer-events: all; white-space: normal; overflow-wrap: normal;"><font style="" size="1"><b style="font-size: 18px;">BeaglePlay</b></font></div></div></div></foreignObject><image x="43" y="49.5" width="568" height="25" xlink:href=""/></switch></g></g><g><rect x="392" y="612" width="200" height="120" rx="18" ry="18" fill="#008a00" stroke="#005700" stroke-width="4" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe flex-end; justify-content: unsafe center; width: 198px; height: 1px; padding-top: 729px; margin-left: 393px;"><div data-drawio-colors="color: #ffffff; " style="box-sizing: border-box; font-size: 0px; text-align: center;"><div style="display: inline-block; font-size: 16px; font-family: Helvetica; color: rgb(255, 255, 255); line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; overflow-wrap: normal;">CC1352 (Zephyr)</div></div></div></foreignObject><image x="393" y="710.5" width="198" height="23" xlink:href=""/></switch></g></g><g><rect x="82" y="82" width="280" height="650" rx="42" ry="42" fill="#008a00" stroke="#005700" stroke-width="5" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe flex-start; justify-content: unsafe center; width: 278px; height: 1px; padding-top: 89px; margin-left: 83px;"><div data-drawio-colors="color: #ffffff; " style="box-sizing: border-box; font-size: 0px; text-align: center;"><div style="display: inline-block; font-size: 16px; font-family: Helvetica; color: rgb(255, 255, 255); line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; overflow-wrap: normal;">AM62 (Linux)</div></div></div></foreignObject><image x="83" y="89.5" width="278" height="23" xlink:href=""/></switch></g></g><g><rect x="652" y="42" width="390" height="260" fill="url(#mx-gradient-001933-1-3399ff-1-r-0)" stroke="#006eaf" stroke-width="6" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe flex-start; justify-content: unsafe center; width: 388px; height: 1px; padding-top: 49px; margin-left: 653px;"><div data-drawio-colors="color: #ffffff; " style="box-sizing: border-box; font-size: 0px; text-align: center;"><div style="display: inline-block; font-size: 12px; font-family: Helvetica; color: rgb(255, 255, 255); line-height: 1.2; pointer-events: all; white-space: normal; overflow-wrap: normal;"><font style="font-size: 18px;"><b>BeagleConnect Freedom (Zephyr)</b></font></div></div></div></foreignObject><image x="653" y="49.5" width="388" height="25" xlink:href=""/></switch></g></g><g><path d="M 222 262 L 222 218.37" fill="none" stroke="rgb(0, 0, 0)" stroke-miterlimit="10" pointer-events="stroke"/><path d="M 222 213.12 L 225.5 220.12 L 222 218.37 L 218.5 220.12 Z" fill="rgb(0, 0, 0)" stroke="rgb(0, 0, 0)" stroke-miterlimit="10" pointer-events="all"/></g><g><rect x="122" y="262" width="200" height="450" rx="30" ry="30" fill="#60a917" stroke="#2d7600" stroke-width="4" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe flex-start; justify-content: unsafe flex-start; width: 188px; height: 1px; padding-top: 269px; margin-left: 134px;"><div data-drawio-colors="color: #ffffff; " style="box-sizing: border-box; font-size: 0px; text-align: left;"><div style="display: inline-block; font-size: 14px; font-family: Helvetica; color: rgb(255, 255, 255); line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; overflow-wrap: normal;"><div style="font-size: 14px;">Linux Kernel<br style="font-size: 14px;" /></div></div></div></div></foreignObject><image x="134" y="269.5" width="188" height="20.5" xlink:href=""/></switch></g></g><g><rect x="122" y="122" width="200" height="120" rx="18" ry="18" fill="#60a917" stroke="#2d7600" stroke-width="4" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"><div xmlns="http://www.w3.org/1999/xhtml" dir="ltr" style="display: flex; align-items: unsafe flex-start; justify-content: unsafe flex-start; width: 188px; height: 1px; padding-top: 129px; margin-left: 134px;"><div data-drawio-colors="color: #ffffff; " style="box-sizing: border-box; font-size: 0px; text-align: left;"><div style="display: inline-block; font-size: 14px; font-family: Helvetica; color: rgb(255, 255, 255); line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; overflow-wrap: normal;">Linux Userspace</div></div></div></foreignObject><image x="134" y="129.5" width="188" height="20.5" xlink:href=""/></switch></g></g><g><path d="M 222 222.1 L 222 291.9" fill="none" stroke="rgb(0, 0, 0)" stroke-width="3" stroke-miterlimit="10" pointer-events="stroke"/><path d="M 222 215.35 L 226.5 224.35 L 222 222.1 L 217.5 224.35 Z" fill="rgb(0, 0, 0)" stroke="rgb(0, 0, 0)" stroke-width="3" stroke-miterlimit="10" pointer-events="all"/><path d="M 222 298.65 L 217.5 289.65 L 222 291.9 L 226.5 289.65 Z" fill="rgb(0, 0, 0)" stroke="rgb(0, 0, 0)" stroke-width="3" stroke-miterlimit="10" pointer-events="all"/></g><g><rect x="162" y="152" width="120" height="60" rx="9" ry="9" fill="#d80073" stroke="#a50040" stroke-width="3" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 118px; height: 1px; padding-top: 182px; margin-left: 163px;"><div data-drawio-colors="color: #ffffff; " style="box-sizing: border-box; font-size: 0px; text-align: center;"><div style="display: inline-block; font-size: 13px; font-family: Helvetica; color: rgb(255, 255, 255); line-height: 1.2; pointer-events: all; white-space: normal; overflow-wrap: normal;">User Application</div></div></div></foreignObject><image x="163" y="174.5" width="118" height="19.25" xlink:href=""/></switch></g></g><g><path d="M 222 372.1 L 222 401.9" fill="none" stroke="rgb(0, 0, 0)" stroke-width="3" stroke-miterlimit="10" pointer-events="stroke"/><path d="M 222 365.35 L 226.5 374.35 L 222 372.1 L 217.5 374.35 Z" fill="rgb(0, 0, 0)" stroke="rgb(0, 0, 0)" stroke-width="3" stroke-miterlimit="10" pointer-events="all"/><path d="M 222 408.65 L 217.5 399.65 L 222 401.9 L 226.5 399.65 Z" fill="rgb(0, 0, 0)" stroke="rgb(0, 0, 0)" stroke-width="3" stroke-miterlimit="10" pointer-events="all"/></g><g><rect x="162" y="302" width="120" height="60" rx="9" ry="9" fill="#d80073" stroke="#a50040" stroke-width="3" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 118px; height: 1px; padding-top: 332px; margin-left: 163px;"><div data-drawio-colors="color: #ffffff; " style="box-sizing: border-box; font-size: 0px; text-align: center;"><div style="display: inline-block; font-size: 13px; font-family: Helvetica; color: rgb(255, 255, 255); line-height: 1.2; pointer-events: all; white-space: normal; overflow-wrap: normal;">IIO Drivers</div></div></div></foreignObject><image x="163" y="324.5" width="118" height="19.25" xlink:href=""/></switch></g></g><g><path d="M 222 482.1 L 222 511.9" fill="none" stroke="rgb(0, 0, 0)" stroke-width="3" stroke-miterlimit="10" pointer-events="stroke"/><path d="M 222 475.35 L 226.5 484.35 L 222 482.1 L 217.5 484.35 Z" fill="rgb(0, 0, 0)" stroke="rgb(0, 0, 0)" stroke-width="3" stroke-miterlimit="10" pointer-events="all"/><path d="M 222 518.65 L 217.5 509.65 L 222 511.9 L 226.5 509.65 Z" fill="rgb(0, 0, 0)" stroke="rgb(0, 0, 0)" stroke-width="3" stroke-miterlimit="10" pointer-events="all"/></g><g><rect x="162" y="412" width="120" height="60" rx="9" ry="9" fill="#d80073" stroke="#a50040" stroke-width="3" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 118px; height: 1px; padding-top: 442px; margin-left: 163px;"><div data-drawio-colors="color: #ffffff; " style="box-sizing: border-box; font-size: 0px; text-align: center;"><div style="display: inline-block; font-size: 13px; font-family: Helvetica; color: rgb(255, 255, 255); line-height: 1.2; pointer-events: all; white-space: normal; overflow-wrap: normal;">mikroBUS**</div></div></div></foreignObject><image x="163" y="434.5" width="118" height="19.25" xlink:href=""/></switch></g></g><g><path d="M 222 592.1 L 222 621.9" fill="none" stroke="rgb(0, 0, 0)" stroke-width="3" stroke-miterlimit="10" pointer-events="stroke"/><path d="M 222 585.35 L 226.5 594.35 L 222 592.1 L 217.5 594.35 Z" fill="rgb(0, 0, 0)" stroke="rgb(0, 0, 0)" stroke-width="3" stroke-miterlimit="10" pointer-events="all"/><path d="M 222 628.65 L 217.5 619.65 L 222 621.9 L 226.5 619.65 Z" fill="rgb(0, 0, 0)" stroke="rgb(0, 0, 0)" stroke-width="3" stroke-miterlimit="10" pointer-events="all"/></g><g><rect x="162" y="522" width="120" height="60" rx="9" ry="9" fill="#d80073" stroke="#a50040" stroke-width="3" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 118px; height: 1px; padding-top: 552px; margin-left: 163px;"><div data-drawio-colors="color: #ffffff; " style="box-sizing: border-box; font-size: 0px; text-align: center;"><div style="display: inline-block; font-size: 13px; font-family: Helvetica; color: rgb(255, 255, 255); line-height: 1.2; pointer-events: all; white-space: normal; overflow-wrap: normal;">Greybus</div></div></div></foreignObject><image x="163" y="544.5" width="118" height="19.25" xlink:href=""/></switch></g></g><g><path d="M 304.5 668 L 304.5 679.5 L 283.5 662 L 304.5 644.5 L 304.5 656 L 409.5 656 L 409.5 644.5 L 430.5 662 L 409.5 679.5 L 409.5 668 Z" fill="#663300" stroke="#ff9933" stroke-width="3" stroke-miterlimit="10" pointer-events="all"/></g><g><rect x="162" y="632" width="120" height="60" rx="9" ry="9" fill="#d80073" stroke="#a50040" stroke-width="3" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 118px; height: 1px; padding-top: 662px; margin-left: 163px;"><div data-drawio-colors="color: #ffffff; " style="box-sizing: border-box; font-size: 0px; text-align: center;"><div style="display: inline-block; font-size: 13px; font-family: Helvetica; color: rgb(255, 255, 255); line-height: 1.2; pointer-events: all; white-space: normal; overflow-wrap: normal;">Platform Driver</div></div></div></foreignObject><image x="163" y="654.5" width="118" height="19.25" xlink:href=""/></switch></g></g><g><rect x="682" y="102" width="120" height="60" rx="9" ry="9" fill="#6a00ff" stroke="#3700cc" stroke-width="3" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 118px; height: 1px; padding-top: 132px; margin-left: 683px;"><div data-drawio-colors="color: #ffffff; " style="box-sizing: border-box; font-size: 0px; text-align: center;"><div style="display: inline-block; font-size: 13px; font-family: Helvetica; color: rgb(255, 255, 255); line-height: 1.2; pointer-events: all; white-space: normal; overflow-wrap: normal;">Sensor</div></div></div></foreignObject><image x="683" y="124.5" width="118" height="19.25" xlink:href=""/></switch></g></g><g><rect x="862" y="102" width="150" height="60" rx="9" ry="9" fill="#6a00ff" stroke="#3700cc" stroke-width="3" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 148px; height: 1px; padding-top: 132px; margin-left: 863px;"><div data-drawio-colors="color: #ffffff; " style="box-sizing: border-box; font-size: 0px; text-align: center;"><div style="display: inline-block; font-size: 13px; font-family: Helvetica; color: rgb(255, 255, 255); line-height: 1.2; pointer-events: all; white-space: normal; overflow-wrap: normal;">Clickboard</div></div></div></foreignObject><image x="863" y="124.5" width="148" height="19.25" xlink:href=""/></switch></g></g><g><path d="M 761.9 232 L 741.94 232 L 741.94 172.1" fill="none" stroke="rgb(0, 0, 0)" stroke-width="3" stroke-miterlimit="10" pointer-events="stroke"/><path d="M 768.65 232 L 759.65 236.5 L 761.9 232 L 759.65 227.5 Z" fill="rgb(0, 0, 0)" stroke="rgb(0, 0, 0)" stroke-width="3" stroke-miterlimit="10" pointer-events="all"/><path d="M 741.94 165.35 L 746.44 174.35 L 741.94 172.1 L 737.44 174.35 Z" fill="rgb(0, 0, 0)" stroke="rgb(0, 0, 0)" stroke-width="3" stroke-miterlimit="10" pointer-events="all"/></g><g><path d="M 922.1 232 L 937 232 L 937 172.1" fill="none" stroke="rgb(0, 0, 0)" stroke-width="3" stroke-miterlimit="10" pointer-events="stroke"/><path d="M 915.35 232 L 924.35 227.5 L 922.1 232 L 924.35 236.5 Z" fill="rgb(0, 0, 0)" stroke="rgb(0, 0, 0)" stroke-width="3" stroke-miterlimit="10" pointer-events="all"/><path d="M 937 165.35 L 941.5 174.35 L 937 172.1 L 932.5 174.35 Z" fill="rgb(0, 0, 0)" stroke="rgb(0, 0, 0)" stroke-width="3" stroke-miterlimit="10" pointer-events="all"/></g><g><rect x="772" y="202" width="140" height="60" rx="9" ry="9" fill="#008a00" stroke="#005700" stroke-width="3" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 138px; height: 1px; padding-top: 232px; margin-left: 773px;"><div data-drawio-colors="color: #ffffff; " style="box-sizing: border-box; font-size: 0px; text-align: center;"><div style="display: inline-block; font-size: 13px; font-family: Helvetica; color: rgb(255, 255, 255); line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; overflow-wrap: normal;">Greybus Firmware (Zephyr)</div></div></div></foreignObject><image x="773" y="217" width="138" height="34.25" xlink:href=""/></switch></g></g><g><rect x="432" y="632" width="120" height="60" rx="9" ry="9" fill="#d80073" stroke="#a50040" stroke-width="3" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 118px; height: 1px; padding-top: 662px; margin-left: 433px;"><div data-drawio-colors="color: #ffffff; " style="box-sizing: border-box; font-size: 0px; text-align: center;"><div style="display: inline-block; font-size: 13px; font-family: Helvetica; color: rgb(255, 255, 255); line-height: 1.2; pointer-events: all; white-space: normal; overflow-wrap: normal;">APBridge + SVC</div></div></div></foreignObject><image x="433" y="654.5" width="118" height="19.25" xlink:href=""/></switch></g></g><g><path d="M 574.5 668 L 574.5 679.5 L 553.5 662 L 574.5 644.5 L 574.5 656 L 836 656 L 836 284.5 L 824.5 284.5 L 842 263.5 L 859.5 284.5 L 848 284.5 L 848 668 Z" fill="#663300" stroke="#ff9933" stroke-width="3" stroke-miterlimit="1.42" pointer-events="all"/><path d="M 574.5 668 L 574.5 679.5 L 553.5 662 L 574.5 644.5 L 574.5 656" fill="none" stroke="#ff9933" stroke-width="3" stroke-miterlimit="4" pointer-events="all"/><path d="M 836 284.5 L 824.5 284.5 L 842 263.5 L 859.5 284.5 L 848 284.5" fill="none" stroke="#ff9933" stroke-width="3" stroke-miterlimit="4" pointer-events="all"/></g><g><rect x="332" y="622" width="60" height="30" fill="none" stroke="none" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 58px; height: 1px; padding-top: 637px; margin-left: 333px;"><div data-drawio-colors="color: #FFFFFF; " style="box-sizing: border-box; font-size: 0px; text-align: center;"><div style="display: inline-block; font-size: 18px; font-family: Helvetica; color: rgb(255, 255, 255); line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; overflow-wrap: normal;">UART</div></div></div></foreignObject><image x="333" y="626.5" width="58" height="26.5" xlink:href=""/></switch></g></g><g><rect x="762" y="622" width="60" height="30" fill="none" stroke="none" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 58px; height: 1px; padding-top: 637px; margin-left: 763px;"><div data-drawio-colors="color: #FFFFFF; " style="box-sizing: border-box; font-size: 0px; text-align: center;"><div style="display: inline-block; font-size: 18px; font-family: Helvetica; color: rgb(255, 255, 255); line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; overflow-wrap: normal;">6lowpan</div></div></div></foreignObject><image x="763" y="626.5" width="58" height="26.5" xlink:href=""/></switch></g></g></g></svg>
\ No newline at end of file
diff --git a/projects/beagleconnect/images/greybus.webp b/projects/beagleconnect/images/greybus.webp
new file mode 100644
index 0000000000000000000000000000000000000000..780fd41e428c434f9a7e8a91fa46e6664831f5fc
Binary files /dev/null and b/projects/beagleconnect/images/greybus.webp differ
diff --git a/projects/beagleconnect/images/software_prop_transport.svg b/projects/beagleconnect/images/software_prop_transport.svg
new file mode 100644
index 0000000000000000000000000000000000000000..019712835cba421767e533ecd3e6a083a0cb5b1f
--- /dev/null
+++ b/projects/beagleconnect/images/software_prop_transport.svg
@@ -0,0 +1,4 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!-- Do not edit this file with editors other than draw.io -->
+<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
+<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" width="763px" height="363px" viewBox="-0.5 -0.5 763 363" class="ge-export-svg-dark" content="&lt;mxfile host=&quot;app.diagrams.net&quot; modified=&quot;2024-04-20T19:26:40.934Z&quot; agent=&quot;Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/124.0.0.0 Safari/537.36&quot; etag=&quot;v4KYTIl_MRsQNeTatdF-&quot; version=&quot;24.2.7&quot; type=&quot;google&quot; scale=&quot;1&quot; border=&quot;0&quot;&gt;&#10;  &lt;diagram name=&quot;Page-1&quot; id=&quot;flhRpbSzN1B1Oqde7Hmw&quot;&gt;&#10;    &lt;mxGraphModel dx=&quot;2249&quot; dy=&quot;784&quot; grid=&quot;1&quot; gridSize=&quot;10&quot; guides=&quot;1&quot; tooltips=&quot;1&quot; connect=&quot;1&quot; arrows=&quot;1&quot; fold=&quot;1&quot; page=&quot;1&quot; pageScale=&quot;1&quot; pageWidth=&quot;827&quot; pageHeight=&quot;1169&quot; math=&quot;0&quot; shadow=&quot;0&quot;&gt;&#10;      &lt;root&gt;&#10;        &lt;mxCell id=&quot;0&quot; /&gt;&#10;        &lt;mxCell id=&quot;1&quot; parent=&quot;0&quot; /&gt;&#10;        &lt;mxCell id=&quot;E3XMTJjsjSVtkwTG0ee--30&quot; value=&quot;&quot; style=&quot;rounded=0;whiteSpace=wrap;html=1;fillColor=#001933;strokeColor=#3399FF;strokeWidth=3;&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry x=&quot;-40&quot; y=&quot;80&quot; width=&quot;760&quot; height=&quot;360&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;E3XMTJjsjSVtkwTG0ee--1&quot; value=&quot;&amp;lt;font size=&amp;quot;1&amp;quot; color=&amp;quot;#ffffff&amp;quot; style=&amp;quot;&amp;quot;&amp;gt;&amp;lt;b style=&amp;quot;font-size: 18px;&amp;quot;&amp;gt;SOC + SVC&amp;lt;/b&amp;gt;&amp;lt;/font&amp;gt;&quot; style=&quot;rounded=1;whiteSpace=wrap;html=1;strokeWidth=8;strokeColor=#3399FF;fillColor=#004C99;&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry y=&quot;120&quot; width=&quot;120&quot; height=&quot;280&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;E3XMTJjsjSVtkwTG0ee--2&quot; value=&quot;&amp;lt;font style=&amp;quot;font-size: 18px;&amp;quot; color=&amp;quot;#ffffff&amp;quot;&amp;gt;&amp;lt;b&amp;gt;MCU&amp;lt;br&amp;gt;(Node)&amp;lt;/b&amp;gt;&amp;lt;/font&amp;gt;&quot; style=&quot;rounded=1;whiteSpace=wrap;html=1;strokeWidth=8;strokeColor=#3399FF;fillColor=#004C99;&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry x=&quot;330&quot; y=&quot;200&quot; width=&quot;120&quot; height=&quot;120&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;E3XMTJjsjSVtkwTG0ee--4&quot; value=&quot;&amp;lt;font color=&amp;quot;#ffffff&amp;quot; style=&amp;quot;font-size: 15px;&amp;quot;&amp;gt;Peripheral&amp;lt;/font&amp;gt;&quot; style=&quot;rounded=0;whiteSpace=wrap;html=1;strokeWidth=4;strokeColor=#3399FF;fillColor=#003366;&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry x=&quot;560&quot; y=&quot;120&quot; width=&quot;120&quot; height=&quot;190&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;E3XMTJjsjSVtkwTG0ee--5&quot; value=&quot;&amp;lt;font style=&amp;quot;font-size: 15px;&amp;quot; color=&amp;quot;#ffffff&amp;quot;&amp;gt;Peripheral&amp;lt;/font&amp;gt;&quot; style=&quot;rounded=0;whiteSpace=wrap;html=1;strokeWidth=4;strokeColor=#3399FF;fillColor=#003366;&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry x=&quot;560&quot; y=&quot;360&quot; width=&quot;120&quot; height=&quot;40&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;E3XMTJjsjSVtkwTG0ee--9&quot; value=&quot;&quot; style=&quot;shape=flexArrow;endArrow=classic;startArrow=classic;html=1;rounded=1;entryX=0;entryY=0.5;entryDx=0;entryDy=0;exitX=1;exitY=0.5;exitDx=0;exitDy=0;strokeWidth=3;fillColor=#001933;gradientColor=#3399FF;strokeColor=none;gradientDirection=radial;&quot; parent=&quot;1&quot; source=&quot;E3XMTJjsjSVtkwTG0ee--1&quot; target=&quot;E3XMTJjsjSVtkwTG0ee--2&quot; edge=&quot;1&quot;&gt;&#10;          &lt;mxGeometry width=&quot;100&quot; height=&quot;100&quot; relative=&quot;1&quot; as=&quot;geometry&quot;&gt;&#10;            &lt;mxPoint x=&quot;150&quot; y=&quot;310&quot; as=&quot;sourcePoint&quot; /&gt;&#10;            &lt;mxPoint x=&quot;250&quot; y=&quot;210&quot; as=&quot;targetPoint&quot; /&gt;&#10;          &lt;/mxGeometry&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;E3XMTJjsjSVtkwTG0ee--14&quot; value=&quot;&quot; style=&quot;shape=flexArrow;endArrow=classic;startArrow=classic;html=1;rounded=1;exitX=1;exitY=0.25;exitDx=0;exitDy=0;strokeWidth=2;endSize=6;width=5;startWidth=12;endWidth=12;strokeColor=none;fillColor=#3399FF;entryX=0;entryY=0.25;entryDx=0;entryDy=0;&quot; parent=&quot;1&quot; source=&quot;E3XMTJjsjSVtkwTG0ee--2&quot; target=&quot;E3XMTJjsjSVtkwTG0ee--4&quot; edge=&quot;1&quot;&gt;&#10;          &lt;mxGeometry width=&quot;100&quot; height=&quot;100&quot; relative=&quot;1&quot; as=&quot;geometry&quot;&gt;&#10;            &lt;mxPoint x=&quot;400&quot; y=&quot;199&quot; as=&quot;sourcePoint&quot; /&gt;&#10;            &lt;mxPoint x=&quot;540&quot; y=&quot;160&quot; as=&quot;targetPoint&quot; /&gt;&#10;          &lt;/mxGeometry&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;E3XMTJjsjSVtkwTG0ee--15&quot; value=&quot;&quot; style=&quot;shape=flexArrow;endArrow=classic;startArrow=classic;html=1;rounded=1;entryX=0;entryY=0.75;entryDx=0;entryDy=0;exitX=1;exitY=0.5;exitDx=0;exitDy=0;strokeWidth=2;endSize=6;width=5;startWidth=12;endWidth=12;fillColor=#3399FF;strokeColor=none;&quot; parent=&quot;1&quot; source=&quot;E3XMTJjsjSVtkwTG0ee--2&quot; target=&quot;E3XMTJjsjSVtkwTG0ee--4&quot; edge=&quot;1&quot;&gt;&#10;          &lt;mxGeometry width=&quot;100&quot; height=&quot;100&quot; relative=&quot;1&quot; as=&quot;geometry&quot;&gt;&#10;            &lt;mxPoint x=&quot;410&quot; y=&quot;209&quot; as=&quot;sourcePoint&quot; /&gt;&#10;            &lt;mxPoint x=&quot;530&quot; y=&quot;189&quot; as=&quot;targetPoint&quot; /&gt;&#10;          &lt;/mxGeometry&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;E3XMTJjsjSVtkwTG0ee--16&quot; value=&quot;&quot; style=&quot;shape=flexArrow;endArrow=classic;startArrow=classic;html=1;rounded=1;entryX=0;entryY=0.5;entryDx=0;entryDy=0;exitX=1;exitY=0.75;exitDx=0;exitDy=0;strokeWidth=2;endSize=6;width=5;startWidth=12;endWidth=12;fillColor=#3399FF;strokeColor=none;&quot; parent=&quot;1&quot; source=&quot;E3XMTJjsjSVtkwTG0ee--2&quot; target=&quot;E3XMTJjsjSVtkwTG0ee--5&quot; edge=&quot;1&quot;&gt;&#10;          &lt;mxGeometry width=&quot;100&quot; height=&quot;100&quot; relative=&quot;1&quot; as=&quot;geometry&quot;&gt;&#10;            &lt;mxPoint x=&quot;410&quot; y=&quot;270&quot; as=&quot;sourcePoint&quot; /&gt;&#10;            &lt;mxPoint x=&quot;530&quot; y=&quot;270&quot; as=&quot;targetPoint&quot; /&gt;&#10;          &lt;/mxGeometry&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;E3XMTJjsjSVtkwTG0ee--29&quot; value=&quot;&amp;lt;font color=&amp;quot;#ffffff&amp;quot; style=&amp;quot;font-size: 16px;&amp;quot;&amp;gt;&amp;lt;b style=&amp;quot;font-size: 16px;&amp;quot;&amp;gt;Arbitrary Transport&amp;lt;/b&amp;gt;&amp;lt;/font&amp;gt;&quot; style=&quot;text;html=1;strokeColor=none;fillColor=none;align=center;verticalAlign=middle;whiteSpace=wrap;rounded=0;fontSize=16;&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry x=&quot;140&quot; y=&quot;210&quot; width=&quot;160&quot; height=&quot;30&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;E3XMTJjsjSVtkwTG0ee--31&quot; value=&quot;I2C&quot; style=&quot;text;html=1;strokeColor=none;fillColor=none;align=center;verticalAlign=middle;whiteSpace=wrap;rounded=0;fontStyle=1;fontColor=#FFFFFF;fontSize=14;&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry x=&quot;470&quot; y=&quot;170&quot; width=&quot;60&quot; height=&quot;30&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;E3XMTJjsjSVtkwTG0ee--33&quot; value=&quot;SPI&quot; style=&quot;text;html=1;strokeColor=none;fillColor=none;align=center;verticalAlign=middle;whiteSpace=wrap;rounded=0;fontStyle=1;fontColor=#FFFFFF;fontSize=14;&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry x=&quot;470&quot; y=&quot;230&quot; width=&quot;60&quot; height=&quot;30&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;        &lt;mxCell id=&quot;E3XMTJjsjSVtkwTG0ee--34&quot; value=&quot;GPIO&quot; style=&quot;text;html=1;strokeColor=none;fillColor=none;align=center;verticalAlign=middle;whiteSpace=wrap;rounded=0;fontStyle=1;fontColor=#FFFFFF;fontSize=14;&quot; parent=&quot;1&quot; vertex=&quot;1&quot;&gt;&#10;          &lt;mxGeometry x=&quot;470&quot; y=&quot;290&quot; width=&quot;60&quot; height=&quot;30&quot; as=&quot;geometry&quot; /&gt;&#10;        &lt;/mxCell&gt;&#10;      &lt;/root&gt;&#10;    &lt;/mxGraphModel&gt;&#10;  &lt;/diagram&gt;&#10;&lt;/mxfile&gt;&#10;"><defs><radialGradient x1="0%" y1="0%" x2="0%" y2="0%" id="mx-gradient-001933-1-3399ff-1-r-0"><stop offset="0%" style="stop-color: rgb(0, 25, 51); stop-opacity: 1;"/><stop offset="100%" style="stop-color: rgb(51, 153, 255); stop-opacity: 1;"/></radialGradient><style type="text/css">svg.ge-export-svg-dark { filter: invert(100%) hue-rotate(180deg); }&#xa;svg.ge-export-svg-dark foreignObject img,&#xa;svg.ge-export-svg-dark image:not(svg.ge-export-svg-dark switch image),&#xa;svg.ge-export-svg-dark svg { filter: invert(100%) hue-rotate(180deg) }</style></defs><g><g><rect x="1" y="1" width="760" height="360" fill="#001933" stroke="#3399ff" stroke-width="3" pointer-events="all"/></g><g><rect x="41" y="41" width="120" height="280" rx="18" ry="18" fill="#004c99" stroke="#3399ff" stroke-width="8" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 118px; height: 1px; padding-top: 181px; margin-left: 42px;"><div data-drawio-colors="color: rgb(0, 0, 0); " style="box-sizing: border-box; font-size: 0px; text-align: center;"><div style="display: inline-block; font-size: 12px; font-family: Helvetica; color: rgb(0, 0, 0); line-height: 1.2; pointer-events: all; white-space: normal; overflow-wrap: normal;"><font style="" color="#ffffff" size="1"><b style="font-size: 18px;">SOC + SVC</b></font></div></div></div></foreignObject><image x="42" y="170.5" width="118" height="25" xlink:href=""/></switch></g></g><g><rect x="371" y="121" width="120" height="120" rx="18" ry="18" fill="#004c99" stroke="#3399ff" stroke-width="8" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 118px; height: 1px; padding-top: 181px; margin-left: 372px;"><div data-drawio-colors="color: rgb(0, 0, 0); " style="box-sizing: border-box; font-size: 0px; text-align: center;"><div style="display: inline-block; font-size: 12px; font-family: Helvetica; color: rgb(0, 0, 0); line-height: 1.2; pointer-events: all; white-space: normal; overflow-wrap: normal;"><font color="#ffffff" style="font-size: 18px;"><b>MCU<br />(Node)</b></font></div></div></div></foreignObject><image x="372" y="160" width="118" height="46" xlink:href=""/></switch></g></g><g><rect x="601" y="41" width="120" height="190" fill="#003366" stroke="#3399ff" stroke-width="4" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 118px; height: 1px; padding-top: 136px; margin-left: 602px;"><div data-drawio-colors="color: rgb(0, 0, 0); " style="box-sizing: border-box; font-size: 0px; text-align: center;"><div style="display: inline-block; font-size: 12px; font-family: Helvetica; color: rgb(0, 0, 0); line-height: 1.2; pointer-events: all; white-space: normal; overflow-wrap: normal;"><font style="font-size: 15px;" color="#ffffff">Peripheral</font></div></div></div></foreignObject><image x="602" y="127.5" width="118" height="21" xlink:href=""/></switch></g></g><g><rect x="601" y="281" width="120" height="40" fill="#003366" stroke="#3399ff" stroke-width="4" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 118px; height: 1px; padding-top: 301px; margin-left: 602px;"><div data-drawio-colors="color: rgb(0, 0, 0); " style="box-sizing: border-box; font-size: 0px; text-align: center;"><div style="display: inline-block; font-size: 12px; font-family: Helvetica; color: rgb(0, 0, 0); line-height: 1.2; pointer-events: all; white-space: normal; overflow-wrap: normal;"><font color="#ffffff" style="font-size: 15px;">Peripheral</font></div></div></div></foreignObject><image x="602" y="292.5" width="118" height="21" xlink:href=""/></switch></g></g><g><path d="M 183.5 187 L 183.5 198.5 L 162.5 181 L 183.5 163.5 L 183.5 175 L 348.5 175 L 348.5 163.5 L 369.5 181 L 348.5 198.5 L 348.5 187 Z" fill="url(#mx-gradient-001933-1-3399ff-1-r-0)" stroke="none" pointer-events="all"/></g><g><path d="M 510.74 143.23 L 514.2 149.32 L 491.87 150.51 L 504.32 131.93 L 507.78 138.02 L 581.26 96.27 L 577.8 90.18 L 600.13 88.99 L 587.68 107.57 L 584.22 101.48 Z" fill="#3399ff" stroke="none" pointer-events="all"/></g><g><path d="M 511.93 184.48 L 511.77 191.47 L 492 181.02 L 512.22 171.48 L 512.06 178.48 L 580.07 180.02 L 580.23 173.03 L 600 183.48 L 579.78 193.02 L 579.94 186.02 Z" fill="#3399ff" stroke="none" pointer-events="all"/></g><g><path d="M 505.35 226.62 L 500.92 232.04 L 491.77 211.63 L 513.59 216.56 L 509.15 221.98 L 586.65 285.38 L 591.08 279.96 L 600.23 300.37 L 578.41 295.44 L 582.85 290.02 Z" fill="#3399ff" stroke="none" pointer-events="all"/></g><g><rect x="181" y="131" width="160" height="30" fill="none" stroke="none" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 158px; height: 1px; padding-top: 146px; margin-left: 182px;"><div data-drawio-colors="color: rgb(0, 0, 0); " style="box-sizing: border-box; font-size: 0px; text-align: center;"><div style="display: inline-block; font-size: 16px; font-family: Helvetica; color: rgb(0, 0, 0); line-height: 1.2; pointer-events: all; white-space: normal; overflow-wrap: normal;"><font style="font-size: 16px;" color="#ffffff"><b style="font-size: 16px;">Arbitrary Transport</b></font></div></div></div></foreignObject><image x="182" y="137" width="158" height="23" xlink:href=""/></switch></g></g><g><rect x="511" y="91" width="60" height="30" fill="none" stroke="none" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 58px; height: 1px; padding-top: 106px; margin-left: 512px;"><div data-drawio-colors="color: #FFFFFF; " style="box-sizing: border-box; font-size: 0px; text-align: center;"><div style="display: inline-block; font-size: 14px; font-family: Helvetica; color: rgb(255, 255, 255); line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; overflow-wrap: normal;">I2C</div></div></div></foreignObject><image x="512" y="98" width="58" height="20.5" xlink:href=""/></switch></g></g><g><rect x="511" y="151" width="60" height="30" fill="none" stroke="none" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 58px; height: 1px; padding-top: 166px; margin-left: 512px;"><div data-drawio-colors="color: #FFFFFF; " style="box-sizing: border-box; font-size: 0px; text-align: center;"><div style="display: inline-block; font-size: 14px; font-family: Helvetica; color: rgb(255, 255, 255); line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; overflow-wrap: normal;">SPI</div></div></div></foreignObject><image x="512" y="158" width="58" height="20.5" xlink:href=""/></switch></g></g><g><rect x="511" y="211" width="60" height="30" fill="none" stroke="none" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 58px; height: 1px; padding-top: 226px; margin-left: 512px;"><div data-drawio-colors="color: #FFFFFF; " style="box-sizing: border-box; font-size: 0px; text-align: center;"><div style="display: inline-block; font-size: 14px; font-family: Helvetica; color: rgb(255, 255, 255); line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; overflow-wrap: normal;">GPIO</div></div></div></foreignObject><image x="512" y="218" width="58" height="20.5" xlink:href=""/></switch></g></g></g></svg>
\ No newline at end of file
diff --git a/projects/beagleconnect/index.rst b/projects/beagleconnect/index.rst
index 588b63ffc70c4456e21983a95a876d72c564fbd4..c1ddb75f1c4a3c8196f5fc897020f3d6691d49aa 100644
--- a/projects/beagleconnect/index.rst
+++ b/projects/beagleconnect/index.rst
@@ -1,1178 +1,29 @@
-.. role:: strike
-   :class: strike
+.. _beagleconnect-technology:
 
-.. _beagleconnect-overview:
+BeagleConnectâ„¢ Technology
+##########################
 
-BeagleConnect Technology
-########################
+.. important::
 
-This is the deep-dive introduction to BeagleConnectâ„¢ technology and software
-architecture.
+   Currently under development
 
-.. note:: 
-    This documentation and the associated software are each a work-in-progress.
+BeagleConnectâ„¢ is a revolutionary technology virtually eliminating low-level  software development for `IoT <https://en.wikipedia.org/wiki/Internet_of_things>`_ and `IIoT <https://en.wikipedia.org/wiki/Industrial_internet_of_things>`_ applications, such as building automation, factory automation, home automation, and scientific data acquisition. 
 
-BeagleConnectâ„¢ is built using `Greybus <https://kernel-recipes.org/en/2015/talks/an-introduction-to-greybus/>`__
-code in the Linux kernel originally designed for mobile phones.
-To understand a bit more about how the BeagleConnectâ„¢ Greybus stack is being
-built, this section helps describe the development currently in progress and
-the principles of operation.
+While numerous IoT and IIoT solutions available today provide massive software libraries for microcontrollers supporting a limited body of `sensors <https://en.wikipedia.org/wiki/Sensor>`_, `actuators <https://en.wikipedia.org/wiki/Actuator>`_ and `indicators <https://en.wikipedia.org/wiki/Indicator_(distance_amplifying_instrument)>`_ as well as libraries for communicating over various networks, BeagleConnectâ„¢ simply eliminates the need for these libraries by shifting the burden into the  most massive and collaborative software project of all time, the `Linux kernel <https://en.wikipedia.org/wiki/Linux_kernel>`_.
 
-Background
-**********
-.. image:: images/SoftwareProp.jpg
-   :width: 600
-   :align: center
-   :height: 400
-   :alt: BeagleConnect Software Proposition
+These are the tools used to automate things in `scientific data collection <https://en.wikipedia.org/wiki/Data_collection_system>`_, `data science <https://en.wikipedia.org/wiki/Data_science>`_, `mechatronics <https://en.wikipedia.org/wiki/Mechatronics>`_, and `IoT <https://en.wikipedia.org/wiki/Internet_of_things>`_.
 
-BeagleConnectâ„¢ uses Greybus and mikroBUS add-on boards with ClickID and BeagleConnectâ„¢ mikroBUS manifests to 
-eliminate the need to add and manually configure devices added onto the Linux 
-system.
+BeagleConnectâ„¢ technology solves:
 
-High-level
-**********
-* For Linux nerds: Think of BeagleConnectâ„¢ as 6LoWPAN over 802.15.4-based 
-  Greybus (instead of Unipro as used by Project Ara), where every 
-  BeagleConnectâ„¢ board shows up as new SPI, I2C, UART, PWM, ADC, and GPIO 
-  controllers that can now be probed to load drivers for the sensors or 
-  whatever is connected to them. (Proof of concept of Greybus over TCP/IP: 
-  https://www.youtube.com/watch?v=7H50pv-4YXw)
+* The need to write software to add a large set of diverse devices to your system,
+* The need to maintain the software with security updates,
+* The need to rapidly prototype using off-the-shelf software and hardware without wiring,
+* The need to connect to devices using long-range, low-power wireless, and
+* The need to produce high-volume custom hardware cost-optimized for your requirements.
 
-* For MCU folks: Think of BeagleConnectâ„¢ as a Firmata-style firmware load that 
-  exposes the interfaces for remote access over a secured wireless network. 
-  However, instead of using host software that knows how to speak the Firmata 
-  protocol, the Linux kernel speaks the slightly similar Greybus protocol to 
-  the MCU and exposes the device generically to users using a Linux kernel 
-  driver. Further, the Greybus protocol is spoken over 6LoWPAN on 802.15.4.
+.. toctree::
+   :maxdepth: 2
 
-.. _beagleconnect-software-architecture:
-
-Software architecture
-*********************
-
-.. _beagleconnect-software-architecture-diagram:
-
-.. graphviz::
-        :caption: BeagleConnect Software Architecture Diagram
-
-    	// Software architecture
-    	digraph S {
-    		node [color=white shape=box]
-    		subgraph cluster_0 {
-    			color=black label="Linux PC"
-    			subgraph cluster_1 {
-    				node [color=green style=filled]
-    				color=lightgrey label="Linux userspace" style=filled
-    				A [label="User Application" tooltip="Primary developer entry point"]
-    				g [label="gbridge**" tooltip="Bridge Greybus to networked devices"]
-    			}
-    			subgraph cluster_2 {
-    				node [color=green style=filled]
-    				color=lightgrey label="Linux kernel" style=filled
-    				I [label="IIO Drivers" tooltip="Hundreds of drivers for sensors and acutators"]
-    				r [label=greybus tooltip="Dynamic RPC-like bus interface for I2C, SPI, UART, etc."]
-    				n [label="gb-netlink**" tooltip="Extend Greybus over netlink to userspace"]
-    				m [label="mikrobus**" tooltip="Board-level abstraction to identify sensor connections"]
-    				w [label="wpanusb**" tooltip="USB-interface to IEEE802.15.4 radio"]
-    				i [label=ieee802154 tooltip="Standards-based radio interface"]
-    				6 [label=lowpan tooltip="IPv6 for low-power wireless networks"]
-    			}
-    		}
-    		subgraph cluster_3 {
-    			color=black label="BCF gateway"
-    			subgraph cluster_4 {
-    				node [color=green style=filled]
-    				color=lightgrey label=CC1352 style=filled
-    				z [label="gateway**" tooltip="Zephyr-based IEEE802.15.4 radio accepting HDLC over UART transactions"]
-    			}
-    			subgraph cluster_5 {
-    				node [color=green style=filled]
-    				color=lightgrey label=MSP430 style=filled
-    				b [label="usb_uart_bridge**" tooltip="USB interace to access CC1352 UART that encapulates WPANUSB in HDLC"]
-    			}
-    		}
-    		subgraph cluster_6 {
-    			color=black label="BCF node"
-    			subgraph cluster_7 {
-    				node [color=green style=filled]
-    				color=lightgrey label=CC1352 style=filled
-    				k [label="greybus-mikrobus**" tooltip="Zephyr-based applies Greybus transactions from IPv6/IEEE802154 to physical I2C, SPI, UART, etc."]
-    			}
-    			subgraph cluster_8 {
-    				node [color=green style=filled]
-    				color=lightgrey label="mikroBUS add-on board" style=filled
-    				e [label="manifest 1-wire EEPROM**" tooltip="Manifest for mikroBUS driver"]
-    				s [label=sensor tooltip="Over 1,000 different sensor, actuator and indicator options"]
-    			}
-    		}
-    		A -> I
-    		I -> m
-    		m -> r
-    		r -> n
-    		n -> g
-    		g -> 6
-    		6 -> i
-    		i -> w
-    		w -> b
-    		b -> z
-    		z -> k
-    		k -> s
-    		k -> e
-    	}
-
-
-TODO items
-**********
-
-* :strike:`Linux kernel driver` (wpanusb and bcfserial still need to be upstreamed)
-
-* Provisioning
-
-* :strike:`Firmware for host CC13x`
-
-* :strike:`Firmware for device CC13x`
-
-* Unify firmware for host/device CC13x
-
-* :strike:`Click Board drivers and device tree formatted metadata for 100 or so Click 
-  Boards`
-
-* Click Board plug-ins for node-red for the same 100 or so Click Boards
-
-* BeagleConnectâ„¢ Freedom System Reference Manual and FAQs
-
-
-Associated pre-work
-*******************
-
-* Click Board support for Node-RED can be executed with native connections on 
-  PocketBeagle+TechLab and BeagleBone Black with mikroBUS Cape
-
-* Device tree fragments and driver updates can be provided via 
-  https://bbb.io/click
-
-* The Kconfig style provisioning can be implemented for those solutions, which 
-  will require a reboot. We need to centralize edits to /boot/uEnv.txt to be 
-  programmatic. As I think through this, I don't think BeagleConnect is 
-  impacted, because the Greybus-style discovery along with Click EEPROMS will 
-  eliminate any need to edit /boot/uEnv.txt.
-
-User experience concerns
-************************
-
-* Make sure no reboots are required
-
-* Plugging BeagleConnect into host should trigger host configuration
-
-* Click EEPROMs should trigger loading whatever drivers are needed and 
-  provisioning should load any new drivers
-
-* Userspace (spidev, etc.) drivers should unload cleanly when 2nd phase 
-  provisioning is completed
-
-BeagleConnectâ„¢ Greybus demo using BeagleConnectâ„¢ Freedom
-********************************************************
-BeagleConnectâ„¢ Freedom runs a subGHz IEEE 802.15.4 network. This BeagleConnectâ„¢
-Greybus demo shows how to interact with GPIO, I2C and mikroBUS add-on boards 
-remotely connected over a BeagleConnectâ„¢ Freedom.
-
-This section starts with the steps required to use 
-`Linux <https://en.wikipedia.org/wiki/Linux>`_ embedded computer 
-(`BeagleBone Green Gateway <https://wiki.seeedstudio.com/BeagleBone-Green-Gateway/>`_) 
-and the `Greybus <https://lwn.net/Articles/715955/>`_ protocol, over an 
-IEEE 802.15.4 wireless link, to blink an LED on a 
-`Zephyr <https://zephyrproject.org/>`_ device.
-
-Introduction
-------------
-
-*Why??*
-
-Good question. Blinking an LED is kind of the 
-`Hello, World <https://en.wikipedia.org/wiki/%22Hello,_World!%22_program>`_ of 
-the hardware community. In this case, we're less interested in the mechanics 
-of switching a GPIO to drive some current through an LED and more interested in
-how that happens with the 
-`Internet of Things (IoT) <https://en.wikipedia.org/wiki/Internet_of_things>`_.
-
-There are several existing network and application layers that are driven by 
-corporate heavyweights and industry consortiums, but relatively few that are 
-community driven and, more specifically, even fewer that have the ability to 
-integrate so tightly with the Linux kernel.
-
-The goal here is to provide a community-maintained, developer-friendly, and 
-open-source protocol for the Internet of Things using the Greybus Protocol, and
-blinking an LED using Greybus is the simplest proof-of-concept for that. All 
-that is required is a reliable transport.
-
-#. Power a BeagleConnect Freedom that has not yet been programmed via a USB 
-   power source, not the BeagleBone Green Gateway. You'll hear a click every 
-   1-2 seconds along with seeing 4 of the LEDs turn off and on.
-
-#. In an isolated terminal window, :code:`sudo beagleconnect-start-gateway`
-
-#. :code:`sensortest-rx.py`
-
-Every 1-2 minutes, you should see something like:
-
-.. code-block:: bash
-
-    ('fe80::3111:7a22:4b:1200%lowpan0', 52213, 0, 13)  '2l:7.79;'
-    ('fe80::3111:7a22:4b:1200%lowpan0', 52213, 0, 13)  '4h:43.75;4t:23.11;'
-
-The value after "2l:" is the amount of light in lux. The value after "4h:" is 
-the relative humidity and after "4t:" is the temperature in Celsius.
-
-Flash BeagleConnectâ„¢ Freedom node device with Greybus firmware
---------------------------------------------------------------
-
-.. todo:: How can we add a step in here to show the network is connected without needing gbridge to be fully functional?
-
-Do this from the BeagleBone® Green Gateway board that was previously used to 
-program the BeagleConnectâ„¢ Freedom gateway device:
-
-#. Disconnect the BeagleConnectâ„¢ Freedom **gateway** device
-
-#. Connect a new BeagleConnectâ„¢ Freedom board via USB
-
-#. :code:`sudo systemctl stop lowpan.service`
-
-#. :code:`cc2538-bsl.py /usr/share/beagleconnect/cc1352/greybus_mikrobus_beagleconnect.bin /dev/ttyACM0`
-
-#. After it finishes programming successfully, disconnect the BeagleConnect Freedom node device
-
-#. Power the newly programmed BeagleConnect Freedom node device from an alternate USB power source
-
-#. Reconnect the BeagleConnect Freedom **gateway** device to the BeagleBone Green Gateway
-
-#. :code:`sudo systemctl start lowpan.service`
-
-#. :code:`sudo beagleconnect-start-gateway`
-
-.. code-block:: bash
-
-    debian@beaglebone:~$ sudo beagleconnect-start-gateway
-    [sudo] password for debian:
-    setting up wpanusb gateway for IEEE 802154 CHANNEL 1(906 Mhz)
-    ping6: Warning: source address might be selected on device other than lowpan0.
-    PING 2001:db8::1(2001:db8::1) from ::1 lowpan0: 56 data bytes
-    64 bytes from 2001:db8::1: icmp_seq=2 ttl=64 time=185 ms
-    64 bytes from 2001:db8::1: icmp_seq=3 ttl=64 time=40.9 ms
-    64 bytes from 2001:db8::1: icmp_seq=4 ttl=64 time=40.9 ms
-    64 bytes from 2001:db8::1: icmp_seq=5 ttl=64 time=40.6 ms
-
-    --- 2001:db8::1 ping statistics ---
-    5 packets transmitted, 4 received, 20% packet loss, time 36ms
-    rtt min/avg/max/mdev = 40.593/76.796/184.799/62.356 ms
-    debian@beaglebone:~$ iio_info
-    Library version: 0.19 (git tag: v0.19)
-    Compiled with backends: local xml ip usb serial
-    IIO context created with local backend.
-    Backend version: 0.19 (git tag: v0.19)
-    Backend description string: Linux beaglebone 5.14.18-bone20 #1buster PREEMPT Tue Nov 16 20:47:19 UTC 2021 armv7l
-    IIO context has 1 attributes:
-        local,kernel: 5.14.18-bone20
-    IIO context has 3 devices:
-        iio:device0: TI-am335x-adc.0.auto (buffer capable)
-            8 channels found:
-                voltage0:  (input, index: 0, format: le:u12/16>>0)
-                1 channel-specific attributes found:
-                    attr  0: raw value: 1412
-                voltage1:  (input, index: 1, format: le:u12/16>>0)
-                1 channel-specific attributes found:
-                    attr  0: raw value: 2318
-                voltage2:  (input, index: 2, format: le:u12/16>>0)
-                1 channel-specific attributes found:
-                    attr  0: raw value: 2631
-                voltage3:  (input, index: 3, format: le:u12/16>>0)
-                1 channel-specific attributes found:
-                    attr  0: raw value: 817
-                voltage4:  (input, index: 4, format: le:u12/16>>0)
-                1 channel-specific attributes found:
-                    attr  0: raw value: 881
-                voltage5:  (input, index: 5, format: le:u12/16>>0)
-                1 channel-specific attributes found:
-                    attr  0: raw value: 0
-                voltage6:  (input, index: 6, format: le:u12/16>>0)
-                1 channel-specific attributes found:
-                    attr  0: raw value: 0
-                voltage7:  (input, index: 7, format: le:u12/16>>0)
-                1 channel-specific attributes found:
-                    attr  0: raw value: 1180
-            2 buffer-specific attributes found:
-                    attr  0: data_available value: 0
-                    attr  1: watermark value: 1
-        iio:device1: hdc2010
-            3 channels found:
-                humidityrelative:  (input)
-                3 channel-specific attributes found:
-                    attr  0: peak_raw value: 52224
-                    attr  1: raw value: 52234
-                    attr  2: scale value: 1.525878906
-                current:  (output)
-                2 channel-specific attributes found:
-                    attr  0: heater_raw value: 0
-                    attr  1: heater_raw_available value: 0 1
-                temp:  (input)
-                4 channel-specific attributes found:
-                    attr  0: offset value: -15887.515151
-                    attr  1: peak_raw value: 25600
-                    attr  2: raw value: 25628
-                    attr  3: scale value: 2.517700195
-        iio:device2: opt3001
-            1 channels found:
-                illuminance:  (input)
-                2 channel-specific attributes found:
-                    attr  0: input value: 79.040000
-                    attr  1: integration_time value: 0.800000
-            2 device-specific attributes found:
-                    attr  0: current_timestamp_clock value: realtime
-
-                    attr  1: integration_time_available value: 0.1 0.8
-    debian@beaglebone:~$ dmesg | grep -e mikrobus -e greybus
-    [  100.491253] greybus 1-2.2: Interface added (greybus)
-    [  100.491294] greybus 1-2.2: GMP VID=0x00000126, PID=0x00000126
-    [  100.491306] greybus 1-2.2: DDBL1 Manufacturer=0x00000126, Product=0x00000126
-    [  100.737637] greybus 1-2.2: excess descriptors in interface manifest
-    [  102.475168] mikrobus:mikrobus_port_gb_register: mikrobus gb_probe , num cports= 2, manifest_size 192
-    [  102.475206] mikrobus:mikrobus_port_gb_register: protocol added 3
-    [  102.475214] mikrobus:mikrobus_port_gb_register: protocol added 2
-    [  102.475239] mikrobus:mikrobus_port_register: registering port mikrobus-1
-    [  102.475400] mikrobus_manifest:mikrobus_state_get: mikrobus descriptor not found
-    [  102.475417] mikrobus_manifest:mikrobus_manifest_attach_device: parsed device 1, driver=opt3001, protocol=3, reg=44
-    [  102.494516] mikrobus_manifest:mikrobus_manifest_attach_device: parsed device 2, driver=hdc2010, protocol=3, reg=41
-    [  102.494567] mikrobus_manifest:mikrobus_manifest_parse:  (null) manifest parsed with 2 devices
-    [  102.494592] mikrobus mikrobus-1: registering device : opt3001
-    [  102.495096] mikrobus mikrobus-1: registering device : hdc2010
-    debian@beaglebone:~$
-
-
-.. todo:: update the below for the built-in sensors
-
-.. todo:: can we also handle the case where these sensors are included and recommend them? Same firmware?
-
-.. todo:: the current demo is for the built-in sensors, not the Click boards mentioned below
-
-Currently only a limited number of add-on boards have been tested to work over Greybus, simple add-on boards without interrupt requirement are the ones that work currently. The example is for Air Quality 2 Click and Weather Click attached to the mikroBUS ports on the device side.
-
-/var/log/gbridge will have the gbridge log, and if the mikroBUS port has been instantiated successfully the kernel log will show the devices probe messages:
-
-.. todo:: this log needs to be updated
-
-.. code-block::
-
-    greybus 1-2.2: GMP VID=0x00000126, PID=0x00000126
-    greybus 1-2.2: DDBL1 Manufacturer=0x00000126, Product=0x00000126
-    greybus 1-2.2: excess descriptors in interface manifest
-    mikrobus:mikrobus_port_gb_register: mikrobus gb_probe , num cports= 3, manifest_size 252
-    mikrobus:mikrobus_port_gb_register: protocol added 11
-    mikrobus:mikrobus_port_gb_register: protocol added 3
-    mikrobus:mikrobus_port_gb_register: protocol added 2
-    mikrobus:mikrobus_port_register: registering port mikrobus-0
-    mikrobus_manifest:mikrobus_manifest_attach_device: parsed device 1, driver=bme280, protocol=3, reg=76
-    mikrobus_manifest:mikrobus_manifest_attach_device: parsed device 2, driver=ams-iaq-core, protocol=3, reg=5a
-    mikrobus_manifest:mikrobus_manifest_parse:  Greybus Service Sample Application manifest parsed with 2 devices
-    mikrobus mikrobus-0: registering device : bme280
-    mikrobus mikrobus-0: registering device : ams-iaq-core
-
-
-.. todo:: bring in the GPIO toggle and I2C explorations for greater understanding
-
-Flashing via a Linux Host
--------------------------
-
-
-
-If flashing the Freedom board via the BeagleBone fails here's a trick you can try to flash from a Linux host.
-
-Use :code:`sshfs` to mount the Bone's files on the Linux host. This assumes the
-Bone is plugged in the USB and appears at :code:`192.168.7.2`:
-
-.. code-block:: bash
-
-    host$ cd
-    host$ sshfs 192.168.7.2:/ bone
-    host$ cd bone; ls
-    bin   dev  home    lib         media  opt   root  sbin  sys  usr
-    boot  etc  ID.txt  lost+found  mnt    proc  run   srv   tmp  var
-    host$ ls /dev/ttyACM*
-    /dev/ttyACM1
-
-
-
-The Bone's files now appear as local files. Notice there is already a 
-:code:`/dev/ACM*` appearing. Now plug the Connect into the Linux host's USB 
-port and run the command again.
-
-.. code-block:: bash
-
-    host$ ls /dev/ttyACM*
-    /dev/ttyACM0  /dev/ttyACM1
-
-The :code:`/dev/ttyACM` that just appeared is the one associated with the 
-Connect. In my case it's :code:`/dev/ttyACM0`. That's what I'll use in this 
-example.
-
-Now change directories to where the binaries are and load:
-
-.. code-block:: bash
-
-    host$ cd ~/bone/usr/share/beagleconnect/cc1352;ls
-    greybus_mikrobus_beagleconnect.bin     sensortest_beagleconnect.dts
-    greybus_mikrobus_beagleconnect.config  wpanusb_beagleconnect.bin
-    greybus_mikrobus_beagleconnect.dts     wpanusb_beagleconnect.config
-    sensortest_beagleconnect.bin           wpanusb_beagleconnect.dts
-    sensortest_beagleconnect.config
-
-    host$ ~/bone/usr/bin/cc2538-bsl.py sensortest_beagleconnect.bin /dev/ttyACM0
-    8-bsl.py sensortest_beagleconnect.bin /dev/ttyACM0
-    Opening port /dev/ttyACM0, baud 50000
-    Reading data from sensortest_beagleconnect.bin
-    Cannot auto-detect firmware filetype: Assuming .bin
-    Connecting to target...
-    CC1350 PG2.0 (7x7mm): 352KB Flash, 20KB SRAM, CCFG.BL_CONFIG at 0x00057FD8
-    Primary IEEE Address: 00:12:4B:00:22:7A:10:46
-        Performing mass erase
-    Erasing all main bank flash sectors
-        Erase done
-    Writing 360448 bytes starting at address 0x00000000
-    Write 104 bytes at 0x00057F988
-        Write done
-    Verifying by comparing CRC32 calculations.
-        Verified (match: 0x0f6bdf0f)
-
-Now you are ready to continue the instructions above after the cc2528 command.
-
-Trying for different add-on boards
-^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-
-See `mikroBUS over Greybus <https://github.com/vaishnav98/greybus-for-zephyr/tree/mikrobus#trying-out-different-add-on-boardsdevices-over-mikrobus>`_ 
-for trying out the same example for different mikroBUS add-on boards/ on-board devices.
-
-Observe the node device
------------------------
-
-Connect BeagleConnect Freedom node device to an Ubuntu laptop to observe the 
-Zephyr console.
-
-
-Console (:code:`tio`)
----------------------
-In order to see diagnostic messages or to run certain commands on the Zephyr 
-device we will require a terminal open to the device console. In this case, we
-use `tio <https://tio.github.io/>`_ due how its usage simplifies the 
-instructions.
-
-#. Install :code:`tio`
-   :code:`sudo apt install -y tio`
-
-#. Run :code:`tio`
-   :code:`tio /dev/ttyACM0`
-
- To exit :code:`tio` (later), enter :code:`ctrl+t, q`. 
-
-
-The Zephyr Shell
-----------------
-
-
-After flashing, you should observe the something matching the following output in :code:`tio`.
-
-.. code-block:: bash
-
-    uart:~$ *** Booting Zephyr OS build 9c858c863223  ***
-    [00:00:00.009,735] <inf> greybus_transport_tcpip: CPort 0 mapped to TCP/IP port 4242
-    [00:00:00.010,131] <inf> greybus_transport_tcpip: CPort 1 mapped to TCP/IP port 4243
-    [00:00:00.010,528] <inf> greybus_transport_tcpip: CPort 2 mapped to TCP/IP port 4244
-    [00:00:00.010,742] <inf> greybus_transport_tcpip: Greybus TCP/IP Transport initialized
-    [00:00:00.010,864] <inf> greybus_manifest: Registering CONTROL greybus driver.
-    [00:00:00.011,230] <inf> greybus_manifest: Registering GPIO greybus driver.
-    [00:00:00.011,596] <inf> greybus_manifest: Registering I2C greybus driver.
-    [00:00:00.011,871] <inf> greybus_service: Greybus is active
-    [00:00:00.026,092] <inf> net_config: Initializing network
-    [00:00:00.134,063] <inf> net_config: IPv6 address: 2001:db8::1
-
-
-
-The line beginning with :code:`***` is the Zephyr boot banner.
-
-Lines beginning with a timestamp of the form :code:`[H:m:s.us]` are Zephyr 
-kernel messages.
-
-Lines beginning with :code:`uart:~$` indicates that the Zephyr shell is 
-prompting you to enter a command.
-
-From the informational messages shown, we observe the following.
-
-* Zephyr is configured with the following 
-  `link-local IPv6 address <https://en.wikipedia.org/wiki/Link-local_address#IPv6>`_ :code:`fe80::3177:a11c:4b:1200`
-
-* It is listening for (both) TCP and UDP traffic on port 4242
-
-However, what the log messages do not show (which will come into play later), 
-are 2 critical pieces of information:
-
-#. **The RF Channel**: As you may have guessed, IEEE 802.15.4 devices are only 
-   able to communicate with each other if they are using the same frequency to 
-   transmit and receive data. This information is part of the Physical Layer.
-
-#. The `PAN identifier <https://www.silabs.com/community/wireless/proprietary/knowledge-base.entry.html/2019/10/04/connect_tutorial6-ieee802154addressing-rapc>`_: 
-   IEEE 802.15.4 devices are only be able to communicate with one another if 
-   they use the same PAN ID. This permits multiple networks (PANs) on the same 
-   frequency. This information is part of the Data Link Layer.
-
-If we type :code:`help` in the shell and hit Enter, we're prompted with the 
-following:
-
-.. code-block::
-
-    Please press the <Tab> button to see all available commands.
-    You can also use the <Tab> button to prompt or auto-complete all commands or its subcommands.
-    You can try to call commands with <-h> or <--help> parameter for more information.
-    Shell supports following meta-keys:
-
-    Ctrl+a, Ctrl+b, Ctrl+c, Ctrl+d, Ctrl+e, Ctrl+f, Ctrl+k, Ctrl+l, Ctrl+n, Ctrl+p, Ctrl+u, Ctrl+w
-    Alt+b, Alt+f.
-    Please refer to shell documentation for more details.
-
-So after hitting Tab, we see that there are several interesting commands we can
-use for additional information.
-
-.. code-block::
-
-    uart:~$
-    clear       help        history     ieee802154  log         net
-    resize      sample      shell
-
-Zephyr Shell: IEEE 802.15.4 commands
-^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-
-Entering :code:`ieee802154 help`, we see
-
-.. code-block::
-
-    uart:~$ ieee802154 help
-    ieee802154 - IEEE 802.15.4 commands
-    Subcommands:
-    ack             :<set/1 | unset/0> Set auto-ack flag
-    associate       :<pan_id> <PAN coordinator short or long address (EUI-64)>
-    disassociate    :Disassociate from network
-    get_chan        :Get currently used channel
-    get_ext_addr    :Get currently used extended address
-    get_pan_id      :Get currently used PAN id
-    get_short_addr  :Get currently used short address
-    get_tx_power    :Get currently used TX power
-    scan            :<passive|active> <channels set n[:m:...]:x|all> <per-channel
-                    duration in ms>
-    set_chan        :<channel> Set used channel
-    set_ext_addr    :<long/extended address (EUI-64)> Set extended address
-    set_pan_id      :<pan_id> Set used PAN id
-    set_short_addr  :<short address> Set short address
-    set_tx_power    :<-18/-7/-4/-2/0/1/2/3/5> Set TX power
-
-
-We get the missing Channel number (frequency) with the command :code:`ieee802154 get_chan`.
-
-.. code-block::
-
-    uart:~$ ieee802154 get_chan
-    Channel 26
-
-We get the missing PAN ID with the command :code:`ieee802154 get_pan_id`.
-
-.. code-block::
-
-    uart:~$ ieee802154 get_pan_id
-    PAN ID 43981 (0xabcd)
-
-Zephyr Shell: Network Commands
-^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-
-Additionally, we may query the IPv6 information of the Zephyr device.
-
-.. code-block::
-
-    uart:~$ net iface
-
-    Interface 0x20002b20 (IEEE 802.15.4) [1]
-    ========================================
-    Link addr : CD:99:A1:1C:00:4B:12:00
-    MTU       : 125
-    IPv6 unicast addresses (max 3):
-            fe80::cf99:a11c:4b:1200 autoconf preferred infinite
-            2001:db8::1 manual preferred infinite
-    IPv6 multicast addresses (max 4):
-            ff02::1
-            ff02::1:ff4b:1200
-            ff02::1:ff00:1
-    IPv6 prefixes (max 2):
-            <none>
-    IPv6 hop limit           : 64
-    IPv6 base reachable time : 30000
-    IPv6 reachable time      : 16929
-    IPv6 retransmit timer    : 0
-
-
-
-And we see that the static IPv6 address (:code:`2001:db8::1`) from 
-:code:`samples/net/sockets/echo_server/prj.conf` is present and configured. 
-While the statically configured IPv6 address is useful, it isn't 100% necessary.
-
-Rebuilding from source
-----------------------
-
-.. todo:: revisit everything below here
-
-Prerequisites
-^^^^^^^^^^^^^
-
-* Zephyr environment is set up according to the 
-  `Getting Started Guide <https://docs.zephyrproject.org/latest/getting_started/index.html>`_
-
-    * Please use the Zephyr SDK when installing a toolchain above
-
-* `Zephyr SDK <https://docs.zephyrproject.org/latest/getting_started/index.html#install-a-toolchain>`_ 
-  is installed at ~/zephyr-sdk-0.11.2 (any later version should be fine as well)
-
-* Zephyr board is connected via USB
-
-Cloning the repository
-^^^^^^^^^^^^^^^^^^^^^^
-
-This repository utilizes `git submodules <https://git-scm.com/book/en/v2/Git-Tools-Submodules>`_ 
-to keep track of all of the projects required to reproduce the ongoing work. 
-The instructions here only cover checking out the :code:`demo` branch which 
-should stay in a tested state. ongoing development will be on the 
-:code:`master` branch.
-
-Note: The parent directory :code:`~` is simply used as a placeholder for testing. 
-Please use whatever parent directory you see fit. 
-
-Clone specific tag
-^^^^^^^^^^^^^^^^^^
-
-.. code-block:: bash
-
-    cd ~
-    git clone --recurse-submodules --branch demo https://github.com/jadonk/beagleconnect
-
-Zephyr
-------
-
-Add the Fork
-^^^^^^^^^^^^
-
-For the time being, Greybus must remain outside of the main Zephyr repository. 
-Currently, it is just in a Zephyr fork, but it should be converted to a 
-proper `Module (External Project) <https://docs.zephyrproject.org/latest/guides/modules.html>`_. 
-This is for a number of reasons, but mainly there must be:
-
-* specifications for authentication and encryption
-
-* specifications for joining and rejoining wireless networks
-
-* specifications for discovery
-
-Therefore, in order to reproduce this example, please run the following.
-
-.. code-block:: bash
-
-    cd ~/beagleconnect/sw/zephyrproject/zephyr
-    west update
-
-Build and Flash Zephyr
-^^^^^^^^^^^^^^^^^^^^^^
-
-Here, we will build and flash the Zephyr 
-`greybus_net sample <https://github.com/cfriedt/zephyr/tree/greybus-sockets/samples/subsys/greybus/net>`_ 
-to our device.
-
-#. Edit the file :code:`~/.zephyrrc` and place the following text inside of it
-
-.. code-block:: bash
-
-    export ZEPHYR_TOOLCHAIN_VARIANT=zephyr
-    export ZEPHYR_SDK_INSTALL_DIR=~/zephyr-sdk-0.11.2
-
-#. Set up the required Zephyr environment variables via
-
-.. code-block:: bash
-
-    source zephyr-env.sh
-
-#. Build the project
-
-.. code-block:: bash
-
-    BOARD=cc1352r1_launchxl west build samples/subsys/greybus/net --pristine \
-    --build-dir build/greybus_launchpad -- -DCONF_FILE="prj.conf overlay-802154.conf"
-
-#. Ensure that the last part of the build process looks somewhat like this:
-
-.. code-block:: bash
-
-    ...
-    [221/226] Linking C executable zephyr/zephyr_prebuilt.elf
-    Memory region         Used Size  Region Size  %age Used
-            FLASH:      155760 B     360360 B     43.22%
-        FLASH_CCFG:          88 B         88 B    100.00%
-                SRAM:       58496 B        80 KB     71.41%
-            IDT_LIST:         184 B         2 KB      8.98%
-    [226/226] Linking C executable zephyr/zephyr.elf
-
-#. Flash the firmware to your device using
-
-.. code-block:: bash
-
-    BOARD=cc1352r1_launchxl west flash --build-dir build/greybus_launchpad
-
-Linux
------
-
-Warning: If you aren't comfortable building and installing a Linux kernel on 
-your computer, you should probably just stop here. I'll assume you know the 
-basics of building and installing a Linux kernel from here on out. 
-
-Clone, patch, and build the kernel
-^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-
-For this demo, I used the 5.8.4 stable kernel. Also, I've applied the 
-:code:`mikrobus` kernel driver, though it isn't strictly required for greybus.
-
-Note: The parent directory :code:`~` is simply used as a placeholder for testing. 
-Please use whatever parent directory you see fit. 
-
-.. todo:: The patches for gb-netlink will eventually be applied here until pushed into mainline.
-
-.. code-block:: bash
-
-    cd ~
-    git clone --branch v5.8.4 --single-branch git://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
-    cd linux
-    git checkout -b v5.8.4-greybus
-    git am ~/beagleconnect/sw/linux/v2-0001-RFC-mikroBUS-driver-for-add-on-boards.patch
-    git am ~/beagleconnect/sw/linux/0001-mikroBUS-build-fixes.patch
-    cp /boot/config-`uname -r` .config
-    yes "" | make oldconfig
-    ./scripts/kconfig/merge_config.sh .config ~/beagleconnect/sw/linux/mikrobus.config
-    ./scripts/kconfig/merge_config.sh .config ~/beagleconnect/sw/linux/atusb.config
-    make -j`nproc --all`
-    sudo make modules_install
-    sudo make install
-
-Reboot and select your new kernel.
-
-Probe the IEEE 802.15.4 Device Driver
-^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-
-On the Linux machine, make sure the :code:`atusb` driver is loaded. This should
-happen automatically when the adapter is inserted or when the machine is booted
-while the adapter is installed.
-
-.. code-block:: bash
-
-    $ dmesg | grep -i ATUSB
-    [    6.512154] usb 1-1: ATUSB: AT86RF231 version 2
-    [    6.512492] usb 1-1: Firmware: major: 0, minor: 3, hardware type: ATUSB (2)
-    [    6.525357] usbcore: registered new interface driver atusb
-    ...
-
-
-
-We should now be able to see the IEEE 802.15.4 network device by entering :code:`ip a show wpan0`.
-
-.. code-block:: bash
-
-    $ ip a show wpan0
-    36: wpan0: <BROADCAST,NOARP,UP,LOWER_UP> mtu 123 qdisc fq_codel state UNKNOWN group default qlen 300
-        link/ieee802.15.4 3e:7d:90:4d:8f:00:76:a2 brd ff:ff:ff:ff:ff:ff:ff:ff
-
-
-But wait, that is not an IP address! It's the hardware address of the 802.15.4 
-device. So, in order to associate it with an IP address, we need to run a 
-couple of other commands (thanks to wpan.cakelab.org).
-
-Set the 802.15.4 Physical and Link-Layer Parameters
-^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-
-#. First, get the phy number for the :code:`wpan0` device
-
-.. code-block:: bash
-
-    $ iwpan list
-        wpan_phy phy0
-        supported channels:
-            page 0: 11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26
-        current_page: 0
-        current_channel: 26,  2480 MHz
-        cca_mode: (1) Energy above threshold
-        cca_ed_level: -77
-        tx_power: 3
-        capabilities:
-            iftypes: node,monitor
-            channels:
-                page 0:
-                    [11]  2405 MHz, [12]  2410 MHz, [13]  2415 MHz,
-                    [14]  2420 MHz, [15]  2425 MHz, [16]  2430 MHz,
-                    [17]  2435 MHz, [18]  2440 MHz, [19]  2445 MHz,
-                    [20]  2450 MHz, [21]  2455 MHz, [22]  2460 MHz,
-                    [23]  2465 MHz, [24]  2470 MHz, [25]  2475 MHz,
-                    [26]  2480 MHz
-            tx_powers:
-                    3 dBm, 2.8 dBm, 2.3 dBm, 1.8 dBm, 1.3 dBm, 0.7 dBm,
-                    0 dBm, -1 dBm, -2 dBm, -3 dBm, -4 dBm, -5 dBm,
-                    -7 dBm, -9 dBm, -12 dBm, -17 dBm,
-            cca_ed_levels:
-                    -91 dBm, -89 dBm, -87 dBm, -85 dBm, -83 dBm, -81 dBm,
-                    -79 dBm, -77 dBm, -75 dBm, -73 dBm, -71 dBm, -69 dBm,
-                    -67 dBm, -65 dBm, -63 dBm, -61 dBm,
-            cca_modes:
-                (1) Energy above threshold
-                (2) Carrier sense only
-                (3, cca_opt: 0) Carrier sense with energy above threshold (logical operator is 'and')
-                (3, cca_opt: 1) Carrier sense with energy above threshold (logical operator is 'or')
-            min_be: 0,1,2,3,4,5,6,7,8
-            max_be: 3,4,5,6,7,8
-            csma_backoffs: 0,1,2,3,4,5
-            frame_retries: 3
-            lbt: false
-
-#. Next, set the Channel for the 802.15.4 device on the Linux machine
-
-.. code-block:: bash
-
-    sudo iwpan phy phy0 set channel 0 26
-
-#. Then, set the PAN identifier for the 802.15.4 device on the Linux machine :code:`sudo iwpan dev wpan0 set pan_id 0xabcd`
-
-#. Associate the :code:`wpan0` device to a new, 6lowpan network interface
-
-.. code-block:: bash
-
-    sudo ip link add link wpan0 name lowpan0 type lowpan
-
-#. Finally, set the links up for both :code:`wpan0` and :code:`lowpan0`
-
-.. code-block:: bash
-
-    sudo ip link set wpan0 up
-    sudo ip link set lowpan0 up
-
-
-
-We should observe something like the following when we run :code:`ip a show lowpan0`.
-
-.. code-block:: bash
-
-    ip a show lowpan0
-    37: lowpan0@wpan0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1280 qdisc noqueue state UNKNOWN group default qlen 1000
-        link/6lowpan 9e:0b:a4:e8:00:d3:45:53 brd ff:ff:ff:ff:ff:ff:ff:ff
-        inet6 fe80::9c0b:a4e8:d3:4553/64 scope link
-        valid_lft forever preferred_lft forever
-
-Ping Pong
----------
-
-Broadcast Ping
-^^^^^^^^^^^^^^
-
-Now, perform a broadcast ping to see what else is listening on :code:`lowpan0`.
-
-.. code-block::
-
-    $ ping6 -I lowpan0 ff02::1
-    PING ff02::1(ff02::1) from fe80::9c0b:a4e8:d3:4553%lowpan0 lowpan0: 56 data bytes
-    64 bytes from fe80::9c0b:a4e8:d3:4553%lowpan0: icmp_seq=1 ttl=64 time=0.099 ms
-    64 bytes from fe80::9c0b:a4e8:d3:4553%lowpan0: icmp_seq=2 ttl=64 time=0.125 ms
-    64 bytes from fe80::cf99:a11c:4b:1200%lowpan0: icmp_seq=2 ttl=64 time=17.3 ms (DUP!)
-    64 bytes from fe80::9c0b:a4e8:d3:4553%lowpan0: icmp_seq=3 ttl=64 time=0.126 ms
-    64 bytes from fe80::cf99:a11c:4b:1200%lowpan0: icmp_seq=3 ttl=64 time=9.60 ms (DUP!)
-    64 bytes from fe80::9c0b:a4e8:d3:4553%lowpan0: icmp_seq=4 ttl=64 time=0.131 ms
-    64 bytes from fe80::cf99:a11c:4b:1200%lowpan0: icmp_seq=4 ttl=64 time=14.9 ms (DUP!)
-
-Yay! We have pinged (pung?) the Zephyr device over IEEE 802.15.4 using 6LowPAN!
-
-Ping Zephyr
-^^^^^^^^^^^
-
-We can ping the Zephyr device directly without a broadcast ping too, of course.
-
-.. code-block::
-
-    $ ping6 -I lowpan0 fe80::cf99:a11c:4b:1200
-    PING fe80::cf99:a11c:4b:1200(fe80::cf99:a11c:4b:1200) from fe80::9c0b:a4e8:d3:4553%lowpan0 lowpan0: 56 data bytes
-    64 bytes from fe80::cf99:a11c:4b:1200%lowpan0: icmp_seq=1 ttl=64 time=16.0 ms
-    64 bytes from fe80::cf99:a11c:4b:1200%lowpan0: icmp_seq=2 ttl=64 time=13.8 ms
-    64 bytes from fe80::cf99:a11c:4b:1200%lowpan0: icmp_seq=3 ttl=64 time=9.77 ms
-    64 bytes from fe80::cf99:a11c:4b:1200%lowpan0: icmp_seq=5 ttl=64 time=11.5 ms
-
-Ping Linux
-^^^^^^^^^^
-
-Similarly, we can ping the Linux host from the Zephyr shell.
-
-.. code-block:: bash
-
-    uart:~$ net ping --help
-    ping - Ping a network host.
-    Subcommands:
-    --help  :'net ping [-c count] [-i interval ms] <host>' Send ICMPv4 or ICMPv6
-            Echo-Request to a network host.
-    $ net ping -c 5 fe80::9c0b:a4e8:d3:4553
-    PING fe80::9c0b:a4e8:d3:4553
-    8 bytes from fe80::9c0b:a4e8:d3:4553 to fe80::cf99:a11c:4b:1200: icmp_seq=0 ttl=64 rssi=110 time=11 ms
-    8 bytes from fe80::9c0b:a4e8:d3:4553 to fe80::cf99:a11c:4b:1200: icmp_seq=1 ttl=64 rssi=126 time=9 ms
-    8 bytes from fe80::9c0b:a4e8:d3:4553 to fe80::cf99:a11c:4b:1200: icmp_seq=2 ttl=64 rssi=128 time=13 ms
-    8 bytes from fe80::9c0b:a4e8:d3:4553 to fe80::cf99:a11c:4b:1200: icmp_seq=3 ttl=64 rssi=126 time=10 ms
-    8 bytes from fe80::9c0b:a4e8:d3:4553 to fe80::cf99:a11c:4b:1200: icmp_seq=4 ttl=64 rssi=126 time=7 ms
-
-Assign a Static Address
-^^^^^^^^^^^^^^^^^^^^^^^
-
-So far, we have been using IPv6 Link-Local addressing. However, the Zephyr 
-application is configured to use a statically configured IPv6 address as well 
-which is, namely :code:`2001:db8::1`.
-
-If we add a similar static IPv6 address to our Linux IEEE 802.15.4 network 
-interface, :code:`lowpan0`, then we should expect to be able to reach that as 
-well.
-
-In Linux, run the following
-
-.. code-block:: bash
-
-    sudo ip -6 addr add 2001:db8::2/64 dev lowpan0
-
-We can verify that the address has been set by examining the :code:`lowpan0` 
-network interface again.
-
-.. code-block:: bash
-
-    $ ip a show lowpan0
-    37: lowpan0@wpan0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1280 qdisc noqueue state UNKNOWN group default qlen 1000
-        link/6lowpan 9e:0b:a4:e8:00:d3:45:53 brd ff:ff:ff:ff:ff:ff:ff:ff
-        inet6 2001:db8::2/64 scope global
-        valid_lft forever preferred_lft forever
-        inet6 fe80::9c0b:a4e8:d3:4553/64 scope link
-        valid_lft forever preferred_lft forever
-
-Lastly, ping the statically configured IPv6 address of the Zephyr device.
-
-.. code-block::
-
-    $ ping6 2001:db8::1
-    PING 2001:db8::1(2001:db8::1) 56 data bytes
-    64 bytes from 2001:db8::1: icmp_seq=2 ttl=64 time=53.7 ms
-    64 bytes from 2001:db8::1: icmp_seq=3 ttl=64 time=13.1 ms
-    64 bytes from 2001:db8::1: icmp_seq=4 ttl=64 time=22.0 ms
-    64 bytes from 2001:db8::1: icmp_seq=5 ttl=64 time=22.7 ms
-    64 bytes from 2001:db8::1: icmp_seq=6 ttl=64 time=18.4 ms
-
-Now that we have set up a reliable transport, let's move on to the application 
-layer.
-
-
-Greybus
--------
-
-Hopefully the videos listed earlier provide a sufficient foundation to 
-understand what will happen shortly. However, there is still a bit more 
-preparation required.
-
-Build and probe Greybus Kernel Modules
-^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-
-Greybus was originally intended to work exclusively on the UniPro physical 
-layer. However, we're using RF as our physical layer and TCP/IP as our 
-transport. As such, there was need to be able to communicate with the Linux 
-Greybus facilities through userspace, and out of that need arose gb-netlink. 
-The Netlink Greybus module actually does not care about the physical layer, but
-is happy to usher Greybus messages back and forth between the kernel and 
-userspace.
-
-Build and probe the gb-netlink modules (as well as the other Greybus modules) 
-with the following:
-
-.. code-block:: bash
-
-    cd ${WORKSPACE}/sw/greybus
-    make -j`nproc --all`
-    sudo make install
-    ../load_gb_modules.sh
-
-Build and Run Gbridge
-^^^^^^^^^^^^^^^^^^^^^
-
-The gbridge utility was created as a proof of concept to abstract the Greybus 
-Netlink datapath among several reliable transports. For the purposes of this 
-tutorial, we'll be using it as a TCP/IP bridge.
-
-To run :code:`gbridge`, perform the following:
-
-.. code-block:: bash
-
-    sudo apt install -y libnl-3-dev libnl-genl-3-dev libbluetooth-dev libavahi-client-dev
-    cd gbridge
-    autoreconf -vfi
-    GBNETLINKDIR=${PWD}/../greybus \
-    ./configure --enable-uart --enable-tcpip --disable-gbsim --enable-netlink --disable-bluetooth
-    make -j`nproc --all`
-    sudo make install
-    gbridge
-
-
-Blinky!
--------
-
-Now that we have set up a reliable TCP transport, and set up the Greybus 
-modules in the Linux kernel, and used Gbridge to connect a Greybus node to the 
-Linux kernel via TCP/IP, we can now get to the heart of the demonstration!
-
-First, save the following script as :code:`blinky.sh`.
-
-.. code-block:: bash
-
-    #!/bin/bash
-    
-    # Blinky Demo for CC1352R SensorTag
-    
-    # /dev/gpiochipN that Greybus created
-    CHIP="$(gpiodetect | grep greybus_gpio | head -n 1 | awk '{print $1}')"
-    
-    # red, green, blue LED pins
-    RED=6
-    GREEN=7
-    BLUE=21
-    
-    # Bash array for pins and values
-    PINS=($RED $GREEN $BLUE)
-    NPINS=${#PINS[@]}
-    
-    for ((;;)); do
-        for i in ${!PINS[@]}; do
-            # turn off previous pin
-            if [ $i -eq 0 ]; then
-                PREV=2
-            else
-                PREV=$((i-1))
-            fi
-            gpioset $CHIP ${PINS[$PREV]}=0
-    
-            # turn on current pin
-            gpioset $CHIP ${PINS[$i]}=1
-    
-            # wait a sec
-            sleep 1
-        done
-    done
-
-
-Second, run the script with root privileges: :code:`sudo bash blinky.sh`
-
-The output of your minicom session should resemble the following.
-
-.. code-block::
-
-    $ *** Booting Zephyr OS build zephyr-v2.3.0-1435-g40c0ed940d71  ***
-    [00:00:00.011,932] <inf> net_config: Initializing network
-    [00:00:00.111,938] <inf> net_config: IPv6 address: fe80::6c42:bc1c:4b:1200
-    [00:00:00.112,121] <dbg> greybus_service.greybus_service_init: Greybus initializing..
-    [00:00:00.112,426] <dbg> greybus_transport_tcpip.gb_transport_backend_init: Greybus TCP/IP Transport initializing..
-    [00:00:00.112,579] <dbg> greybus_transport_tcpip.netsetup: created server socket 0 for cport 0
-    [00:00:00.112,579] <dbg> greybus_transport_tcpip.netsetup: setting socket options for socket 0
-    [00:00:00.112,609] <dbg> greybus_transport_tcpip.netsetup: binding socket 0 (cport 0) to port 4242
-    [00:00:00.112,640] <dbg> greybus_transport_tcpip.netsetup: listening on socket 0 (cport 0)
-    [00:00:00.112,823] <dbg> greybus_transport_tcpip.netsetup: created server socket 1 for cport 1
-    [00:00:00.112,823] <dbg> greybus_transport_tcpip.netsetup: setting socket options for socket 1
-    [00:00:00.112,854] <dbg> greybus_transport_tcpip.netsetup: binding socket 1 (cport 1) to port 4243
-    [00:00:00.112,854] <dbg> greybus_transport_tcpip.netsetup: listening on socket 1 (cport 1)
-    [00:00:00.113,037] <inf> net_config: IPv6 address: fe80::6c42:bc1c:4b:1200
-    [00:00:00.113,250] <dbg> greybus_transport_tcpip.netsetup: created server socket 2 for cport 2
-    [00:00:00.113,250] <dbg> greybus_transport_tcpip.netsetup: setting socket options for socket 2
-    [00:00:00.113,281] <dbg> greybus_transport_tcpip.netsetup: binding socket 2 (cport 2) to port 4244
-    [00:00:00.113,311] <dbg> greybus_transport_tcpip.netsetup: listening on socket 2 (cport 2)
-    [00:00:00.113,494] <dbg> greybus_transport_tcpip.netsetup: created server socket 3 for cport 3
-    [00:00:00.113,494] <dbg> greybus_transport_tcpip.netsetup: setting socket options for socket 3
-    [00:00:00.113,525] <dbg> greybus_transport_tcpip.netsetup: binding socket 3 (cport 3) to port 4245
-    [00:00:00.113,555] <dbg> greybus_transport_tcpip.netsetup: listening on socket 3 (cport 3)
-    [00:00:00.113,861] <inf> greybus_transport_tcpip: Greybus TCP/IP Transport initialized
-    [00:00:00.116,149] <inf> greybus_service: Greybus is active
-    [00:00:00.116,546] <dbg> greybus_transport_tcpip.accept_loop: calling poll
-    [00:45:08.397,399] <dbg> greybus_transport_tcpip.accept_loop: poll returned 1
-    [00:45:08.397,399] <dbg> greybus_transport_tcpip.accept_loop: socket 0 (cport 0) has traffic
-    [00:45:08.397,491] <dbg> greybus_transport_tcpip.accept_loop: accepted connection from [2001:db8::2]:39638 as fd 4
-    [00:45:08.397,491] <dbg> greybus_transport_tcpip.accept_loop: spawning client thread..
-    [00:45:08.397,735] <dbg> greybus_transport_tcpip.accept_loop: calling poll
-    [00:45:08.491,363] <dbg> greybus_transport_tcpip.accept_loop: poll returned 1
-    [00:45:08.491,363] <dbg> greybus_transport_tcpip.accept_loop: socket 3 (cport 3) has traffic
-    [00:45:08.491,455] <dbg> greybus_transport_tcpip.accept_loop: accepted connection from [2001:db8::2]:39890 as fd 5
-    [00:45:08.491,455] <dbg> greybus_transport_tcpip.accept_loop: spawning client thread..
-    [00:45:08.491,699] <dbg> greybus_transport_tcpip.accept_loop: calling poll
-    [00:45:08.620,056] <dbg> greybus_transport_tcpip.accept_loop: poll returned 1
-    [00:45:08.620,086] <dbg> greybus_transport_tcpip.accept_loop: socket 2 (cport 2) has traffic
-    [00:45:08.620,147] <dbg> greybus_transport_tcpip.accept_loop: accepted connection from [2001:db8::2]:42422 as fd 6
-    [00:45:08.620,147] <dbg> greybus_transport_tcpip.accept_loop: spawning client thread..
-    [00:45:08.620,422] <dbg> greybus_transport_tcpip.accept_loop: calling poll
-    [00:45:08.679,504] <dbg> greybus_transport_tcpip.accept_loop: poll returned 1
-    [00:45:08.679,534] <dbg> greybus_transport_tcpip.accept_loop: socket 1 (cport 1) has traffic
-    [00:45:08.679,595] <dbg> greybus_transport_tcpip.accept_loop: accepted connection from [2001:db8::2]:48286 as fd 7
-    [00:45:08.679,595] <dbg> greybus_transport_tcpip.accept_loop: spawning client thread..
-    [00:45:08.679,870] <dbg> greybus_transport_tcpip.accept_loop: calling poll
-    ...
-
-Read I2C Registers
-^^^^^^^^^^^^^^^^^^
-
-The SensorTag comes with an opt3001 ambient light sensor as well as an hdc2080 
-temperature & humidity sensor.
-
-First, find which i2c device corresponds to the SensorTag:
-
-.. code-block:: bash
-
-    ls -la /sys/bus/i2c/devices/* | grep "greybus"
-    lrwxrwxrwx 1 root root 0 Aug 15 11:24 /sys/bus/i2c/devices/i2c-8 -> ../../../devices/virtual/gb_nl/gn_nl/greybus1/1-2/1-2.2/1-2.2.2/gbphy2/i2c-8
-
-On my machine, the i2c device node that Greybus creates is :code:`/dev/i2c-8`.
-
-Read the ID registers (at the i2c register address 0x7e) of the opt3001 sensor 
-(at i2c bus address 0x44) as shown below:
-
-.. code-block:: bash
-
-    i2cget -y 8 0x44 0x7e w
-    0x4954
-
-Read the ID registers (at the i2c register address 0xfc) of the hdc2080 sensor 
-(at i2c bus address 0x41) as shown below:
-
-.. code-block:: bash
-
-    i2cget -y 8 0x41 0xfc w
-    0x5449
-
-Conclusion
-----------
-
-The blinking LED can and poking i2c registers can be a somewhat anticlimactic, 
-but hopefully it illustrates the potential for Greybus as an IoT application layer 
-protocol.
-
-What is nice about this demo, is that we're using Device Tree to describe our 
-Greybus Peripheral declaratively, they Greybus Manifest is automatically 
-generated, and the Greybus Service is automatically started in Zephyr.
-
-In other words, all that is required to replicate this for other IoT devices is
-simply an appropriate Device Tree overlay file.
-
-The proof-of-concept involving Linux, Zephyr, and IEEE 802.15.4 was actually 
-fairly straight forward and was accomplished with mostly already-upstream 
-source.
-
-For Greybus in Zephyr, there is still a considerable amount of integration work
-to be done, including * converting the fork to a proper Zephyr module * adding 
-security and authentication * automatic detection, joining, and rejoining of 
-devices.
-
-Thanks for reading, and we hope you've enjoyed this tutorial.
+   introduction
+   beagleplay-bcf
+   beaglebone-bcf
diff --git a/projects/beagleconnect/introduction.rst b/projects/beagleconnect/introduction.rst
new file mode 100644
index 0000000000000000000000000000000000000000..e38e84e009d1808c04172905f9e51b41dac53e05
--- /dev/null
+++ b/projects/beagleconnect/introduction.rst
@@ -0,0 +1,74 @@
+.. _beagleconnect-overview:
+
+Overview
+#########
+
+Greybus
+*******
+
+I will be taking information from the `Greybus LWN article <https://lwn.net/Articles/715955/>`_. So feel free to check it out.
+
+Greybus was initially designed for Google's Project Ara smartphone (which is discontinued now), but the first (and only) product released with it is Motorola's Moto Mods. It was initially merged for potential use by kernel components that need to communicate in a platform-independent way.
+
+The `Greybus specification <https://github.com/projectara/greybus-spec>`_ provides device discovery and description at runtime, network routing and housekeeping, and class and bridged PHY protocols, which devices use to talk to each other and to the processors. The following figure shows how various parts of the kernel interact with the Greybus subsystem.
+
+.. image:: images/greybus.webp
+   :align: center
+   :alt: Greybus subsystem
+
+
+There are three main entities in the Greybus network:
+
+#. **AP:** It refers to the host CPUs, i.e., CPUs running Linux in most cases. It is responsible for administrating the Greybus network via the SVC.
+#. **SVC:** The SVC represents an entity within the Greybus network that configures and controls the Greybus (UniPro) network, mostly based on the instructions from the AP. All module insertion and removal events are first reported to the SVC, which in turn informs the AP about them using the SVC protocol.
+#. **Module:** A module is the physical hardware entity that can be connected or disconnected statically (before powering the system on) or dynamically (while the system is running) from the Greybus network. Once the modules are connected to the Greybus network, the AP and the SVC enumerate the modules and fetch per-interface manifests to learn about their capabilities.
+
+While Greybus is a great protocol, the implementation is tightly coupled with the UniPro transport. This makes it challenging to use Greybus in other modes of transport.
+
+
+BeagleConnectâ„¢ Technology Mission
+**********************************
+
+BeagleConnectâ„¢ Technology aims to use Greybus outside of the traditional Greybus network. This includes using transports other than UniPro (such as 6lowpan), using embedded devices running `ZephyrRTOS <https://zephyrproject.org/>`_ as modules, emulating :term:`SVC <BeagleConnect SVC>` in co-processor, etc. This makes BeagleConnectâ„¢ much more flexible than what traditional greybus seems to support. Here is a diagram of the general BeagleConnectâ„¢ setup:
+
+.. image:: images/software_prop_transport.svg
+   :align: center
+   :alt: BeagleConnect Technology arbitrary transport
+
+The :term:`SVC <BeagleConnect SVC>` is either emulated in userspace software in the SOC (gbridge) or in a co-processor (e.g., in :ref:`BeaglePlay <beagleplay-home>`). The arbitrary transport can be anything from 6lowpan (for long range) to ethernet or optical cables (for max speed). Finally, greybus nodes such as BeagleConnectâ„¢ Freedom running Greybus Zephyr firmware allow the use of `mikroBUS <https://www.mikroe.com/mikrobus>`_ which opens a host of Plug and Play possibilities for peripherals.
+
+
+Why should you use BeagleConnectâ„¢?
+***********************************
+
+.. image:: images/SoftwareProp.jpg
+   :align: center
+   :alt: BeagleConnect Technology arbitrary transport
+
+#. **Open-source:** The `Greybus Spec <https://github.com/projectara/greybus-spec>`_ is open-source and a part of the Linux kernel. This makes it easy to use and personalize for your use case. Being part of the Linux Kernel also provides it a level of reliability that most similar solutions lack.
+
+#. **Network agnostic:** BeagleConnectâ„¢ allows Greybus to be network agnostic. This means it can be used over networks like 6lowpan, which has incredible wireless range, or over optical networks for high-throughput, low-latency use cases.
+
+#. **Rapid Prototyping:** Any device (e.g., `mikroBUS add-on boards <https://www.mikroe.com/click-boards>`_) connected to the greybus node can be accessed from the Linux host. In this setup, only the Linux host needs to have device drivers. We remove the need to write drivers for the OS our node (the device with which peripheral is actually connected) runs on (e.g. `ZephyrRTOS <https://www.zephyrproject.org>`_, `Nuttx <https://nuttx.apache.org>`_, etc). This allows being able to prototype devices by just creating a Linux driver instead of having to write drivers for each individual embedded OS.
+
+#. **Star topology IoT and IIoT networks:** Greybus was designed to be low level and allow hot-plugging of remote devices. This means a greybus network does not need to use bulky protocols like REST and data formats like JSON. This in turn allows using relatively low-powered device as nodes.
+
+#. **Use of Existing Infrastructure:** Since BeagleConnectâ„¢ devices show up as normal Linux devices, they work with existing local device management software. This eliminates need for propritory and custom solutions to monitor devices. Instead Linux host can directly read peripherals on nodes using standard Linux tools such as `iio_readdev <https://wiki.analog.com/resources/tools-software/linux-software/libiio/iio_readdev>`_.
+
+#. **Infinite Customization:** With support for `mikroBUS add-on boards <https://www.mikroe.com/click-boards>`_, capabilities of BeagleConnectâ„¢ nodes can be expanded dramaticically with little to no fiddling.
+
+.. note::
+
+    The above is just a glimpse of what BeagleConnectâ„¢ can do. Many more use cases can be explored. If you have any ideas, feel free to reach out to us.
+
+
+What's next?
+************
+
+BeagleConnectâ„¢ is still in its early stages. We are working on making it more robust and easy to use. We are trying to provide a complete experience for testing BeagleConnectâ„¢ Technology in our BeaglePlay and BeagleConnectâ„¢ boards.
+
+We are looking for more people to join us in improving BeagleConnectâ„¢ technology. Feel free to reach out to us at `Discord <https://discordapp.com/channels/1108795636956024986/1189277127590289469>`_ or `BeagleBoard Forum <https://forum.beagleboard.org/>`_.
+
+Contributions
+*************
+- `Greybus LWN article <https://lwn.net/Articles/715955/>`_
diff --git a/projects/index.rst b/projects/index.rst
index 1bb3de7abdbbf0a1163286eb2d6ae570864e13e1..b66c5cf116800bdb2b33b88928feaa1eccd5d250 100644
--- a/projects/index.rst
+++ b/projects/index.rst
@@ -6,7 +6,7 @@ Projects
 This is a collection of reasonably well-supported projects useful to Beagle developers.
 
 .. toctree::
-   :maxdepth: 1
+   :maxdepth: 2
 
    /projects/simppru/index
    /projects/bb-config/index