2020-12-23 22:21:36 +01:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
2019-09-25 13:13:40 +02:00
|
|
|
/*
|
2009-11-24 10:43:43 -08:00
|
|
|
* Copyright (C) 2007 - 2008 Novell, Inc.
|
2013-05-09 10:24:08 -04:00
|
|
|
* Copyright (C) 2007 - 2013 Red Hat, Inc.
|
2009-11-24 10:43:43 -08:00
|
|
|
*/
|
|
|
|
|
|
2016-09-29 13:49:01 +02:00
|
|
|
#ifndef __NM_RFKILL_MANAGER_H__
|
|
|
|
|
#define __NM_RFKILL_MANAGER_H__
|
2016-08-23 11:45:51 +02:00
|
|
|
|
2022-02-02 12:12:12 +01:00
|
|
|
typedef enum {
|
2022-02-01 20:21:34 +01:00
|
|
|
NM_RFKILL_STATE_UNBLOCKED = 0,
|
|
|
|
|
NM_RFKILL_STATE_SOFT_BLOCKED = 1,
|
|
|
|
|
NM_RFKILL_STATE_HARD_BLOCKED = 2,
|
2022-02-16 15:42:33 +02:00
|
|
|
/* NM_RFKILL_STATE_HARD_BLOCKED_OS_NOT_OWNER means that the CSME firmware
|
|
|
|
|
* is currently controlling the device. This feature is implmented on Intel
|
|
|
|
|
* wifi devices only.
|
|
|
|
|
* The NetworkManager can get ownership on the device, but it requires to
|
|
|
|
|
* first ask ownership through the iwlmei kernel module.
|
|
|
|
|
*/
|
|
|
|
|
NM_RFKILL_STATE_HARD_BLOCKED_OS_NOT_OWNER = 3,
|
2022-02-01 20:21:34 +01:00
|
|
|
} NMRfkillState;
|
2009-11-24 10:43:43 -08:00
|
|
|
|
2022-02-02 12:12:12 +01:00
|
|
|
typedef enum {
|
2022-02-01 20:21:34 +01:00
|
|
|
NM_RFKILL_TYPE_WLAN = 0,
|
|
|
|
|
NM_RFKILL_TYPE_WWAN = 1,
|
2009-12-22 23:46:06 -08:00
|
|
|
|
2022-02-02 12:12:12 +01:00
|
|
|
/* UNKNOWN and MAX should always be 1 more than
|
2022-02-01 20:21:34 +01:00
|
|
|
* the last rfkill type since NM_RFKILL_TYPE_MAX is
|
2009-12-22 23:46:06 -08:00
|
|
|
* used as an array size.
|
|
|
|
|
*/
|
2022-02-01 20:21:34 +01:00
|
|
|
NM_RFKILL_TYPE_UNKNOWN, /* KEEP LAST */
|
|
|
|
|
NM_RFKILL_TYPE_MAX = NM_RFKILL_TYPE_UNKNOWN,
|
|
|
|
|
} NMRfkillType;
|
2009-12-22 23:46:06 -08:00
|
|
|
|
2022-02-01 22:32:46 +01:00
|
|
|
const char *nm_rfkill_type_to_string(NMRfkillType rtype);
|
|
|
|
|
|
2013-05-09 10:24:08 -04:00
|
|
|
#define NM_TYPE_RFKILL_MANAGER (nm_rfkill_manager_get_type())
|
|
|
|
|
#define NM_RFKILL_MANAGER(obj) \
|
|
|
|
|
(G_TYPE_CHECK_INSTANCE_CAST((obj), NM_TYPE_RFKILL_MANAGER, NMRfkillManager))
|
|
|
|
|
#define NM_RFKILL_MANAGER_CLASS(klass) \
|
|
|
|
|
(G_TYPE_CHECK_CLASS_CAST((klass), NM_TYPE_RFKILL_MANAGER, NMRfkillManagerClass))
|
|
|
|
|
#define NM_IS_RFKILL_MANAGER(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj), NM_TYPE_RFKILL_MANAGER))
|
|
|
|
|
#define NM_IS_RFKILL_MANAGER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass), NM_TYPE_RFKILL_MANAGER))
|
|
|
|
|
#define NM_RFKILL_MANAGER_GET_CLASS(obj) \
|
|
|
|
|
(G_TYPE_INSTANCE_GET_CLASS((obj), NM_TYPE_RFKILL_MANAGER, NMRfkillManagerClass))
|
|
|
|
|
|
2016-09-29 13:49:01 +02:00
|
|
|
#define NM_RFKILL_MANAGER_SIGNAL_RFKILL_CHANGED "rfkill-changed"
|
2013-05-09 10:24:08 -04:00
|
|
|
|
2016-09-29 13:49:01 +02:00
|
|
|
typedef struct _NMRfkillManagerClass NMRfkillManagerClass;
|
2013-05-09 10:24:08 -04:00
|
|
|
|
|
|
|
|
GType nm_rfkill_manager_get_type(void);
|
|
|
|
|
|
|
|
|
|
NMRfkillManager *nm_rfkill_manager_new(void);
|
|
|
|
|
|
2022-02-01 20:21:34 +01:00
|
|
|
NMRfkillState nm_rfkill_manager_get_rfkill_state(NMRfkillManager *manager, NMRfkillType rtype);
|
2013-05-09 10:24:08 -04:00
|
|
|
|
2016-09-29 13:49:01 +02:00
|
|
|
#endif /* __NM_RFKILL_MANAGER_H__ */
|