From 15ea60034077c8c67fdceca1e21a13e79cc92423 Mon Sep 17 00:00:00 2001 From: Fred Hornsey Date: Wed, 31 Jan 2024 21:20:20 -0600 Subject: [PATCH] Expand Android Netlink Warning and Match DevGuide Also fix some minor typos in the section. --- dds/DCPS/LinuxNetworkConfigMonitor.cpp | 8 +++++--- docs/devguide/building/android.rst | 8 ++++---- 2 files changed, 9 insertions(+), 7 deletions(-) diff --git a/dds/DCPS/LinuxNetworkConfigMonitor.cpp b/dds/DCPS/LinuxNetworkConfigMonitor.cpp index 3eb912b23c1..d9561e0f597 100644 --- a/dds/DCPS/LinuxNetworkConfigMonitor.cpp +++ b/dds/DCPS/LinuxNetworkConfigMonitor.cpp @@ -78,12 +78,14 @@ bool LinuxNetworkConfigMonitor::open_i() if (socket_.open(addr, AF_NETLINK, NETLINK_ROUTE) != 0) { #ifdef ACE_ANDROID if (log_level >= LogLevel::Warning) { - ACE_ERROR((LM_WARNING, "(%P|%t) WARNING: LinuxNetworkConfigMonitor::open_i: could not open socket" - " this is expected for API30+\n")); + ACE_ERROR((LM_WARNING, "(%P|%t) WARNING: LinuxNetworkConfigMonitor::open_i: " + "could not open Netlink socket " + "(this is expected for API>=30, see Android section in the Developer's Guide)\n")); } #else if (log_level >= LogLevel::Error) { - ACE_ERROR((LM_ERROR, "(%P|%t) ERROR: LinuxNetworkConfigMonitor::open_i: could not open socket: %m\n")); + ACE_ERROR((LM_ERROR, "(%P|%t) ERROR: LinuxNetworkConfigMonitor::open_i: " + "could not open Netlink socket: %m\n")); } #endif return false; diff --git a/docs/devguide/building/android.rst b/docs/devguide/building/android.rst index d844eb72b6c..f0d4d7756a3 100644 --- a/docs/devguide/building/android.rst +++ b/docs/devguide/building/android.rst @@ -578,12 +578,12 @@ Failure to do so will result in ACE failing to access any sockets and OpenDDS wi Network Availability -------------------- -When not running in an application targeting API 30 later on Android 10 or later, Android builds of OpenDDS use the ``LinuxNetworkConfigMonitor`` to reconfigure OpenDDS connections automatically when the device switches from one network (cellular or wifi) to another. +When not running in an application targeting API 30 or later on Android 10 or later, Android builds of OpenDDS use the ``LinuxNetworkConfigMonitor`` to reconfigure OpenDDS connections automatically when the device switches from one network (cellular or WiFi) to another. -When running in an application targeting API 30 later on Android 10, ``LinuxNetworkConfigMonitor`` can no longer be used, as Netlink sockets are blocked by the OS for security reasons. -In the logs this error show up as: +When running in an application targeting API 30 or later on Android 10, ``LinuxNetworkConfigMonitor`` can no longer be used, as Netlink sockets are blocked by the OS for security reasons. +In the logs this warning shows up as: - ERROR: LinuxNetworkConfigMonitor::open: could not open socket: Permission denied + WARNING: LinuxNetworkConfigMonitor::open_i: could not open Netlink socket (this is expected for API>=30, see Android section in the Developer's Guide) Instead, ``NetworkConfigModifier`` is utilized. As a consequence of this, two variables are required from the user, :ref:`android_sdk`, and :ref:`android_target_api`.