diff options
Diffstat (limited to 'src/plugins/fibocom/mm-broadband-modem-fibocom.c')
-rw-r--r-- | src/plugins/fibocom/mm-broadband-modem-fibocom.c | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/src/plugins/fibocom/mm-broadband-modem-fibocom.c b/src/plugins/fibocom/mm-broadband-modem-fibocom.c index 2bc27f16..0789188e 100644 --- a/src/plugins/fibocom/mm-broadband-modem-fibocom.c +++ b/src/plugins/fibocom/mm-broadband-modem-fibocom.c @@ -27,6 +27,8 @@ static void iface_modem_init (MMIfaceModemInterface *iface); static void iface_modem_firmware_init (MMIfaceModemFirmwareInterface *iface); static void shared_fibocom_init (MMSharedFibocomInterface *iface); +static MMIfaceModemFirmwareInterface *iface_modem_firmware_parent; + G_DEFINE_TYPE_EXTENDED (MMBroadbandModemFibocom, mm_broadband_modem_fibocom, MM_TYPE_BROADBAND_MODEM, 0, G_IMPLEMENT_INTERFACE (MM_TYPE_IFACE_MODEM, iface_modem_init) G_IMPLEMENT_INTERFACE (MM_TYPE_SHARED_FIBOCOM, shared_fibocom_init) @@ -265,10 +267,18 @@ iface_modem_init (MMIfaceModemInterface *iface) static void iface_modem_firmware_init (MMIfaceModemFirmwareInterface *iface) { + iface_modem_firmware_parent = g_type_interface_peek_parent (iface); + iface->load_update_settings = mm_shared_fibocom_firmware_load_update_settings; iface->load_update_settings_finish = mm_shared_fibocom_firmware_load_update_settings_finish; } +static MMIfaceModemFirmwareInterface * +peek_parent_firmware_interface (MMSharedFibocom *self) +{ + return iface_modem_firmware_parent; +} + static MMBaseModemClass * peek_parent_class (MMSharedFibocom *self) { @@ -279,6 +289,7 @@ static void shared_fibocom_init (MMSharedFibocomInterface *iface) { iface->peek_parent_class = peek_parent_class; + iface->peek_parent_firmware_interface = peek_parent_firmware_interface; } static void |