Re: [PATCH BlueZ] mesh/meshctl: Exit cleanly if start up fails

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Luiz,

On Mon, 2018-03-26 at 16:31 +0300, Luiz Augusto von Dentz wrote:
> Hi Inga,
> 
> On Sat, Mar 24, 2018 at 4:33 AM, Inga Stotland <inga.stotland@intel.c
> om> wrote:
> > When failing to start meshctl due to invalid input configuration,
> > release bt_shell resources prior to exit.
> 
> 
> Similar response as to Eramoto's patch, if the tool is going to exit
> there is no need to free up the resources, the exit status is still
> useful but that is a different matter. Or perhaps we just want to
> avoid false positives with static analyzers?
> 

My motivation for this patch was quite simple: if the program exits
after bt_shell_init() has ben called but prior to calling bt_shell_run,
bash shell is all messed up (at least on my system) after that.

> 
> > ---
> >  mesh/main.c | 14 +++++++++-----
> >  1 file changed, 9 insertions(+), 5 deletions(-)
> > 
> > diff --git a/mesh/main.c b/mesh/main.c
> > index d991c9f8c..d0f71c2d9 100644
> > --- a/mesh/main.c
> > +++ b/mesh/main.c
> > @@ -1930,11 +1930,11 @@ int main(int argc, char *argv[])
> >         mesh_local_config_filename = g_malloc(len +
> > strlen("local_node.json")
> >                                                                    
> >      + 2);
> >         if (!mesh_local_config_filename)
> > -               exit(1);
> > +               goto fail;
> > 
> >         mesh_prov_db_filename = g_malloc(len +
> > strlen("prov_db.json") + 2);
> >         if (!mesh_prov_db_filename) {
> > -               exit(1);
> > +               goto fail;
> >         }
> > 
> >         sprintf(mesh_local_config_filename, "%s", mesh_config_dir);
> > @@ -1950,7 +1950,7 @@ int main(int argc, char *argv[])
> >         if (!prov_db_read_local_node(mesh_local_config_filename,
> > true)) {
> >                 g_printerr("Failed to parse local node
> > configuration file %s\n",
> >                         mesh_local_config_filename);
> > -               exit(1);
> > +               goto fail;
> >         }
> > 
> >         sprintf(mesh_prov_db_filename, "%s", mesh_config_dir);
> > @@ -1965,7 +1965,7 @@ int main(int argc, char *argv[])
> >         if (!prov_db_read(mesh_prov_db_filename)) {
> >                 g_printerr("Failed to parse provisioning database
> > file %s\n",
> >                         mesh_prov_db_filename);
> > -               exit(1);
> > +               goto fail;
> >         }
> > 
> >         dbus_conn = g_dbus_setup_bus(DBUS_BUS_SYSTEM, NULL, NULL);
> > @@ -2001,5 +2001,9 @@ int main(int argc, char *argv[])
> >         g_list_free(service_list);
> >         g_list_free_full(ctrl_list, proxy_leak);
> > 
> > -       return 0;
> > +       return EXIT_SUCCESS;
> > +
> > +fail:
> > +       bt_shell_cleanup();
> > +       return EXIT_FAILURE;
> >  }
> > --
> > 2.13.6
> > 
> > --
> > To unsubscribe from this list: send the line "unsubscribe linux-
> > bluetooth" in
> > the body of a message to majordomo@xxxxxxxxxxxxxxx
> > More majordomo info at  http://vger.kernel.org/majordomo-info.html
> 
> 
> 

Attachment: smime.p7s
Description: S/MIME cryptographic signature


[Index of Archives]     [Bluez Devel]     [Linux Wireless Networking]     [Linux Wireless Personal Area Networking]     [Linux ATH6KL]     [Linux USB Devel]     [Linux Media Drivers]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Big List of Linux Books]

  Powered by Linux