2020-09-29 16:42:22 +02:00
|
|
|
/* SPDX-License-Identifier: LGPL-2.1+ */
|
2014-07-24 08:53:33 -04:00
|
|
|
/*
|
2019-10-01 09:20:35 +02:00
|
|
|
* Copyright (C) 2012 Red Hat, Inc.
|
2014-07-24 08:53:33 -04:00
|
|
|
*/
|
|
|
|
|
|
all: fix up multiple-include-guard defines
Previously, src/nm-ip4-config.h, libnm/nm-ip4-config.h, and
libnm-glib/nm-ip4-config.h all used "NM_IP4_CONFIG_H" as an include
guard, which meant that nm-test-utils.h could not tell which of them
was being included (and so, eg, if you tried to include
nm-ip4-config.h in a libnm test, it would fail to compile because
nm-test-utils.h was referring to symbols in src/nm-ip4-config.h).
Fix this by changing the include guards in the non-API-stable parts of
the tree:
- libnm-glib/nm-ip4-config.h remains NM_IP4_CONFIG_H
- libnm/nm-ip4-config.h now uses __NM_IP4_CONFIG_H__
- src/nm-ip4-config.h now uses __NETWORKMANAGER_IP4_CONFIG_H__
And likewise for all other headers.
The two non-"nm"-prefixed headers, libnm/NetworkManager.h and
src/NetworkManagerUtils.h are now __NETWORKMANAGER_H__ and
__NETWORKMANAGER_UTILS_H__ respectively, which, while not entirely
consistent with the general scheme, do still mostly make sense in
isolation.
2014-08-13 14:10:11 -04:00
|
|
|
#ifndef __NM_SETTING_BRIDGE_PORT_H__
|
|
|
|
|
#define __NM_SETTING_BRIDGE_PORT_H__
|
2014-07-24 08:53:33 -04:00
|
|
|
|
2014-07-06 16:53:02 -04:00
|
|
|
#if !defined(__NETWORKMANAGER_H_INSIDE__) && !defined(NETWORKMANAGER_COMPILATION)
|
|
|
|
|
#error "Only <NetworkManager.h> can be included directly."
|
|
|
|
|
#endif
|
|
|
|
|
|
2017-03-09 13:02:20 +01:00
|
|
|
#include "nm-setting.h"
|
2019-03-16 17:21:35 +01:00
|
|
|
#include "nm-setting-bridge.h"
|
2014-07-24 08:53:33 -04:00
|
|
|
|
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
|
|
|
|
|
|
#define NM_TYPE_SETTING_BRIDGE_PORT (nm_setting_bridge_port_get_type())
|
|
|
|
|
#define NM_SETTING_BRIDGE_PORT(obj) \
|
|
|
|
|
(G_TYPE_CHECK_INSTANCE_CAST((obj), NM_TYPE_SETTING_BRIDGE_PORT, NMSettingBridgePort))
|
|
|
|
|
#define NM_SETTING_BRIDGE_PORT_CLASS(klass) \
|
|
|
|
|
(G_TYPE_CHECK_CLASS_CAST((klass), NM_TYPE_SETTING_BRIDGE_PORT, NMSettingBridgePortClass))
|
|
|
|
|
#define NM_IS_SETTING_BRIDGE_PORT(obj) \
|
|
|
|
|
(G_TYPE_CHECK_INSTANCE_TYPE((obj), NM_TYPE_SETTING_BRIDGE_PORT))
|
|
|
|
|
#define NM_IS_SETTING_BRIDGE_PORT_CLASS(klass) \
|
|
|
|
|
(G_TYPE_CHECK_CLASS_TYPE((klass), NM_TYPE_SETTING_BRIDGE_PORT))
|
|
|
|
|
#define NM_SETTING_BRIDGE_PORT_GET_CLASS(obj) \
|
|
|
|
|
(G_TYPE_INSTANCE_GET_CLASS((obj), NM_TYPE_SETTING_BRIDGE_PORT, NMSettingBridgePortClass))
|
|
|
|
|
|
|
|
|
|
#define NM_SETTING_BRIDGE_PORT_SETTING_NAME "bridge-port"
|
|
|
|
|
|
|
|
|
|
#define NM_SETTING_BRIDGE_PORT_PRIORITY "priority"
|
|
|
|
|
#define NM_SETTING_BRIDGE_PORT_PATH_COST "path-cost"
|
|
|
|
|
#define NM_SETTING_BRIDGE_PORT_HAIRPIN_MODE "hairpin-mode"
|
2019-03-16 17:21:35 +01:00
|
|
|
#define NM_SETTING_BRIDGE_PORT_VLANS "vlans"
|
2014-07-24 08:53:33 -04:00
|
|
|
|
2016-05-05 09:36:32 +02:00
|
|
|
/**
|
|
|
|
|
* NMSettingBridgePort:
|
2017-03-10 20:04:34 +01:00
|
|
|
*
|
|
|
|
|
* Bridge Port Settings
|
2016-05-05 09:36:32 +02:00
|
|
|
*/
|
2014-10-21 22:09:52 -04:00
|
|
|
struct _NMSettingBridgePort {
|
2014-07-24 08:53:33 -04:00
|
|
|
NMSetting parent;
|
2014-10-21 22:09:52 -04:00
|
|
|
};
|
2014-07-24 08:53:33 -04:00
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
|
NMSettingClass parent;
|
|
|
|
|
|
2014-05-15 09:55:18 -04:00
|
|
|
/*< private >*/
|
|
|
|
|
gpointer padding[4];
|
2014-07-24 08:53:33 -04:00
|
|
|
} NMSettingBridgePortClass;
|
|
|
|
|
|
|
|
|
|
GType nm_setting_bridge_port_get_type(void);
|
|
|
|
|
|
|
|
|
|
NMSetting *nm_setting_bridge_port_new(void);
|
|
|
|
|
|
|
|
|
|
guint16 nm_setting_bridge_port_get_priority(NMSettingBridgePort *setting);
|
|
|
|
|
|
|
|
|
|
guint16 nm_setting_bridge_port_get_path_cost(NMSettingBridgePort *setting);
|
|
|
|
|
|
|
|
|
|
gboolean nm_setting_bridge_port_get_hairpin_mode(NMSettingBridgePort *setting);
|
|
|
|
|
|
2019-03-16 17:21:35 +01:00
|
|
|
NM_AVAILABLE_IN_1_18
|
|
|
|
|
void nm_setting_bridge_port_add_vlan(NMSettingBridgePort *setting, NMBridgeVlan *vlan);
|
|
|
|
|
NM_AVAILABLE_IN_1_18
|
|
|
|
|
guint nm_setting_bridge_port_get_num_vlans(NMSettingBridgePort *setting);
|
|
|
|
|
NM_AVAILABLE_IN_1_18
|
|
|
|
|
NMBridgeVlan *nm_setting_bridge_port_get_vlan(NMSettingBridgePort *setting, guint idx);
|
|
|
|
|
NM_AVAILABLE_IN_1_18
|
|
|
|
|
void nm_setting_bridge_port_remove_vlan(NMSettingBridgePort *setting, guint idx);
|
|
|
|
|
NM_AVAILABLE_IN_1_18
|
2019-04-15 15:14:33 +02:00
|
|
|
gboolean nm_setting_bridge_port_remove_vlan_by_vid(NMSettingBridgePort *setting,
|
|
|
|
|
guint16 vid_start,
|
|
|
|
|
guint16 vid_end);
|
2019-03-16 17:21:35 +01:00
|
|
|
NM_AVAILABLE_IN_1_18
|
|
|
|
|
void nm_setting_bridge_port_clear_vlans(NMSettingBridgePort *setting);
|
|
|
|
|
|
2014-07-24 08:53:33 -04:00
|
|
|
G_END_DECLS
|
|
|
|
|
|
all: fix up multiple-include-guard defines
Previously, src/nm-ip4-config.h, libnm/nm-ip4-config.h, and
libnm-glib/nm-ip4-config.h all used "NM_IP4_CONFIG_H" as an include
guard, which meant that nm-test-utils.h could not tell which of them
was being included (and so, eg, if you tried to include
nm-ip4-config.h in a libnm test, it would fail to compile because
nm-test-utils.h was referring to symbols in src/nm-ip4-config.h).
Fix this by changing the include guards in the non-API-stable parts of
the tree:
- libnm-glib/nm-ip4-config.h remains NM_IP4_CONFIG_H
- libnm/nm-ip4-config.h now uses __NM_IP4_CONFIG_H__
- src/nm-ip4-config.h now uses __NETWORKMANAGER_IP4_CONFIG_H__
And likewise for all other headers.
The two non-"nm"-prefixed headers, libnm/NetworkManager.h and
src/NetworkManagerUtils.h are now __NETWORKMANAGER_H__ and
__NETWORKMANAGER_UTILS_H__ respectively, which, while not entirely
consistent with the general scheme, do still mostly make sense in
isolation.
2014-08-13 14:10:11 -04:00
|
|
|
#endif /* __NM_SETTING_BRIDGE_PORT_H__ */
|