summaryrefslogtreecommitdiff
path: root/recipes-connectivity/lora/lora-basic-station-sx1303
diff options
context:
space:
mode:
Diffstat (limited to 'recipes-connectivity/lora/lora-basic-station-sx1303')
-rw-r--r--recipes-connectivity/lora/lora-basic-station-sx1303/lora-basic-station.default2
-rwxr-xr-xrecipes-connectivity/lora/lora-basic-station-sx1303/lora-basic-station.init158
-rw-r--r--recipes-connectivity/lora/lora-basic-station-sx1303/mtcap3-station.conf.E0047
-rw-r--r--recipes-connectivity/lora/lora-basic-station-sx1303/mtcap3-station.conf.U0047
-rw-r--r--recipes-connectivity/lora/lora-basic-station-sx1303/mtcdt-station.conf.E0047
-rw-r--r--recipes-connectivity/lora/lora-basic-station-sx1303/mtcdt-station.conf.U0047
-rw-r--r--recipes-connectivity/lora/lora-basic-station-sx1303/setup.gmk91
-rw-r--r--recipes-connectivity/lora/lora-basic-station-sx1303/tc.uri1
8 files changed, 440 insertions, 0 deletions
diff --git a/recipes-connectivity/lora/lora-basic-station-sx1303/lora-basic-station.default b/recipes-connectivity/lora/lora-basic-station-sx1303/lora-basic-station.default
new file mode 100644
index 0000000..0f92640
--- /dev/null
+++ b/recipes-connectivity/lora/lora-basic-station-sx1303/lora-basic-station.default
@@ -0,0 +1,2 @@
+# set to "yes" or "no" to control starting on boot
+ENABLED="no"
diff --git a/recipes-connectivity/lora/lora-basic-station-sx1303/lora-basic-station.init b/recipes-connectivity/lora/lora-basic-station-sx1303/lora-basic-station.init
new file mode 100755
index 0000000..7ebeea2
--- /dev/null
+++ b/recipes-connectivity/lora/lora-basic-station-sx1303/lora-basic-station.init
@@ -0,0 +1,158 @@
+#!/bin/bash
+
+
+NAME="lora-basic-station"
+ENABLED="yes"
+
+
+[ -f /etc/default/$NAME ] && source /etc/default/$NAME
+
+run_dir=/var/run/lora
+opt_conf_dir=/opt/lora
+conf_dir=/var/config/lora
+conf_file=$conf_dir/station.conf
+tc_uri_file=$conf_dir/tc.uri
+tc_key_file=$conf_dir/tc.key
+tc_trust_file=$conf_dir/tc.trust
+
+pkt_fwd=$run_dir/1/station
+pkt_fwd_pidfile=$run_dir/station.pid
+
+port1=/sys/devices/platform/mts-io/ap1
+port2=/sys/devices/platform/mts-io/ap2
+
+lora_mtac_id="MTAC-LORA"
+lora_1_0_hw="MTAC-LORA-1.0"
+lora_1_5_h_hw="MTAC-LORA-1.5"
+lora_2_1_hw="MTAC-LORA-2.1"
+
+lora_mtac_id="MTAC-LORA"
+lora_mtac_id915="MTAC-LORA-915"
+lora_mtac_id868="MTAC-LORA-868"
+lora_mtac_h_id915="MTAC-LORA-H-915"
+lora_mtac_h_id868="MTAC-LORA-H-868"
+
+lora_mtcap_id="MTCAP-LORA"
+lora_mtcap_id868="MTCAP-LORA-868"
+lora_mtcap_id915="MTCAP-LORA-915"
+
+lora_mtac_g_id="MTAC-LORA-G"
+lora_mtac_g16_id868="MTAC-LORA-G16-868"
+lora_mtac_g16_id915="MTAC-LORA-G16-915"
+lora_mtac_g64_id868="MTAC-LORA-G64-868"
+lora_mtac_g64_id915="MTAC-LORA-G64-915"
+
+pkt_fwd_options=""
+
+gps_path="/dev/gps0"
+
+read_lora_hw_info() {
+ lora_id=$(mts-io-sysfs show lora/product-id 2> /dev/null)
+ lora_hw=$(mts-io-sysfs show lora/hw-version 2> /dev/null)
+ lora_eui=$(mts-io-sysfs show lora/eui 2> /dev/null)
+ lora_eui_raw=${lora_eui//:/}
+}
+
+hardware_found() {
+ if [[ "$lora_id" =~ "$lora_mtac_g_id" ]]; then
+ setup_mtcdt_2_1
+ elif [[ "$lora_id" =~ "$lora_mtcap_id" ]]; then
+ setup_mtcap
+ elif [[ "$lora_id" =~ "$lora_mtac_id" ]]; then
+ setup_mtcdt
+ else
+ return 1
+ fi
+ return 0
+}
+
+setup_mtcdt() {
+ ln -sf /opt/lora/station $pkt_fwd
+}
+
+setup_mtcap() {
+ ln -sf /opt/lora/station $pkt_fwd
+}
+
+setup_mtcdt_2_1() {
+ echo LORA-2.1 not supported
+ return 1
+}
+
+do_start() {
+
+ mkdir -p $run_dir/1
+ rm -rf $run_dir/1/*
+
+ read_lora_hw_info
+
+ if hardware_found; then
+ echo "Found $lora_id with $lora_hw hardware. Configuring"
+ else
+ echo "$0: LORA card not detected"
+ exit 1
+ fi
+
+ if ! [ -f $conf_file ]; then
+ echo "$0: $conf_file missing"
+ exit 1
+ fi
+
+ #
+ # copy conf files to the run directory
+ #
+ cp $conf_file $run_dir/1/
+ cp $tc_uri_file $run_dir/1/
+ cp $tc_key_file $run_dir/1/
+ cp $tc_trust_file $run_dir/1/
+
+ sed -i.bak "s/\(.*routerid\"\s*\:\s*\"\)<.*>[^\"]*\(.*\)/\1${lora_eui_raw}\2/g" /var/run/lora/1/station.conf
+
+ #
+ # start packet forwarder
+ #
+ echo -n "Starting $NAME: "
+
+ /usr/sbin/start-stop-daemon --chdir $run_dir/1 --background --start --make-pidfile \
+ --pidfile $pkt_fwd_pidfile --startas /bin/bash -- -c "exec $pkt_fwd $pkt_fwd_options"
+
+ renice -n -20 -p $(pgrep $(basename $pkt_fwd))
+
+ echo "OK"
+}
+
+
+do_stop() {
+ echo -n "Stopping $NAME: "
+ start-stop-daemon --stop --quiet --oknodo --pidfile $pkt_fwd_pidfile --retry 5
+ rm -f $pkt_fwd_pidfile
+ echo "OK"
+}
+
+
+if [ "$ENABLED" != "yes" ]; then
+ echo "$NAME: disabled in /etc/default"
+ exit
+fi
+
+
+case "$1" in
+ "start")
+ do_start
+ ;;
+ "stop")
+ do_stop
+ ;;
+ "restart")
+ ## Stop the service and regardless of whether it was
+ ## running or not, start it again.
+ do_stop
+ do_start
+ ;;
+ *)
+ ## If no parameters are given, print which are avaiable.
+ echo "Usage: $0 {start|stop|restart}"
+ exit 1
+ ;;
+esac
+
diff --git a/recipes-connectivity/lora/lora-basic-station-sx1303/mtcap3-station.conf.E00 b/recipes-connectivity/lora/lora-basic-station-sx1303/mtcap3-station.conf.E00
new file mode 100644
index 0000000..95da968
--- /dev/null
+++ b/recipes-connectivity/lora/lora-basic-station-sx1303/mtcap3-station.conf.E00
@@ -0,0 +1,47 @@
+{
+ "SX1301_conf": {
+ "chan_FSK": {"bandwidth": 125000,"datarate": 50000,"enable": true,"if": 300000,"radio": 0},
+ "chan_Lora_std": {"bandwidth": 250000,"enable": true,"if": -200000,"radio": 0,"spread_factor": 7},
+ "chan_multiSF_0": {"enable": true,"if": -400000,"radio": 0},
+ "chan_multiSF_1": {"enable": true,"if": -200000,"radio": 0},
+ "chan_multiSF_2": {"enable": true,"if": 0,"radio": 0},
+ "chan_multiSF_3": {"enable": true,"if": -400000,"radio": 1},
+ "chan_multiSF_4": {"enable": true,"if": -200000,"radio": 1},
+ "chan_multiSF_5": {"enable": true,"if": 0,"radio": 1},
+ "chan_multiSF_6": {"enable": true,"if": 200000,"radio": 1},
+ "chan_multiSF_7": {"enable": true,"if": 400000,"radio": 1},
+ "clksrc": 0,
+ "device": "/dev/spidev0.0",
+ "lorawan_public": true,
+ "pps": true,
+ "radio_0": {"enable": true,"freq": 868500000,"rssi_offset": -214.5,"tx_enable": true,"type": "SX1250"},
+ "radio_1": {"enable": true,"freq": 867500000,"rssi_offset": -214.5,"tx_enable": false,"type": "SX1250"},
+ "tx_gain_lut":[
+ {"rf_power": 10, "pa_gain": 0, "pwr_idx": 12},
+ {"rf_power": 11, "pa_gain": 0, "pwr_idx": 13},
+ {"rf_power": 12, "pa_gain": 0, "pwr_idx": 14},
+ {"rf_power": 13, "pa_gain": 0, "pwr_idx": 15},
+ {"rf_power": 14, "pa_gain": 0, "pwr_idx": 16},
+ {"rf_power": 16, "pa_gain": 0, "pwr_idx": 17},
+ {"rf_power": 17, "pa_gain": 1, "pwr_idx": 0},
+ {"rf_power": 18, "pa_gain": 1, "pwr_idx": 1},
+ {"rf_power": 19, "pa_gain": 1, "pwr_idx": 2},
+ {"rf_power": 21, "pa_gain": 1, "pwr_idx": 4},
+ {"rf_power": 22, "pa_gain": 1, "pwr_idx": 5},
+ {"rf_power": 23, "pa_gain": 1, "pwr_idx": 6},
+ {"rf_power": 24, "pa_gain": 1, "pwr_idx": 7},
+ {"rf_power": 25, "pa_gain": 1, "pwr_idx": 8},
+ {"rf_power": 26, "pa_gain": 1, "pwr_idx": 11},
+ {"rf_power": 27, "pa_gain": 1, "pwr_idx": 14}
+ ]
+ },
+ "station_conf": {
+ "TC_TIMEOUT": "2s",
+ "euiprefix": "::0",
+ "log_file": "stderr",
+ "log_level": "INFO",
+ "log_rotate": 3,
+ "log_size": 100000,
+ "routerid": "<WILL-BE-AUTO-REPLACED-WITH-LORA-EUI>"
+ }
+}
diff --git a/recipes-connectivity/lora/lora-basic-station-sx1303/mtcap3-station.conf.U00 b/recipes-connectivity/lora/lora-basic-station-sx1303/mtcap3-station.conf.U00
new file mode 100644
index 0000000..a97fdc0
--- /dev/null
+++ b/recipes-connectivity/lora/lora-basic-station-sx1303/mtcap3-station.conf.U00
@@ -0,0 +1,47 @@
+{
+ "SX1301_conf": {
+ "chan_FSK": {"bandwidth": 125000,"datarate": 50000,"enable": false,"if": 300000,"radio": 0},
+ "chan_Lora_std": {"bandwidth": 500000,"enable": true,"if": 300000,"radio": 0,"spread_factor": 8},
+ "chan_multiSF_0": {"enable": true,"if": -400000,"radio": 0},
+ "chan_multiSF_1": {"enable": true,"if": -200000,"radio": 0},
+ "chan_multiSF_2": {"enable": true,"if": 0,"radio": 0},
+ "chan_multiSF_3": {"enable": true,"if": 200000,"radio": 0},
+ "chan_multiSF_4": {"enable": true,"if": -400000,"radio": 1},
+ "chan_multiSF_5": {"enable": true,"if": -200000,"radio": 1},
+ "chan_multiSF_6": {"enable": true,"if": 0,"radio": 1},
+ "chan_multiSF_7": {"enable": true,"if": 200000,"radio": 1},
+ "clksrc": 0,
+ "device": "/dev/spidev0.0",
+ "lorawan_public": true,
+ "pps": true,
+ "radio_0": {"enable": true,"freq": 902700000,"rssi_offset": -214.5,"tx_enable": true,"type": "SX1250"},
+ "radio_1": {"enable": true,"freq": 903500000,"rssi_offset": -214.5,"tx_enable": false,"type": "SX1250"},
+ "tx_gain_lut":[
+ {"rf_power": 11, "pa_gain": 0, "pwr_idx": 14},
+ {"rf_power": 12, "pa_gain": 0, "pwr_idx": 15},
+ {"rf_power": 13, "pa_gain": 0, "pwr_idx": 16},
+ {"rf_power": 15, "pa_gain": 0, "pwr_idx": 17},
+ {"rf_power": 16, "pa_gain": 0, "pwr_idx": 18},
+ {"rf_power": 17, "pa_gain": 0, "pwr_idx": 19},
+ {"rf_power": 18, "pa_gain": 0, "pwr_idx": 20},
+ {"rf_power": 19, "pa_gain": 1, "pwr_idx": 3},
+ {"rf_power": 20, "pa_gain": 1, "pwr_idx": 4},
+ {"rf_power": 21, "pa_gain": 1, "pwr_idx": 5},
+ {"rf_power": 22, "pa_gain": 1, "pwr_idx": 6},
+ {"rf_power": 23, "pa_gain": 1, "pwr_idx": 7},
+ {"rf_power": 24, "pa_gain": 1, "pwr_idx": 8},
+ {"rf_power": 25, "pa_gain": 1, "pwr_idx": 10},
+ {"rf_power": 26, "pa_gain": 1, "pwr_idx": 12},
+ {"rf_power": 27, "pa_gain": 1, "pwr_idx": 15}
+ ]
+ },
+ "station_conf": {
+ "TC_TIMEOUT": "2s",
+ "euiprefix": "::0",
+ "log_file": "stderr",
+ "log_level": "INFO",
+ "log_rotate": 3,
+ "log_size": 100000,
+ "routerid": "<WILL-BE-AUTO-REPLACED-WITH-LORA-EUI>"
+ }
+}
diff --git a/recipes-connectivity/lora/lora-basic-station-sx1303/mtcdt-station.conf.E00 b/recipes-connectivity/lora/lora-basic-station-sx1303/mtcdt-station.conf.E00
new file mode 100644
index 0000000..95da968
--- /dev/null
+++ b/recipes-connectivity/lora/lora-basic-station-sx1303/mtcdt-station.conf.E00
@@ -0,0 +1,47 @@
+{
+ "SX1301_conf": {
+ "chan_FSK": {"bandwidth": 125000,"datarate": 50000,"enable": true,"if": 300000,"radio": 0},
+ "chan_Lora_std": {"bandwidth": 250000,"enable": true,"if": -200000,"radio": 0,"spread_factor": 7},
+ "chan_multiSF_0": {"enable": true,"if": -400000,"radio": 0},
+ "chan_multiSF_1": {"enable": true,"if": -200000,"radio": 0},
+ "chan_multiSF_2": {"enable": true,"if": 0,"radio": 0},
+ "chan_multiSF_3": {"enable": true,"if": -400000,"radio": 1},
+ "chan_multiSF_4": {"enable": true,"if": -200000,"radio": 1},
+ "chan_multiSF_5": {"enable": true,"if": 0,"radio": 1},
+ "chan_multiSF_6": {"enable": true,"if": 200000,"radio": 1},
+ "chan_multiSF_7": {"enable": true,"if": 400000,"radio": 1},
+ "clksrc": 0,
+ "device": "/dev/spidev0.0",
+ "lorawan_public": true,
+ "pps": true,
+ "radio_0": {"enable": true,"freq": 868500000,"rssi_offset": -214.5,"tx_enable": true,"type": "SX1250"},
+ "radio_1": {"enable": true,"freq": 867500000,"rssi_offset": -214.5,"tx_enable": false,"type": "SX1250"},
+ "tx_gain_lut":[
+ {"rf_power": 10, "pa_gain": 0, "pwr_idx": 12},
+ {"rf_power": 11, "pa_gain": 0, "pwr_idx": 13},
+ {"rf_power": 12, "pa_gain": 0, "pwr_idx": 14},
+ {"rf_power": 13, "pa_gain": 0, "pwr_idx": 15},
+ {"rf_power": 14, "pa_gain": 0, "pwr_idx": 16},
+ {"rf_power": 16, "pa_gain": 0, "pwr_idx": 17},
+ {"rf_power": 17, "pa_gain": 1, "pwr_idx": 0},
+ {"rf_power": 18, "pa_gain": 1, "pwr_idx": 1},
+ {"rf_power": 19, "pa_gain": 1, "pwr_idx": 2},
+ {"rf_power": 21, "pa_gain": 1, "pwr_idx": 4},
+ {"rf_power": 22, "pa_gain": 1, "pwr_idx": 5},
+ {"rf_power": 23, "pa_gain": 1, "pwr_idx": 6},
+ {"rf_power": 24, "pa_gain": 1, "pwr_idx": 7},
+ {"rf_power": 25, "pa_gain": 1, "pwr_idx": 8},
+ {"rf_power": 26, "pa_gain": 1, "pwr_idx": 11},
+ {"rf_power": 27, "pa_gain": 1, "pwr_idx": 14}
+ ]
+ },
+ "station_conf": {
+ "TC_TIMEOUT": "2s",
+ "euiprefix": "::0",
+ "log_file": "stderr",
+ "log_level": "INFO",
+ "log_rotate": 3,
+ "log_size": 100000,
+ "routerid": "<WILL-BE-AUTO-REPLACED-WITH-LORA-EUI>"
+ }
+}
diff --git a/recipes-connectivity/lora/lora-basic-station-sx1303/mtcdt-station.conf.U00 b/recipes-connectivity/lora/lora-basic-station-sx1303/mtcdt-station.conf.U00
new file mode 100644
index 0000000..a97fdc0
--- /dev/null
+++ b/recipes-connectivity/lora/lora-basic-station-sx1303/mtcdt-station.conf.U00
@@ -0,0 +1,47 @@
+{
+ "SX1301_conf": {
+ "chan_FSK": {"bandwidth": 125000,"datarate": 50000,"enable": false,"if": 300000,"radio": 0},
+ "chan_Lora_std": {"bandwidth": 500000,"enable": true,"if": 300000,"radio": 0,"spread_factor": 8},
+ "chan_multiSF_0": {"enable": true,"if": -400000,"radio": 0},
+ "chan_multiSF_1": {"enable": true,"if": -200000,"radio": 0},
+ "chan_multiSF_2": {"enable": true,"if": 0,"radio": 0},
+ "chan_multiSF_3": {"enable": true,"if": 200000,"radio": 0},
+ "chan_multiSF_4": {"enable": true,"if": -400000,"radio": 1},
+ "chan_multiSF_5": {"enable": true,"if": -200000,"radio": 1},
+ "chan_multiSF_6": {"enable": true,"if": 0,"radio": 1},
+ "chan_multiSF_7": {"enable": true,"if": 200000,"radio": 1},
+ "clksrc": 0,
+ "device": "/dev/spidev0.0",
+ "lorawan_public": true,
+ "pps": true,
+ "radio_0": {"enable": true,"freq": 902700000,"rssi_offset": -214.5,"tx_enable": true,"type": "SX1250"},
+ "radio_1": {"enable": true,"freq": 903500000,"rssi_offset": -214.5,"tx_enable": false,"type": "SX1250"},
+ "tx_gain_lut":[
+ {"rf_power": 11, "pa_gain": 0, "pwr_idx": 14},
+ {"rf_power": 12, "pa_gain": 0, "pwr_idx": 15},
+ {"rf_power": 13, "pa_gain": 0, "pwr_idx": 16},
+ {"rf_power": 15, "pa_gain": 0, "pwr_idx": 17},
+ {"rf_power": 16, "pa_gain": 0, "pwr_idx": 18},
+ {"rf_power": 17, "pa_gain": 0, "pwr_idx": 19},
+ {"rf_power": 18, "pa_gain": 0, "pwr_idx": 20},
+ {"rf_power": 19, "pa_gain": 1, "pwr_idx": 3},
+ {"rf_power": 20, "pa_gain": 1, "pwr_idx": 4},
+ {"rf_power": 21, "pa_gain": 1, "pwr_idx": 5},
+ {"rf_power": 22, "pa_gain": 1, "pwr_idx": 6},
+ {"rf_power": 23, "pa_gain": 1, "pwr_idx": 7},
+ {"rf_power": 24, "pa_gain": 1, "pwr_idx": 8},
+ {"rf_power": 25, "pa_gain": 1, "pwr_idx": 10},
+ {"rf_power": 26, "pa_gain": 1, "pwr_idx": 12},
+ {"rf_power": 27, "pa_gain": 1, "pwr_idx": 15}
+ ]
+ },
+ "station_conf": {
+ "TC_TIMEOUT": "2s",
+ "euiprefix": "::0",
+ "log_file": "stderr",
+ "log_level": "INFO",
+ "log_rotate": 3,
+ "log_size": 100000,
+ "routerid": "<WILL-BE-AUTO-REPLACED-WITH-LORA-EUI>"
+ }
+}
diff --git a/recipes-connectivity/lora/lora-basic-station-sx1303/setup.gmk b/recipes-connectivity/lora/lora-basic-station-sx1303/setup.gmk
new file mode 100644
index 0000000..72450ee
--- /dev/null
+++ b/recipes-connectivity/lora/lora-basic-station-sx1303/setup.gmk
@@ -0,0 +1,91 @@
+# -*- makefile -*-
+
+# Top dir of s2core
+# - override accordingly in makefile including this setup.gmk
+
+platform ?= mlinux
+variant ?= sx1303
+
+
+ARCH ?=
+CROSS_COMPILE ?=
+export
+
+# TOOLPREFIX=${CROSS_COMPILE}
+
+
+BD=build-${platform}-${variant}
+
+# -- Architecture specific
+CFG.arm-linux-gnueabihf = mlinux
+# CFG.x86_64-linux-gnu = linux
+
+# -- Variant specific
+# testsim runs libloragw inside master process
+# testms uses a master slave model
+#CFG.testsim = logini_lvl=DEBUG selftests tlsdebug lgwsim ral_lgw
+#CFG.testms = logini_lvl=DEBUG selftests tlsdebug lgwsim ral_master_slave
+#CFG.testfs = logini_lvl=DEBUG selftests tlsdebug lgwsim ral_lgw
+#CFG.testpin = logini_lvl=INFO tlsdebug ral_lgw testpin
+#CFG.std = logini_lvl=INFO tlsdebug ral_lgw
+#CFG.stdn = logini_lvl=INFO tlsdebug ral_master_slave
+#CFG.debug = logini_lvl=DEBUG selftests tlsdebug ral_lgw
+#CFG.debugn = logini_lvl=DEBUG selftests tlsdebug ral_master_slave
+
+# -- Platform specific
+CFG.linux = linux lgw1 no_leds
+CFG.rpi = linux lgw1 no_leds
+CFG.kerlink = linux lgw1 no_leds
+CFG.mlinux = linux no_leds ral_lgw prod sx1302 lgw1 usegpsd
+
+SD.default = src-linux
+
+SD = $(or ${SD.${platform}}, ${SD.default})
+
+UTILS.linux = mtuns
+
+UTILS = $(or ${UTILS.${platform}}, ${UTILS.default})
+
+PERSO.default =
+PERSO = $(or ${PERSO.${platform}}, ${PERSO.default})
+PERSOH = $(if ${PERSO},perso.h,)
+
+# Paths to dependencies
+MBEDLIBS = -lmbedtls -lmbedx509 -lmbedcrypto
+
+# -lm: Needed for lgw which uses pow/ceil
+ifneq (minihub,$(platform))
+SYSLIBS = -lm
+endif
+
+CFLAGS.linux.testsim = -g -O0 --coverage
+CFLAGS.linux.testms = -g -O0 --coverage
+CFLAGS.linux.testfs = -g -O0 --coverage
+CFLAGS.linux.testpin = -g -O3
+CFLAGS.linux.std = -g -O3
+CFLAGS.mlinux.std = -g -O3
+
+LIBS.mlinux = -lloragw ${MBEDLIBS} -lrt -lm -lpthread -lgps
+LIBS.linux = -llgw ${MBEDLIBS} -lpthread
+LIBS.rpi = -llgw ${MBEDLIBS} -lpthread
+LIBS.kerlink = -llgw ${MBEDLIBS} -lrt -lpthread
+
+xCFG = ${CFG.${ARCH}} ${CFG.${platform}} ${CFG.${variant}} ${CFG.${platform}.${variant}}
+xCFLAGS = ${CFLAGS.${ARCH}} ${CFLAGS.${platform}} ${CFLAGS.${variant}} ${CFLAGS.${platform}.${variant}}
+xINCS = ${INCS.${ARCH}} ${INCS.${platform}} ${INCS.${variant}}
+xLDFLAGS = ${LDFLAGS.${ARCH}} ${LDFLAGS.${platform}} ${LDFLAGS.${variant}}
+xLIBS = ${LIBS.${ARCH}} ${LIBS.${platform}} ${LIBS.${variant}}
+xFILES = ${FILES.${ARCH}} ${FILES.${platform}} ${FILES.${variant}}
+xOCFLAGS = ${OCFLAGS.${ARCH}} ${OCFLAGS.${platform}} ${OCFLAGS.${variant}}
+
+DEFS = -DCFG_platform_${platform} -DCFG_platform=\"${platform}\" -DCFG_variant_${variant} -DCFG_variant=\"${variant}\"
+DEFS += -DCFG_bdate='"$(shell date -u '+%Y-%m-%d %H:%M:%S')"'
+DEFS += -DCFG_version='"$(shell if [ -f ${TD}/VERSION.txt ]; then cat ${TD}/VERSION.txt; else git describe --tag; fi)(${platform}/${variant})"'
+DEFS += -DCFG_commit='"$(shell if git rev-parse --git-dir >/dev/null 2>&1; then git rev-parse --short HEAD; else echo -; fi)"'
+DEFS += ${xCFG:%=-DCFG_%}
+INCS = ${VPATH:%=-I%} -I ${TD}/${BD}/include ${xINCS}
+CFLAGS += -std=gnu11 ${INCS} ${DEFS} ${xCFLAGS} ${MORECFLAGS}
+LDFLAGS += -L ${TD}/${BD}/lib ${xLDFLAGS}
+LIBS = ${xLIBS} ${SYSLIBS}
+FILES = ${xFILES}
+OCFLAGS = ${xOCFLAGS}
diff --git a/recipes-connectivity/lora/lora-basic-station-sx1303/tc.uri b/recipes-connectivity/lora/lora-basic-station-sx1303/tc.uri
new file mode 100644
index 0000000..62ad13e
--- /dev/null
+++ b/recipes-connectivity/lora/lora-basic-station-sx1303/tc.uri
@@ -0,0 +1 @@
+wss://127.0.0.1:9002