From 311abdd88f5e10ea74f289ec3e82f2b2e054b63e Mon Sep 17 00:00:00 2001 From: Ing-Dom Date: Mon, 25 Dec 2023 16:34:40 +0100 Subject: [PATCH] redesigned the activitycallback without using the facade and with a more flexible approach. For performace reasons, the calls in the actual link layer is only activated when KNX_ACTIVITYCALLBACK is defined. There is now a DataLinkLayerCallback class where a specific Bau *can* inherit from and - if the specific link layer supports it, pass itself to that linklayer(s). --- src/knx/bau07B0.cpp | 17 ++++++++++++++++- src/knx/bau07B0.h | 2 +- src/knx/bau091A.cpp | 5 +++-- src/knx/bau091A.h | 2 +- src/knx/bau57B0.cpp | 3 ++- src/knx/bau57B0.h | 2 +- src/knx/data_link_layer.cpp | 12 ++++++++++++ src/knx/data_link_layer.h | 12 ++++++++++++ src/knx/ip_data_link_layer.cpp | 11 +++++++---- src/knx/ip_data_link_layer.h | 3 ++- src/knx/tpuart_data_link_layer.cpp | 13 ++++++++----- src/knx/tpuart_data_link_layer.h | 7 ++++++- 12 files changed, 71 insertions(+), 18 deletions(-) diff --git a/src/knx/bau07B0.cpp b/src/knx/bau07B0.cpp index ccd9b62a..92fe6658 100644 --- a/src/knx/bau07B0.cpp +++ b/src/knx/bau07B0.cpp @@ -10,7 +10,8 @@ using namespace std; Bau07B0::Bau07B0(Platform& platform) : BauSystemBDevice(platform), - _dlLayer(_deviceObj, _netLayer.getInterface(), _platform, (ITpUartCallBacks&) *this) + _dlLayer(_deviceObj, _netLayer.getInterface(), _platform, (ITpUartCallBacks&) *this, (DataLinkLayerCallbacks*) this), + DataLinkLayerCallbacks() #ifdef USE_CEMI_SERVER , _cemiServer(*this) #endif @@ -150,4 +151,18 @@ bool Bau07B0::isAckRequired(uint16_t address, bool isGrpAddr) return false; } +// /// @brief sets the Callback Function indicating sent or received telegrams +// /// @param activityCallback +// /// @details the info parameter +// void Bau07B0::setActivityCallback(ActivityCallback activityCallback) +// { +// _activityCallback = activityCallback; +// } + +// void Bau07B0::Activity(uint8_t info) +// { +// if(_activityCallback) +// _activityCallback(info); +// } + #endif diff --git a/src/knx/bau07B0.h b/src/knx/bau07B0.h index 3b29d720..b9c1e6c0 100644 --- a/src/knx/bau07B0.h +++ b/src/knx/bau07B0.h @@ -8,7 +8,7 @@ #include "cemi_server.h" #include "cemi_server_object.h" -class Bau07B0 : public BauSystemBDevice, public ITpUartCallBacks +class Bau07B0 : public BauSystemBDevice, public ITpUartCallBacks, public DataLinkLayerCallbacks { public: Bau07B0(Platform& platform); diff --git a/src/knx/bau091A.cpp b/src/knx/bau091A.cpp index 9774952e..2465bc42 100644 --- a/src/knx/bau091A.cpp +++ b/src/knx/bau091A.cpp @@ -12,8 +12,9 @@ Bau091A::Bau091A(Platform& platform) : BauSystemBCoupler(platform), _routerObj(memory()), _ipParameters(_deviceObj, platform), - _dlLayerPrimary(_deviceObj, _ipParameters, _netLayer.getPrimaryInterface(), _platform), - _dlLayerSecondary(_deviceObj, _netLayer.getSecondaryInterface(), platform, (ITpUartCallBacks&) *this) + _dlLayerPrimary(_deviceObj, _ipParameters, _netLayer.getPrimaryInterface(), _platform, (DataLinkLayerCallbacks*) this), + _dlLayerSecondary(_deviceObj, _netLayer.getSecondaryInterface(), platform, (ITpUartCallBacks&) *this, (DataLinkLayerCallbacks*) this), + DataLinkLayerCallbacks() #ifdef USE_CEMI_SERVER , _cemiServer(*this) diff --git a/src/knx/bau091A.h b/src/knx/bau091A.h index 7c9b8e5f..606fbda0 100644 --- a/src/knx/bau091A.h +++ b/src/knx/bau091A.h @@ -10,7 +10,7 @@ #include "tpuart_data_link_layer.h" #include "cemi_server_object.h" -class Bau091A : public BauSystemBCoupler, public ITpUartCallBacks +class Bau091A : public BauSystemBCoupler, public ITpUartCallBacks, public DataLinkLayerCallbacks { public: Bau091A(Platform& platform); diff --git a/src/knx/bau57B0.cpp b/src/knx/bau57B0.cpp index c9b3827b..75522aa1 100644 --- a/src/knx/bau57B0.cpp +++ b/src/knx/bau57B0.cpp @@ -11,7 +11,8 @@ using namespace std; Bau57B0::Bau57B0(Platform& platform) : BauSystemBDevice(platform), _ipParameters(_deviceObj, platform), - _dlLayer(_deviceObj, _ipParameters, _netLayer.getInterface(), _platform) + _dlLayer(_deviceObj, _ipParameters, _netLayer.getInterface(), _platform, (DataLinkLayerCallbacks*) this), + DataLinkLayerCallbacks() #ifdef USE_CEMI_SERVER , _cemiServer(*this) diff --git a/src/knx/bau57B0.h b/src/knx/bau57B0.h index a381ebb4..f6309f93 100644 --- a/src/knx/bau57B0.h +++ b/src/knx/bau57B0.h @@ -8,7 +8,7 @@ #include "ip_data_link_layer.h" #include "cemi_server_object.h" -class Bau57B0 : public BauSystemBDevice +class Bau57B0 : public BauSystemBDevice, public DataLinkLayerCallbacks { public: Bau57B0(Platform& platform); diff --git a/src/knx/data_link_layer.cpp b/src/knx/data_link_layer.cpp index e2f601e2..8de99f8c 100644 --- a/src/knx/data_link_layer.cpp +++ b/src/knx/data_link_layer.cpp @@ -6,6 +6,18 @@ #include "cemi_server.h" #include "cemi_frame.h" + +void DataLinkLayerCallbacks::Activity(uint8_t info) +{ + if(_activityCallback) + _activityCallback(info); +} + +void DataLinkLayerCallbacks::setActivityCallback(ActivityCallback activityCallback) +{ + _activityCallback = activityCallback; +} + DataLinkLayer::DataLinkLayer(DeviceObject& devObj, NetworkLayerEntity& netLayerEntity, Platform& platform) : _deviceObject(devObj), _networkLayerEntity(netLayerEntity), _platform(platform) { diff --git a/src/knx/data_link_layer.h b/src/knx/data_link_layer.h index 0270d31f..fe0d4749 100644 --- a/src/knx/data_link_layer.h +++ b/src/knx/data_link_layer.h @@ -10,6 +10,18 @@ class Platform; +typedef void (*ActivityCallback)(uint8_t info); + +class DataLinkLayerCallbacks +{ +protected: + ActivityCallback _activityCallback = nullptr; +public: + virtual ~DataLinkLayerCallbacks() = default; + virtual void Activity(uint8_t info); + virtual void setActivityCallback(ActivityCallback activityCallback); +}; + class DataLinkLayer { public: diff --git a/src/knx/ip_data_link_layer.cpp b/src/knx/ip_data_link_layer.cpp index b18f4d2a..aad2c149 100644 --- a/src/knx/ip_data_link_layer.cpp +++ b/src/knx/ip_data_link_layer.cpp @@ -19,7 +19,7 @@ #define MIN_LEN_CEMI 10 IpDataLinkLayer::IpDataLinkLayer(DeviceObject& devObj, IpParameterObject& ipParam, - NetworkLayerEntity &netLayerEntity, Platform& platform) : DataLinkLayer(devObj, netLayerEntity, platform), _ipParameters(ipParam) + NetworkLayerEntity &netLayerEntity, Platform& platform, DataLinkLayerCallbacks* dllcb) : DataLinkLayer(devObj, netLayerEntity, platform), _ipParameters(ipParam), _dllcb(dllcb) { } @@ -31,7 +31,8 @@ bool IpDataLinkLayer::sendFrame(CemiFrame& frame) return false; bool success = sendBytes(packet.data(), packet.totalLength()); #ifdef KNX_ACTIVITYCALLBACK - knx.Activity((_netIndex << KNX_ACTIVITYCALLBACK_NET) | (KNX_ACTIVITYCALLBACK_DIR_SEND << KNX_ACTIVITYCALLBACK_DIR)); + if(_dllcb) + _dllcb->Activity((_netIndex << KNX_ACTIVITYCALLBACK_NET) | (KNX_ACTIVITYCALLBACK_DIR_SEND << KNX_ACTIVITYCALLBACK_DIR)); #endif dataConReceived(frame, success); return success; @@ -55,7 +56,8 @@ void IpDataLinkLayer::loop() return; #ifdef KNX_ACTIVITYCALLBACK - knx.Activity((_netIndex << KNX_ACTIVITYCALLBACK_NET) | (KNX_ACTIVITYCALLBACK_DIR_RECV << KNX_ACTIVITYCALLBACK_DIR)); + if(_dllcb) + _dllcb->Activity((_netIndex << KNX_ACTIVITYCALLBACK_NET) | (KNX_ACTIVITYCALLBACK_DIR_RECV << KNX_ACTIVITYCALLBACK_DIR)); #endif uint16_t code; @@ -75,7 +77,8 @@ void IpDataLinkLayer::loop() auto hpai = searchRequest.hpai(); #ifdef KNX_ACTIVITYCALLBACK - knx.Activity((_netIndex << KNX_ACTIVITYCALLBACK_NET) | (KNX_ACTIVITYCALLBACK_DIR_SEND << KNX_ACTIVITYCALLBACK_DIR) | (KNX_ACTIVITYCALLBACK_IPUNICAST)); + if(_dllcb) + _dllcb->Activity((_netIndex << KNX_ACTIVITYCALLBACK_NET) | (KNX_ACTIVITYCALLBACK_DIR_SEND << KNX_ACTIVITYCALLBACK_DIR) | (KNX_ACTIVITYCALLBACK_IPUNICAST)); #endif _platform.sendBytesUniCast(hpai.ipAddress(), hpai.ipPortNumber(), searchResponse.data(), searchResponse.totalLength()); break; diff --git a/src/knx/ip_data_link_layer.h b/src/knx/ip_data_link_layer.h index 5f2d9962..5402a936 100644 --- a/src/knx/ip_data_link_layer.h +++ b/src/knx/ip_data_link_layer.h @@ -13,7 +13,7 @@ class IpDataLinkLayer : public DataLinkLayer public: IpDataLinkLayer(DeviceObject& devObj, IpParameterObject& ipParam, NetworkLayerEntity& netLayerEntity, - Platform& platform); + Platform& platform, DataLinkLayerCallbacks* dllcb = nullptr); void loop(); void enabled(bool value); @@ -30,5 +30,6 @@ class IpDataLinkLayer : public DataLinkLayer bool isSendLimitReached(); IpParameterObject& _ipParameters; + DataLinkLayerCallbacks* _dllcb; }; #endif diff --git a/src/knx/tpuart_data_link_layer.cpp b/src/knx/tpuart_data_link_layer.cpp index a17b2a4d..2af0ddaa 100644 --- a/src/knx/tpuart_data_link_layer.cpp +++ b/src/knx/tpuart_data_link_layer.cpp @@ -7,7 +7,6 @@ #include "device_object.h" #include "address_table_object.h" #include "cemi_frame.h" -#include "knx_facade.h" #include #include @@ -538,9 +537,11 @@ void TpUartDataLinkLayer::stopChip() TpUartDataLinkLayer::TpUartDataLinkLayer(DeviceObject& devObj, NetworkLayerEntity &netLayerEntity, Platform& platform, - ITpUartCallBacks& cb) + ITpUartCallBacks& cb, + DataLinkLayerCallbacks* dllcb) : DataLinkLayer(devObj, netLayerEntity, platform), - _cb(cb) + _cb(cb), + _dllcb(dllcb) { } @@ -548,7 +549,8 @@ void TpUartDataLinkLayer::frameBytesReceived(uint8_t* buffer, uint16_t length) { //printHex("=>", buffer, length); #ifdef KNX_ACTIVITYCALLBACK - knx.Activity((_netIndex << KNX_ACTIVITYCALLBACK_NET) | (KNX_ACTIVITYCALLBACK_DIR_RECV << KNX_ACTIVITYCALLBACK_DIR)); + if(_dllcb) + _dllcb->Activity((_netIndex << KNX_ACTIVITYCALLBACK_NET) | (KNX_ACTIVITYCALLBACK_DIR_RECV << KNX_ACTIVITYCALLBACK_DIR)); #endif CemiFrame frame(buffer, length); frameReceived(frame); @@ -657,7 +659,8 @@ bool TpUartDataLinkLayer::sendSingleFrameByte() { _TxByteCnt = 0; #ifdef KNX_ACTIVITYCALLBACK - knx.Activity((_netIndex << KNX_ACTIVITYCALLBACK_NET) | (KNX_ACTIVITYCALLBACK_DIR_SEND << KNX_ACTIVITYCALLBACK_DIR)); + if(_dllcb) + _dllcb->Activity((_netIndex << KNX_ACTIVITYCALLBACK_NET) | (KNX_ACTIVITYCALLBACK_DIR_SEND << KNX_ACTIVITYCALLBACK_DIR)); #endif return false; } diff --git a/src/knx/tpuart_data_link_layer.h b/src/knx/tpuart_data_link_layer.h index 9cc658b3..4551fcfe 100644 --- a/src/knx/tpuart_data_link_layer.h +++ b/src/knx/tpuart_data_link_layer.h @@ -21,8 +21,12 @@ class TpUartDataLinkLayer : public DataLinkLayer using DataLinkLayer::_platform; public: + // TpUartDataLinkLayer(DeviceObject& devObj, NetworkLayerEntity& netLayerEntity, + // Platform& platform, ITpUartCallBacks& cb); TpUartDataLinkLayer(DeviceObject& devObj, NetworkLayerEntity& netLayerEntity, - Platform& platform, ITpUartCallBacks& cb); + Platform& platform, ITpUartCallBacks& cb, DataLinkLayerCallbacks* dllcb = nullptr); + + void loop(); void enabled(bool value); @@ -74,5 +78,6 @@ class TpUartDataLinkLayer : public DataLinkLayer void stopChip(); ITpUartCallBacks& _cb; + DataLinkLayerCallbacks* _dllcb; }; #endif