Skip to content

Commit

Permalink
[Linux] Fix getting ActiveDatasetTlvs in ThreadStackManager
Browse files Browse the repository at this point in the history
  • Loading branch information
erjiaqing committed Feb 22, 2022
1 parent e71be1c commit 1f8d18b
Show file tree
Hide file tree
Showing 2 changed files with 32 additions and 9 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -279,8 +279,6 @@ async def test_thread(self, endpointId):
raise AssertionError(
f"LastNetworkID, LastConnectErrorValue and LastNetworkingStatus should not be Null")

# TODO: Linux Thread driver cannot get infomation of current connected networks.
'''
logger.info(f"Check network list")
res = await self._devCtrl.ReadAttribute(nodeid=self._nodeid, attributes=[(endpointId, Clusters.NetworkCommissioning.Attributes.Networks)], returnClusterObject=True)
networkList = res[endpointId][Clusters.NetworkCommissioning].networks
Expand All @@ -294,7 +292,6 @@ async def test_thread(self, endpointId):
if not networkList[0].connected:
raise AssertionError(
f"Unexpected result: network is not marked as connected")
'''

async def run(self):
try:
Expand Down
38 changes: 32 additions & 6 deletions src/platform/Linux/ThreadStackManagerImpl.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -238,15 +238,25 @@ CHIP_ERROR ThreadStackManagerImpl::_GetThreadProvision(ByteSpan & netInfo)
VerifyOrReturnError(mProxy, CHIP_ERROR_INCORRECT_STATE);

{
// TODO: The following code does not works actually, since otbr-posix does not emit signals for properties changes. Which is
// required for gdbus to caching properties.
std::unique_ptr<GError, GErrorDeleter> err;

std::unique_ptr<GVariant, GVariantDeleter> value(
openthread_io_openthread_border_router_dup_active_dataset_tlvs(mProxy.get()));
g_dbus_proxy_call_sync(G_DBUS_PROXY(mProxy.get()), "org.freedesktop.DBus.Properties.Get",
g_variant_new("(ss)", "io.openthread.BorderRouter", "ActiveDatasetTlvs"), G_DBUS_CALL_FLAGS_NONE,
-1, nullptr, &MakeUniquePointerReceiver(err).Get()));

if (err)
{
ChipLogError(DeviceLayer, "openthread: failed to read ActiveDatasetTlvs property: %s", err->message);
return CHIP_ERROR_INTERNAL;
}

if (value == nullptr)
{
netInfo = ByteSpan();
return CHIP_ERROR_KEY_NOT_FOUND;
}

GBytes * bytes = g_variant_get_data_as_bytes(value.get());
gsize size;
const uint8_t * data = reinterpret_cast<const uint8_t *>(g_bytes_get_data(bytes, &size));
Expand All @@ -270,13 +280,29 @@ void ThreadStackManagerImpl::_ErasePersistentInfo()

bool ThreadStackManagerImpl::_IsThreadEnabled()
{
if (!mProxy)
VerifyOrReturnError(mProxy, false);

std::unique_ptr<GError, GErrorDeleter> err;

std::unique_ptr<GVariant, GVariantDeleter> value(
g_dbus_proxy_call_sync(G_DBUS_PROXY(mProxy.get()), "org.freedesktop.DBus.Properties.Get",
g_variant_new("(ss)", "io.openthread.BorderRouter", "DeviceRole"), G_DBUS_CALL_FLAGS_NONE, -1,
nullptr, &MakeUniquePointerReceiver(err).Get()));

if (err)
{
ChipLogError(DeviceLayer, "openthread: failed to read DeviceRole property: %s", err->message);
return false;
}

std::unique_ptr<gchar, GFree> role(openthread_io_openthread_border_router_dup_device_role(mProxy.get()));
return (strcmp(role.get(), kOpenthreadDeviceRoleDisabled) != 0);
if (value == nullptr)
{
return false;
}

gchar * role = g_variant_get_string(value.get());

return (strcmp(role, kOpenthreadDeviceRoleDisabled) != 0);
}

bool ThreadStackManagerImpl::_IsThreadAttached()
Expand Down

0 comments on commit 1f8d18b

Please sign in to comment.