]> git.ipfire.org Git - thirdparty/openvpn.git/commitdiff
write pid file immediately after daemonizing
authorSteffan Karger <steffan@karger.me>
Thu, 18 Jun 2015 22:08:45 +0000 (00:08 +0200)
committerGert Doering <gert@greenie.muc.de>
Sun, 21 Jun 2015 12:27:30 +0000 (14:27 +0200)
Since we split daemonizing from changing directory in commit da9b292
(f025de005d719201a69ad0313d545a1ddd244752 in release/2.3), we can
now simply write the pid file immediately after daemonizing.

This not only fixes the bug reported in trac #563, but also further
simplifies the code.

trac #563

Signed-off-by: Steffan Karger <steffan@karger.me>
Acked-by: Gert Doering <gert@greenie.muc.de>
Message-Id: <1434665325-3225-1-git-send-email-steffan@karger.me>
URL: http://article.gmane.org/gmane.network.openvpn.devel/9793
Signed-off-by: Gert Doering <gert@greenie.muc.de>
src/openvpn/init.c
src/openvpn/misc.c
src/openvpn/misc.h
src/openvpn/openvpn.c
src/openvpn/openvpn.h

index 3daf5a46efac0972c60d6384ac3109a086f96fa8..13f5612d1933b69e0f16159808b8f701965d97c1 100644 (file)
@@ -2764,16 +2764,10 @@ do_init_first_time (struct context *c)
        platform_group_get (c->options.groupname, &c0->platform_state_group) |
        platform_user_get (c->options.username, &c0->platform_state_user);
 
-      /* get --writepid file descriptor */
-      get_pid_file (c->options.writepid, &c0->pid_state);
-
       /* perform postponed chdir if --daemon */
       if (c->did_we_daemonize && c->options.cd_dir == NULL)
        platform_chdir("/");
 
-      /* save process ID in a file */
-      write_pid (&c0->pid_state);
-
       /* should we change scheduling priority? */
       platform_nice (c->options.nice);
     }
index 5627cb9eaec4b4b423ebbc6e32a460a2e97566fa..4fdbf1753ee8cbb6427f77cee0f55749b12a9590 100644 (file)
@@ -127,30 +127,21 @@ run_up_down (const char *command,
   gc_free (&gc);
 }
 
-/* Get the file we will later write our process ID to */
+/* Write our PID to a file */
 void
-get_pid_file (const char* filename, struct pid_state *state)
+write_pid (const char *filename)
 {
-  CLEAR (*state);
   if (filename)
     {
-      state->fp = platform_fopen (filename, "w");
-      if (!state->fp)
+      unsigned int pid = 0;
+      FILE *fp = platform_fopen (filename, "w");
+      if (!fp)
        msg (M_ERR, "Open error on pid file %s", filename);
-      state->filename = filename;
-    }
-}
 
-/* Write our PID to a file */
-void
-write_pid (const struct pid_state *state)
-{
-  if (state->filename && state->fp)
-    {
-      unsigned int pid = platform_getpid (); 
-      fprintf(state->fp, "%u\n", pid);
-      if (fclose (state->fp))
-       msg (M_ERR, "Close error on pid file %s", state->filename);
+      pid = platform_getpid ();
+      fprintf(fp, "%u\n", pid);
+      if (fclose (fp))
+       msg (M_ERR, "Close error on pid file %s", filename);
     }
 }
 
index 5fe085e916e6d3a6aad9eae3e0578d95b0bd7df4..7c2691257b0383dee3e9b94fd93e40688caa7f29 100644 (file)
@@ -73,14 +73,7 @@ void run_up_down (const char *command,
                  const char *script_type,
                  struct env_set *es);
 
-/* workspace for get_pid_file/write_pid */
-struct pid_state {
-  FILE *fp;
-  const char *filename;
-};
-
-void get_pid_file (const char* filename, struct pid_state *state);
-void write_pid (const struct pid_state *state);
+void write_pid (const char *filename);
 
 /* check file protections */
 void warn_if_group_others_accessible(const char* filename);
index 2f327f36706d55fe60d9b873ff325afc68b40742..00bd5703c36ec6ca7ddce4f4f4af942dd13ce6a1 100644 (file)
@@ -231,7 +231,10 @@ openvpn_main (int argc, char *argv[])
          
          /* become a daemon if --daemon */
          if (c.first_time)
-           c.did_we_daemonize = possibly_become_daemon (&c.options);
+           {
+             c.did_we_daemonize = possibly_become_daemon (&c.options);
+             write_pid (c.options.writepid);
+           }
 
 #ifdef ENABLE_MANAGEMENT
          /* open management subsystem */
index 9ab50b80b5ea7dcc814d0bd4d91cefc0bc066a89..ef7ca1d027fe66c3e2f8bf3e0afa99a637660a84 100644 (file)
@@ -134,9 +134,6 @@ struct context_persist
  */
 struct context_0
 {
-  /* workspace for get_pid_file/write_pid */
-  struct pid_state pid_state;
-
   /* workspace for --user/--group */
   bool uid_gid_specified;
   bool uid_gid_set;