<div dir="ltr"><div dir="ltr"><div>Sorry for the late reply,</div><div><br></div><div>I completely understand why there may be concerns at editing such critical code for a use case that is not very common.</div><div><br></div><div>Unfortunately my current situation requires renaming the interfaces. Multiple modems may take turns being 'selected' (having the interface renamed) to pass traffic. I hope to remove that need one day, but until then I will need this patch.</div><div><br></div><div>Even if this is an uncommon problem, I still think this change (or at least my approach) could be useful to pull into ModemManager mainline. Yes, people don't rename interfaces often, but it is something that Linux/udev support, these events effectively breaks the Modem object lifecycle in ModemManager (which makes ModemManager look buggy), the log messages that are printed out do not make it clear that renaming the interface caused it (it took my a long time to figure it out), and I have not seen any piece of documentation warning that renaming any interface managed by ModemManager is unsupported.</div><div><br></div><div>You do bring up an interesting point I had missed: what if someone renamed a control interface? My code currently would not catch that, but maybe it should!</div><div><br></div>ModemManager handles tons of events and states for modems and all the weird things they can do. If a user could do something with the ModemManager API that caused strange errors like I described, the issue would be fixed in the driver/etc. <br><div><br>Linux Interfaces can be renamed using the Linux API, and while they are renamed, ModemManager is in a precarious state until the interface is changed back to its original name. Removing or resetting the modem in that precarious state will cause ModemManager to act strangely for that modem until it is removed again with the original interface name (which could be a problem if another modem was added while the interface was renamed). And linux+udev gives us all the tools to handle these known and supported events. I personally think these are enough reasons to address this behavior.</div><div><br></div><div><div>I see this as an issue of stability, reliability, and resiliency. Even if this behavior is rarely encountered, I believe there are substantial reasons to fix it. That does not mean that my code is the best way to do it. If you end up agreeing that this behavior should be fixed, I will make revisions to address your concerns.<br></div></div><div><br></div><div>To the complexity of my code, I tried to made it pretty straight forward and self contained. When a rename event happens, find the Modem object associated with the old device name, remove the old name from the modem, and add the new name. I could make the replacement logic into a function to keep the code more readable if you would prefer.<br></div><br><div>You mention opening the door to more complex interactions, and that is interesting. If I don't correctly handle the udev events, then I am not really fixing anything!</div><div><br></div><div> I just looked up all of the udev event types: <b>add</b>, <b>remove</b>, <b>change</b>, <b>move</b>, <b>online</b>, <b>offline</b>, <b>bind</b>, and <b>unbind</b>.</div><div><br></div><div>ModemManager already has support for <b>add</b>, <b>remove</b>, <b>change</b> (kind of, more on that later), and with my patch <b>move</b> (I would argue that the upstream version of the move handler was incorrect). <br></div><div><br></div><div>The <b>online</b> and <b>offline</b> events are supposedly for things like a network interface coming up or going down, so I do not think these events will be relevant to ModemManager at all. The <b>bind</b> and <b>unbind</b> events are for when drivers are attached or detached from the device, which I also believe is useless to ModemManager and could not affect anything with the Modem lifecycle.</div><div><br></div><div>But the <b>change</b> event is interesting. I am getting contradicting descriptions from different sources about <b>change</b> vs <b>move</b>. Perhaps you are right that this could cause similar issues. I will probably need to rework this to properly handle both in case <b>change</b> can be triggered in a rename, but either way, more research is required. </div><div><br></div><div>I may also be double handling <b>move</b>, which could be handled more gracefully.</div><div><br></div><div>I will try to fix these up in the coming weeks or months as time allows. I welcome feedback and ideas even before I finish the patch.</div><div><br></div><div>Thanks as usual to the ModemManager team for building such a useful tool,<br></div><div>Jessy Diamond Exum<br></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Tue, Jan 30, 2024 at 2:44 AM Aleksander Morgado <<a href="mailto:aleksandermj@chromium.org" target="_blank">aleksandermj@chromium.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div>Hey,</div><div><br></div><div>> In my application, I use ModemManager to connect the modem, and then I rename the network interface to a special name that is required by another part of my system (and change the name back if the modem disconnects).</div><div><br></div><div>Is it not possible to rename the interface before even MM tries to grab the port?</div><div><br></div><div>We could support a patch like yours, but it seems overly complicated and may open the door to even more complex interactions, e.g. what if someone comes with the idea of renaming the control port instead of the net port.</div><div>I'm sure it's technically possible to do all that, but not sure how much benefit it will bring.</div><div><br></div><span class="gmail_signature_prefix">-- </span><br><div dir="ltr" class="gmail_signature"><div dir="ltr"><div>Aleksander</div></div></div></div>
</blockquote></div></div>