[PATCH v2 03/13] ublox: define port type hints for the TOBY-L4

Aleksander Morgado aleksander at aleksander.es
Fri Sep 15 23:21:55 UTC 2017


On 14/09/17 22:00, Aleksander Morgado wrote:
> The TOBY-L4 exposes multiple TTY ports, but each of them has different
> purposes:
> 
> The TTY at interface #2 is a fully capable AT port but shouldn't be
> used to start connections, so we flag it as secondary.
> 
> The TTY at interface #4 is a non-AT debug port, so we explicitly
> ignore it to make probing faster.
> 
> The TTY at interface #6 is the fully capable AT port that must be used
> as primary port.
> 
> The TTY at interface #8 is an AT-capable port but dedicated to FOTA
> update operations.
> ---

Merged to git master.

>  plugins/Makefile.am                        |  2 ++
>  plugins/ublox/77-mm-ublox-port-types.rules | 20 ++++++++++++++++++++
>  plugins/ublox/mm-plugin-ublox.c            | 29 +++++++++++++++++++++++++++++
>  3 files changed, 51 insertions(+)
>  create mode 100644 plugins/ublox/77-mm-ublox-port-types.rules
> 
> diff --git a/plugins/Makefile.am b/plugins/Makefile.am
> index d3575522..98a95f53 100644
> --- a/plugins/Makefile.am
> +++ b/plugins/Makefile.am
> @@ -899,6 +899,8 @@ test_udev_rules_LDADD = \
>  # plugin: u-blox
>  ################################################################################
> 
> +dist_udevrules_DATA += ublox/77-mm-ublox-port-types.rules
> +
>  PLUGIN_UBLOX_COMPILER_FLAGS = \
>  	-I$(top_srcdir)/plugins/ublox \
>  	-I$(top_builddir)/plugins/ublox \
> diff --git a/plugins/ublox/77-mm-ublox-port-types.rules b/plugins/ublox/77-mm-ublox-port-types.rules
> new file mode 100644
> index 00000000..0c5b0961
> --- /dev/null
> +++ b/plugins/ublox/77-mm-ublox-port-types.rules
> @@ -0,0 +1,20 @@
> +# do not edit this file, it will be overwritten on update
> +ACTION!="add|change|move", GOTO="mm_ublox_port_types_end"
> +SUBSYSTEMS=="usb", ATTRS{idVendor}=="1546", GOTO="mm_ublox_port_types"
> +GOTO="mm_ublox_port_types_end"
> +
> +LABEL="mm_ublox_port_types"
> +
> +SUBSYSTEMS=="usb", ATTRS{bInterfaceNumber}=="?*", ENV{.MM_USBIFNUM}="$attr{bInterfaceNumber}"
> +
> +# Toby-L4 port types
> +#  ttyACM0 (if #2): secondary
> +#  ttyACM1 (if #4): debug port (ignore)
> +#  ttyACM2 (if #6): primary
> +#  ttyACM3 (if #8): AT port for FOTA (ignore)
> +ATTRS{idVendor}=="1546", ATTRS{idProduct}=="1010", ENV{.MM_USBIFNUM}=="02", ENV{ID_MM_UBLOX_SECONDARY_PORT}="1"
> +ATTRS{idVendor}=="1546", ATTRS{idProduct}=="1010", ENV{.MM_USBIFNUM}=="04", ENV{ID_MM_PORT_IGNORE}="1"
> +ATTRS{idVendor}=="1546", ATTRS{idProduct}=="1010", ENV{.MM_USBIFNUM}=="06", ENV{ID_MM_UBLOX_PRIMARY_PORT}="1"
> +ATTRS{idVendor}=="1546", ATTRS{idProduct}=="1010", ENV{.MM_USBIFNUM}=="08", ENV{ID_MM_PORT_IGNORE}="1"
> +
> +LABEL="mm_ublox_port_types_end"
> \ No newline at end of file
> diff --git a/plugins/ublox/mm-plugin-ublox.c b/plugins/ublox/mm-plugin-ublox.c
> index 6ebd8711..13d95816 100644
> --- a/plugins/ublox/mm-plugin-ublox.c
> +++ b/plugins/ublox/mm-plugin-ublox.c
> @@ -59,6 +59,34 @@ create_modem (MMPlugin     *self,
>                                                          product));
>  }
> 
> +static gboolean
> +grab_port (MMPlugin     *self,
> +           MMBaseModem  *modem,
> +           MMPortProbe  *probe,
> +           GError      **error)
> +{
> +    MMPortSerialAtFlag pflags = MM_PORT_SERIAL_AT_FLAG_NONE;
> +    MMKernelDevice *port;
> +    MMPortType port_type;
> +
> +    port_type = mm_port_probe_get_port_type (probe);
> +    port = mm_port_probe_peek_port (probe);
> +
> +    if (mm_kernel_device_get_property_as_boolean (port, "ID_MM_UBLOX_PRIMARY_PORT")) {
> +        mm_dbg ("(%s/%s)' port flagged as primary",
> +                mm_port_probe_get_port_subsys (probe),
> +                mm_port_probe_get_port_name (probe));
> +        pflags = MM_PORT_SERIAL_AT_FLAG_PRIMARY;
> +    } else if (mm_kernel_device_get_property_as_boolean (port, "ID_MM_UBLOX_SECONDARY_PORT")) {
> +        mm_dbg ("(%s/%s) port flagged as secondary",
> +                mm_port_probe_get_port_subsys (probe),
> +                mm_port_probe_get_port_name (probe));
> +        pflags = MM_PORT_SERIAL_AT_FLAG_SECONDARY;
> +    }
> +
> +    return mm_base_modem_grab_port (modem, port, port_type, pflags, error);
> +}
> +
>  /*****************************************************************************/
> 
>  G_MODULE_EXPORT MMPlugin *
> @@ -90,4 +118,5 @@ mm_plugin_ublox_class_init (MMPluginUbloxClass *klass)
>      MMPluginClass *plugin_class = MM_PLUGIN_CLASS (klass);
> 
>      plugin_class->create_modem = create_modem;
> +    plugin_class->grab_port    = grab_port;
>  }
> --
> 2.14.1
> 


-- 
Aleksander
https://aleksander.es


More information about the ModemManager-devel mailing list