From 070f4938f3ff5425f8c4f18f57e79d935ad05b32 Mon Sep 17 00:00:00 2001 From: Aleksander Morgado Date: Tue, 19 Nov 2013 20:48:20 +0100 Subject: plugin: allow probing non-tty AT ports --- src/mm-plugin.c | 20 +++++++++++++------- 1 file changed, 13 insertions(+), 7 deletions(-) (limited to 'src/mm-plugin.c') diff --git a/src/mm-plugin.c b/src/mm-plugin.c index 6b33f9a7..a5ddb5db 100644 --- a/src/mm-plugin.c +++ b/src/mm-plugin.c @@ -718,21 +718,27 @@ mm_plugin_supports_port (MMPlugin *self, probe_run_flags |= MM_PORT_PROBE_AT; else if (self->priv->single_at) probe_run_flags |= MM_PORT_PROBE_AT; - if (need_vendor_probing) - probe_run_flags |= (MM_PORT_PROBE_AT | MM_PORT_PROBE_AT_VENDOR); - if (need_product_probing) - probe_run_flags |= (MM_PORT_PROBE_AT | MM_PORT_PROBE_AT_PRODUCT); if (self->priv->qcdm) probe_run_flags |= MM_PORT_PROBE_QCDM; - if (self->priv->icera_probe || self->priv->allowed_icera || self->priv->forbidden_icera) - probe_run_flags |= (MM_PORT_PROBE_AT | MM_PORT_PROBE_AT_ICERA); } else { /* cdc-wdm ports... */ probe_run_flags = MM_PORT_PROBE_NONE; if (self->priv->qmi && find_driver_in_device (device, "qmi_wwan")) probe_run_flags |= MM_PORT_PROBE_QMI; - if (self->priv->mbim && find_driver_in_device (device, "cdc_mbim")) + else if (self->priv->mbim && find_driver_in_device (device, "cdc_mbim")) probe_run_flags |= MM_PORT_PROBE_MBIM; + else + probe_run_flags |= MM_PORT_PROBE_AT; + } + + /* For potential AT ports, check for more things */ + if (probe_run_flags & MM_PORT_PROBE_AT) { + if (need_vendor_probing) + probe_run_flags |= MM_PORT_PROBE_AT_VENDOR; + if (need_product_probing) + probe_run_flags |= MM_PORT_PROBE_AT_PRODUCT; + if (self->priv->icera_probe || self->priv->allowed_icera || self->priv->forbidden_icera) + probe_run_flags |= MM_PORT_PROBE_AT_ICERA; } /* If no explicit probing was required, just request to grab it without probing anything. -- cgit v1.2.3-70-g09d2