<div dir="ltr"><div>Hi,</div><div>Thank you for replied so quick.</div><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">> I'm now developing my application with ModemManager.<br>
> I want to add a feature that can directly assign which plugin to use for my modem. Instead of using the filter to match appropriate plugin.<br>
><br>
<br>
I'm not totally sure we'd like to support this, truth be told. The<br>
different available plugins exist to handle different available<br>
devices. There should be no device that is "better" managed by a<br>
different plugin than the one ModemManager thinks is best; at the end<br>
ModemManager knows what each plugin can do. A different thing would be<br>
the "generic" plugin that is used as fallback if none other applies<br>
better; in this case, the solution is to implement a new plugin for<br>
the new device.<br></blockquote><div><br></div>Sorry that I didn't say it clearly. <br><div>ModemManager is a general tool. One plugin can support many kinds of modems.</div><div>

I'm afraid that my 

optimization

for one single modem may affects other modem supported by the plugin.</div><div>So I separated it in my current development process.</div><div><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
> This is because I am integrating a modem to a device. And I have developed my own plugin for the modem with some optimization.<br>
<br>
Did you take an already existing plugin and update it? If so, you<br>
should keep your own build of ModemManager and just patch the existing<br>
plugin.<br>
What does your own plugin do? Is it for a completely new device?<br>
Please remember that there is no real guarantee that a plugin<br>
developed out-of-tree will be compatible between different MM<br>
versions...<br></blockquote><div><br></div><div>Can I ask that if I finally have some patches for a plugin.</div><div>How can I push them to ModemManager?</div><div>Should I send the patch to this mailing-list or a merge request?</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
> In this situation, I already know which plugin to use for my modem. Currently I use a simple way to achieve. I create a udev tag "ID_MM_SUGGESTED_PLUGIN", it's usage is the same as "ID_MM_PHYSDEV_UID". Once the device is detected with this tag, I'll set it as the suggested plugin.<br>
> I posted my branch here: <a href="https://gitlab.freedesktop.org/kenchou0731/ModemManager/-/commit/117c9dcf655007ed57a4a248856df1f4b47bd814" rel="noreferrer" target="_blank">https://gitlab.freedesktop.org/kenchou0731/ModemManager/-/commit/117c9dcf655007ed57a4a248856df1f4b47bd814</a><br>
><br>
<br>
We shouldn't let users select the plugin that way I'm afraid. I don't<br>
think that's a sane approach for a general use. If you're building<br>
your own system with always the same kind of modem, why don't you just<br>
install that single plugin only? I've done that kind of setup for<br>
several customers and it have worked quite well. Moreover, in MM git<br>
master and the new 1.14 release soon, you will be able to select at<br>
configure time which plugins you want to build and install.<br></blockquote><div><br></div><div>Yes, to just install the single plugin is a good solution.</div><div>I'm glad to hear that 

new 1.14 release will have the option to configure which plugins you want to build and install.</div><div>It's helpful for me.</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
> Furthermore, I want to do some enhancement for this.<br>
> My application will sometimes need to reset modem (for changing USB configs or changing carrier profile). ModemManager will do the filter for finding plugin for every ports of the modem. This procedure took about 1 second with the debug log enabled. And it may took longer if ModemManager supports more and more plugins in the future.<br>
> I think this procedure can be skipped if I'm sure that which plugin to use. And I can reduce the downtime of modem being reset.<br>
<br>
I really don't think this is an issue, at least if the plugins are<br>
correctly setup. The plugin selection has several steps; for plugins<br>
based on USB like yours, the per-VID/PID filter rule is a simple int<br>
comparison that is very very quick to decide whether a plugin is<br>
expected for a device or not. Even if we have 100 plugins, the per-VID<br>
filter that applies to most of them would make the process very very<br>
quick. I wouldn't attempt to optimize this very much because it truly<br>
should be very very quick. For other filter decisions it may take some<br>
more time, e.g. if it needs to do AT vendor probing for RS232 modems,<br>
but that is totally understandable because there is no better option.<br></blockquote><div> </div><div>Understand. I don't think this should be an issue for ModemManager.</div><div>I'm just thinking that how can I reduce the downtime for modem during reset.</div><div>And I'll try it with only install the single plugin. Thank you!</div><div><br></div>Best regards,<br><div>Ken </div></div></div>