-
Notifications
You must be signed in to change notification settings - Fork 27
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
2 changed files
with
237 additions
and
0 deletions.
There are no files selected for viewing
51 changes: 51 additions & 0 deletions
51
0006-Python-Allow-early-logging-initialization-31945.patch
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,51 @@ | ||
From e4d6e50d1485110068e85ec28836b37d386fbd47 Mon Sep 17 00:00:00 2001 | ||
From: Stefan Agner <[email protected]> | ||
Date: Tue, 13 Feb 2024 22:38:46 +0100 | ||
Subject: [PATCH] [Python] Allow early logging initialization (#31945) | ||
|
||
* [Python] Allow early logging initialization | ||
|
||
Allow to initialize logging before initializing the stack. Similar to | ||
tracing, logging doesn't need the stack to be setup. This allows to | ||
redirect logging to Python as early as possible. | ||
|
||
* Log using chip.native module for clarity | ||
|
||
Use chip.native module for all redirected logs. This separates it from | ||
logs written by the Python bindings themselfs. | ||
--- | ||
src/controller/python/chip/logging/__init__.py | 2 +- | ||
src/controller/python/chip/logging/library_handle.py | 4 +++- | ||
2 files changed, 4 insertions(+), 2 deletions(-) | ||
|
||
diff --git a/src/controller/python/chip/logging/__init__.py b/src/controller/python/chip/logging/__init__.py | ||
index 980c33ac92..6916c8b272 100644 | ||
--- a/src/controller/python/chip/logging/__init__.py | ||
+++ b/src/controller/python/chip/logging/__init__.py | ||
@@ -32,7 +32,7 @@ def _RedirectToPythonLogging(category, module, message): | ||
module = module.decode('utf-8') | ||
message = message.decode('utf-8') | ||
|
||
- logger = logging.getLogger('chip.%s' % module) | ||
+ logger = logging.getLogger('chip.native.%s' % module) | ||
|
||
if category == ERROR_CATEGORY_ERROR: | ||
logger.error("%s", message) | ||
diff --git a/src/controller/python/chip/logging/library_handle.py b/src/controller/python/chip/logging/library_handle.py | ||
index ae34f502fd..f74a810b46 100644 | ||
--- a/src/controller/python/chip/logging/library_handle.py | ||
+++ b/src/controller/python/chip/logging/library_handle.py | ||
@@ -27,7 +27,9 @@ def _GetLoggingLibraryHandle() -> ctypes.CDLL: | ||
native methods. | ||
""" | ||
|
||
- handle = chip.native.GetLibraryHandle() | ||
+ # Getting a handle without requiring init, as logging methods | ||
+ # do not require chip stack startup | ||
+ handle = chip.native.GetLibraryHandle(chip.native.HandleFlags(0)) | ||
|
||
# Uses one of the type decorators as an indicator for everything being | ||
# initialized. | ||
-- | ||
2.43.0 | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,186 @@ | ||
From bf8ce26830a60e0d247f37f3b26d2f2244cb986d Mon Sep 17 00:00:00 2001 | ||
From: Stefan Agner <[email protected]> | ||
Date: Wed, 14 Feb 2024 15:11:44 +0100 | ||
Subject: [PATCH] [Python] Make Logging Filtering global (#31944) | ||
|
||
Log filtering is a global affair, so move the filtering functions to a | ||
global context too. This allows to setup logging before creating any | ||
device controller. It aligns with how the SDK treats logging. | ||
|
||
Also enable log filtering for the Linux platform to make the | ||
functionality useful on Linux. | ||
--- | ||
src/controller/python/BUILD.gn | 1 + | ||
.../ChipDeviceController-ScriptBinding.cpp | 20 ---------- | ||
src/controller/python/chip/ChipDeviceCtrl.py | 17 --------- | ||
.../python/chip/logging/LoggingFilter.cpp | 37 +++++++++++++++++++ | ||
.../python/chip/logging/__init__.py | 13 +++++++ | ||
src/platform/Linux/CHIPPlatformConfig.h | 2 +- | ||
6 files changed, 52 insertions(+), 38 deletions(-) | ||
create mode 100644 src/controller/python/chip/logging/LoggingFilter.cpp | ||
|
||
diff --git a/src/controller/python/BUILD.gn b/src/controller/python/BUILD.gn | ||
index 140ef1e08d..5fc2212098 100644 | ||
--- a/src/controller/python/BUILD.gn | ||
+++ b/src/controller/python/BUILD.gn | ||
@@ -81,6 +81,7 @@ shared_library("ChipDeviceCtrl") { | ||
"chip/internal/ChipThreadWork.cpp", | ||
"chip/internal/ChipThreadWork.h", | ||
"chip/internal/CommissionerImpl.cpp", | ||
+ "chip/logging/LoggingFilter.cpp", | ||
"chip/logging/LoggingRedirect.cpp", | ||
"chip/native/ChipMainLoopWork.h", | ||
"chip/native/PyChipError.cpp", | ||
diff --git a/src/controller/python/ChipDeviceController-ScriptBinding.cpp b/src/controller/python/ChipDeviceController-ScriptBinding.cpp | ||
index 2576a36030..b4f2edb295 100644 | ||
--- a/src/controller/python/ChipDeviceController-ScriptBinding.cpp | ||
+++ b/src/controller/python/ChipDeviceController-ScriptBinding.cpp | ||
@@ -71,7 +71,6 @@ | ||
#include <lib/support/CodeUtils.h> | ||
#include <lib/support/DLLUtil.h> | ||
#include <lib/support/ScopedBuffer.h> | ||
-#include <lib/support/logging/CHIPLogging.h> | ||
#include <platform/CHIPDeviceLayer.h> | ||
#include <setup_payload/QRCodeSetupPayloadParser.h> | ||
#include <system/SystemClock.h> | ||
@@ -200,9 +199,6 @@ PyChipError pychip_ScriptDevicePairingDelegate_SetOpenWindowCompleteCallback( | ||
// BLE | ||
PyChipError pychip_DeviceCommissioner_CloseBleConnection(chip::Controller::DeviceCommissioner * devCtrl); | ||
|
||
-uint8_t pychip_DeviceController_GetLogFilter(); | ||
-void pychip_DeviceController_SetLogFilter(uint8_t category); | ||
- | ||
const char * pychip_Stack_ErrorToString(ChipError::StorageType err); | ||
const char * pychip_Stack_StatusReportToString(uint32_t profileId, uint16_t statusCode); | ||
void pychip_Stack_SetLogFunct(LogMessageFunct logFunct); | ||
@@ -353,22 +349,6 @@ const char * pychip_DeviceController_StatusReportToString(uint32_t profileId, ui | ||
return nullptr; | ||
} | ||
|
||
-uint8_t pychip_DeviceController_GetLogFilter() | ||
-{ | ||
-#if _CHIP_USE_LOGGING | ||
- return chip::Logging::GetLogFilter(); | ||
-#else | ||
- return chip::Logging::kLogCategory_None; | ||
-#endif | ||
-} | ||
- | ||
-void pychip_DeviceController_SetLogFilter(uint8_t category) | ||
-{ | ||
-#if _CHIP_USE_LOGGING | ||
- chip::Logging::SetLogFilter(category); | ||
-#endif | ||
-} | ||
- | ||
PyChipError pychip_DeviceController_ConnectBLE(chip::Controller::DeviceCommissioner * devCtrl, uint16_t discriminator, | ||
uint32_t setupPINCode, chip::NodeId nodeid) | ||
{ | ||
diff --git a/src/controller/python/chip/ChipDeviceCtrl.py b/src/controller/python/chip/ChipDeviceCtrl.py | ||
index 2297dfff30..2400d543f6 100644 | ||
--- a/src/controller/python/chip/ChipDeviceCtrl.py | ||
+++ b/src/controller/python/chip/ChipDeviceCtrl.py | ||
@@ -1480,23 +1480,6 @@ class ChipDeviceControllerBase(): | ||
|
||
return self._Cluster.ListClusterAttributes() | ||
|
||
- def SetLogFilter(self, category): | ||
- self.CheckIsActive() | ||
- | ||
- if category < 0 or category > pow(2, 8): | ||
- raise ValueError("category must be an unsigned 8-bit integer") | ||
- | ||
- self._ChipStack.Call( | ||
- lambda: self._dmLib.pychip_DeviceController_SetLogFilter(category) | ||
- ) | ||
- | ||
- def GetLogFilter(self): | ||
- self.CheckIsActive() | ||
- | ||
- self._ChipStack.Call( | ||
- lambda: self._dmLib.pychip_DeviceController_GetLogFilter() | ||
- ) | ||
- | ||
def SetBlockingCB(self, blockingCB): | ||
self.CheckIsActive() | ||
|
||
diff --git a/src/controller/python/chip/logging/LoggingFilter.cpp b/src/controller/python/chip/logging/LoggingFilter.cpp | ||
new file mode 100644 | ||
index 0000000000..52271dc3ae | ||
--- /dev/null | ||
+++ b/src/controller/python/chip/logging/LoggingFilter.cpp | ||
@@ -0,0 +1,37 @@ | ||
+/* | ||
+ * | ||
+ * Copyright (c) 2024 Project CHIP Authors | ||
+ * | ||
+ * Licensed under the Apache License, Version 2.0 (the "License"); | ||
+ * you may not use this file except in compliance with the License. | ||
+ * You may obtain a copy of the License at | ||
+ * | ||
+ * http://www.apache.org/licenses/LICENSE-2.0 | ||
+ * | ||
+ * Unless required by applicable law or agreed to in writing, software | ||
+ * distributed under the License is distributed on an "AS IS" BASIS, | ||
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
+ * See the License for the specific language governing permissions and | ||
+ * limitations under the License. | ||
+ */ | ||
+ | ||
+#include <lib/support/logging/CHIPLogging.h> | ||
+ | ||
+extern "C" { | ||
+ | ||
+uint8_t pychip_logging_GetLogFilter() | ||
+{ | ||
+#if _CHIP_USE_LOGGING | ||
+ return chip::Logging::GetLogFilter(); | ||
+#else | ||
+ return chip::Logging::kLogCategory_None; | ||
+#endif | ||
+} | ||
+ | ||
+void pychip_logging_SetLogFilter(uint8_t category) | ||
+{ | ||
+#if _CHIP_USE_LOGGING | ||
+ chip::Logging::SetLogFilter(category); | ||
+#endif | ||
+} | ||
+} | ||
diff --git a/src/controller/python/chip/logging/__init__.py b/src/controller/python/chip/logging/__init__.py | ||
index 6916c8b272..047d3f4f8e 100644 | ||
--- a/src/controller/python/chip/logging/__init__.py | ||
+++ b/src/controller/python/chip/logging/__init__.py | ||
@@ -51,3 +51,16 @@ def RedirectToPythonLogging(): | ||
|
||
handle = _GetLoggingLibraryHandle() | ||
handle.pychip_logging_set_callback(_RedirectToPythonLogging) | ||
+ | ||
+ | ||
+def SetLogFilter(category): | ||
+ if category < 0 or category > pow(2, 8): | ||
+ raise ValueError("category must be an unsigned 8-bit integer") | ||
+ | ||
+ handle = _GetLoggingLibraryHandle() | ||
+ handle.pychip_logging_SetLogFilter(category) | ||
+ | ||
+ | ||
+def GetLogFilter(): | ||
+ handle = _GetLoggingLibraryHandle() | ||
+ return handle.pychip_logging_GetLogFilter() | ||
diff --git a/src/platform/Linux/CHIPPlatformConfig.h b/src/platform/Linux/CHIPPlatformConfig.h | ||
index 788fe9b80c..9e2832307f 100644 | ||
--- a/src/platform/Linux/CHIPPlatformConfig.h | ||
+++ b/src/platform/Linux/CHIPPlatformConfig.h | ||
@@ -57,7 +57,7 @@ using CHIP_CONFIG_PERSISTED_STORAGE_KEY_TYPE = const char *; | ||
#endif // CHIP_CONFIG_MAX_EXCHANGE_CONTEXTS | ||
|
||
#ifndef CHIP_LOG_FILTERING | ||
-#define CHIP_LOG_FILTERING 0 | ||
+#define CHIP_LOG_FILTERING 1 | ||
#endif // CHIP_LOG_FILTERING | ||
|
||
#ifndef CHIP_CONFIG_BDX_MAX_NUM_TRANSFERS | ||
-- | ||
2.43.0 | ||
|