mirror of
https://gitlab.freedesktop.org/NetworkManager/NetworkManager.git
synced 2026-03-24 09:00:37 +01:00
bridge: move the Bluetooth NAP logic to bridge device
The Bluetooth NAP functionality seems only useful for the bridges. Move it away from NMDevice.
This commit is contained in:
parent
b0f9571d3d
commit
bf7e86128c
5 changed files with 76 additions and 64 deletions
|
|
@ -33,7 +33,7 @@
|
|||
#include "nm-utils/c-list.h"
|
||||
#include "nm-bluez-device.h"
|
||||
#include "nm-bluez-common.h"
|
||||
#include "devices/nm-device.h"
|
||||
#include "devices/nm-device-bridge.h"
|
||||
#include "settings/nm-settings.h"
|
||||
|
||||
/*****************************************************************************/
|
||||
|
|
|
|||
|
|
@ -49,6 +49,56 @@ G_DEFINE_TYPE (NMDeviceBridge, nm_device_bridge, NM_TYPE_DEVICE)
|
|||
|
||||
/*****************************************************************************/
|
||||
|
||||
const NMBtVTableNetworkServer *nm_bt_vtable_network_server = NULL;
|
||||
|
||||
static gboolean
|
||||
bt_network_server_available (NMConnection *connection)
|
||||
{
|
||||
NMSettingBluetooth *s_bt = _nm_connection_get_setting_bluetooth_for_nap (connection);
|
||||
|
||||
if (!s_bt)
|
||||
return TRUE;
|
||||
if (!nm_bt_vtable_network_server)
|
||||
return FALSE;
|
||||
return nm_bt_vtable_network_server->is_available (nm_bt_vtable_network_server,
|
||||
nm_setting_bluetooth_get_bdaddr (s_bt));
|
||||
}
|
||||
|
||||
static gboolean
|
||||
bt_network_server_register (NMDevice *self)
|
||||
{
|
||||
NMConnection *connection = nm_device_get_applied_connection (self);
|
||||
NMSettingBluetooth *s_bt = _nm_connection_get_setting_bluetooth_for_nap (connection);
|
||||
|
||||
if (!s_bt)
|
||||
return TRUE;
|
||||
if (!nm_bt_vtable_network_server)
|
||||
return FALSE;
|
||||
return nm_bt_vtable_network_server->register_bridge (nm_bt_vtable_network_server,
|
||||
nm_setting_bluetooth_get_bdaddr (s_bt),
|
||||
self);
|
||||
}
|
||||
|
||||
static void
|
||||
bt_network_server_unregister (NMDevice *self)
|
||||
{
|
||||
NMConnection *connection = nm_device_get_applied_connection (self);
|
||||
NMSettingBluetooth *s_bt;
|
||||
|
||||
if (!connection)
|
||||
return;
|
||||
s_bt = _nm_connection_get_setting_bluetooth_for_nap (connection);
|
||||
if (!s_bt)
|
||||
return;
|
||||
|
||||
if (!nm_bt_vtable_network_server)
|
||||
return;
|
||||
nm_bt_vtable_network_server->unregister_bridge (nm_bt_vtable_network_server,
|
||||
self);
|
||||
}
|
||||
|
||||
/*****************************************************************************/
|
||||
|
||||
static NMDeviceCapabilities
|
||||
get_generic_capabilities (NMDevice *dev)
|
||||
{
|
||||
|
|
@ -67,6 +117,9 @@ check_connection_available (NMDevice *device,
|
|||
NMDeviceCheckConAvailableFlags flags,
|
||||
const char *specific_object)
|
||||
{
|
||||
if (!bt_network_server_available (connection))
|
||||
return FALSE;
|
||||
|
||||
/* Connections are always available because the carrier state is determined
|
||||
* by the bridge port carrier states, not the bridge's state.
|
||||
*/
|
||||
|
|
@ -324,6 +377,24 @@ act_stage1_prepare (NMDevice *device, NMDeviceStateReason *out_failure_reason)
|
|||
return NM_ACT_STAGE_RETURN_SUCCESS;
|
||||
}
|
||||
|
||||
static NMActStageReturn
|
||||
act_stage2_config (NMDevice *device, NMDeviceStateReason *out_failure_reason)
|
||||
{
|
||||
if (!bt_network_server_register (device)) {
|
||||
/* The HCI we could use is no longer present. */
|
||||
*out_failure_reason = NM_DEVICE_STATE_REASON_REMOVED;
|
||||
return NM_ACT_STAGE_RETURN_FAILURE;
|
||||
}
|
||||
|
||||
return NM_ACT_STAGE_RETURN_SUCCESS;
|
||||
}
|
||||
|
||||
static void
|
||||
deactivate (NMDevice *device)
|
||||
{
|
||||
bt_network_server_unregister (device);
|
||||
}
|
||||
|
||||
static gboolean
|
||||
enslave_slave (NMDevice *device,
|
||||
NMDevice *slave,
|
||||
|
|
@ -443,6 +514,8 @@ nm_device_bridge_class_init (NMDeviceBridgeClass *klass)
|
|||
|
||||
parent_class->create_and_realize = create_and_realize;
|
||||
parent_class->act_stage1_prepare = act_stage1_prepare;
|
||||
parent_class->act_stage2_config = act_stage2_config;
|
||||
parent_class->deactivate = deactivate;
|
||||
parent_class->enslave_slave = enslave_slave;
|
||||
parent_class->release_slave = release_slave;
|
||||
parent_class->get_configured_mtu = nm_device_get_configured_mtu_for_wired;
|
||||
|
|
|
|||
|
|
@ -35,4 +35,6 @@ typedef struct _NMDeviceBridgeClass NMDeviceBridgeClass;
|
|||
|
||||
GType nm_device_bridge_get_type (void);
|
||||
|
||||
extern const NMBtVTableNetworkServer *nm_bt_vtable_network_server;
|
||||
|
||||
#endif /* __NETWORKMANAGER_DEVICE_BRIDGE_H__ */
|
||||
|
|
|
|||
|
|
@ -4364,56 +4364,6 @@ dnsmasq_state_changed_cb (NMDnsMasqManager *manager, guint32 status, gpointer us
|
|||
|
||||
/*****************************************************************************/
|
||||
|
||||
const NMBtVTableNetworkServer *nm_bt_vtable_network_server = NULL;
|
||||
|
||||
static gboolean
|
||||
bt_network_server_available (NMConnection *connection)
|
||||
{
|
||||
NMSettingBluetooth *s_bt = _nm_connection_get_setting_bluetooth_for_nap (connection);
|
||||
|
||||
if (!s_bt)
|
||||
return TRUE;
|
||||
if (!nm_bt_vtable_network_server)
|
||||
return FALSE;
|
||||
return nm_bt_vtable_network_server->is_available (nm_bt_vtable_network_server,
|
||||
nm_setting_bluetooth_get_bdaddr (s_bt));
|
||||
}
|
||||
|
||||
static gboolean
|
||||
bt_network_server_register (NMDevice *self)
|
||||
{
|
||||
NMConnection *connection = nm_device_get_applied_connection (self);
|
||||
NMSettingBluetooth *s_bt = _nm_connection_get_setting_bluetooth_for_nap (connection);
|
||||
|
||||
if (!s_bt)
|
||||
return TRUE;
|
||||
if (!nm_bt_vtable_network_server)
|
||||
return FALSE;
|
||||
return nm_bt_vtable_network_server->register_bridge (nm_bt_vtable_network_server,
|
||||
nm_setting_bluetooth_get_bdaddr (s_bt),
|
||||
self);
|
||||
}
|
||||
|
||||
static void
|
||||
bt_network_server_unregister (NMDevice *self)
|
||||
{
|
||||
NMConnection *connection = nm_device_get_applied_connection (self);
|
||||
NMSettingBluetooth *s_bt;
|
||||
|
||||
if (!connection)
|
||||
return;
|
||||
s_bt = _nm_connection_get_setting_bluetooth_for_nap (connection);
|
||||
if (!s_bt)
|
||||
return;
|
||||
|
||||
if (!nm_bt_vtable_network_server)
|
||||
return;
|
||||
nm_bt_vtable_network_server->unregister_bridge (nm_bt_vtable_network_server,
|
||||
self);
|
||||
}
|
||||
|
||||
/*****************************************************************************/
|
||||
|
||||
static gboolean
|
||||
activation_source_handle_cb4 (gpointer user_data)
|
||||
{
|
||||
|
|
@ -4799,12 +4749,6 @@ activate_stage2_device_config (NMDevice *self)
|
|||
nm_device_queue_recheck_assume (info->slave);
|
||||
}
|
||||
|
||||
if (!bt_network_server_register (self)) {
|
||||
/* The HCI we could use is no longer present. */
|
||||
nm_device_state_changed (self, NM_DEVICE_STATE_FAILED, NM_DEVICE_STATE_REASON_REMOVED);
|
||||
return;
|
||||
}
|
||||
|
||||
lldp_init (self, TRUE);
|
||||
nm_device_activate_schedule_stage3_ip_config_start (self);
|
||||
}
|
||||
|
|
@ -11494,9 +11438,6 @@ _nm_device_check_connection_available (NMDevice *self,
|
|||
{
|
||||
NMDeviceState state;
|
||||
|
||||
if (!bt_network_server_available (connection))
|
||||
return FALSE;
|
||||
|
||||
/* an unrealized software device is always available, hardware devices never. */
|
||||
if (!nm_device_is_real (self)) {
|
||||
if (nm_device_is_software (self))
|
||||
|
|
@ -11938,8 +11879,6 @@ _cleanup_generic_pre (NMDevice *self, CleanupType cleanup_type)
|
|||
|
||||
queued_state_clear (self);
|
||||
|
||||
bt_network_server_unregister (self);
|
||||
|
||||
_cleanup_ip4_pre (self, cleanup_type);
|
||||
_cleanup_ip6_pre (self, cleanup_type);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -716,6 +716,4 @@ struct _NMBtVTableNetworkServer {
|
|||
NMDevice *device);
|
||||
};
|
||||
|
||||
extern const NMBtVTableNetworkServer *nm_bt_vtable_network_server;
|
||||
|
||||
#endif /* __NETWORKMANAGER_DEVICE_H__ */
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue