Diff for /ansh/src/proc.c between versions 1.1.1.1.2.1 and 1.5

version 1.1.1.1.2.1, 2011/10/13 16:08:52 version 1.5, 2015/05/19 23:25:30
Line 12  terms: Line 12  terms:
 All of the documentation and software included in the ELWIX and AITNET  All of the documentation and software included in the ELWIX and AITNET
 Releases is copyrighted by ELWIX - Sofia/Bulgaria <info@elwix.org>  Releases is copyrighted by ELWIX - Sofia/Bulgaria <info@elwix.org>
   
Copyright 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011Copyright 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012, 2013
         by Michael Pounov <misho@elwix.org>.  All rights reserved.          by Michael Pounov <misho@elwix.org>.  All rights reserved.
   
 Redistribution and use in source and binary forms, with or without  Redistribution and use in source and binary forms, with or without
Line 49  SUCH DAMAGE. Line 49  SUCH DAMAGE.
   
   
 struct tagProc *  struct tagProc *
InitProc(int h, struct sockaddr *sa, u_short id, int len)InitProc(int h, sockaddr_t *sa, u_short id, int len)
 {  {
         struct tagProc *proc;          struct tagProc *proc;
   
         FTRACE(5);          FTRACE(5);
   
        proc = malloc(sizeof(struct tagProc));        proc = e_malloc(sizeof(struct tagProc));
         if (!proc) {          if (!proc) {
                 ERR("Not enough memory #%d - %s", errno, strerror(errno));                  ERR("Not enough memory #%d - %s", errno, strerror(errno));
                 return NULL;                  return NULL;
Line 64  InitProc(int h, struct sockaddr *sa, u_short id, int l Line 64  InitProc(int h, struct sockaddr *sa, u_short id, int l
         proc->proc_sock = h;          proc->proc_sock = h;
         proc->proc_id = id;          proc->proc_id = id;
         if (sa)          if (sa)
                memcpy(&proc->proc_cli, sa, sizeof(struct sockaddr));                memcpy(&proc->proc_cli, sa, sizeof(sockaddr_t));
   
         proc->proc_blen = len;          proc->proc_blen = len;
        proc->proc_buf_[0] = malloc(proc->proc_blen);        proc->proc_buf_[0] = e_malloc(proc->proc_blen);
         if (!proc->proc_buf_[0]) {          if (!proc->proc_buf_[0]) {
                free(proc);                e_free(proc);
                 proc = NULL;                  proc = NULL;
         }          }
        proc->proc_buf_[1] = malloc(proc->proc_blen);        proc->proc_buf_[1] = e_malloc(proc->proc_blen);
         if (!proc->proc_buf_[1]) {          if (!proc->proc_buf_[1]) {
                free(proc->proc_buf_[0]);                e_free(proc->proc_buf_[0]);
                free(proc);                e_free(proc);
                 proc = NULL;                  proc = NULL;
         }          }
   
Line 105  FreeProc(struct tagProc ** __restrict proc) Line 105  FreeProc(struct tagProc ** __restrict proc)
                 return;                  return;
   
         if ((*proc)->proc_buf_[1])          if ((*proc)->proc_buf_[1])
                free((*proc)->proc_buf_[1]);                e_free((*proc)->proc_buf_[1]);
         if ((*proc)->proc_buf_[0])          if ((*proc)->proc_buf_[0])
                free((*proc)->proc_buf_[0]);                e_free((*proc)->proc_buf_[0]);
        free(*proc);        e_free(*proc);
         *proc = NULL;          *proc = NULL;
 }  }
   
Line 121  DestroyProc() Line 121  DestroyProc()
                 SLIST_REMOVE_HEAD(&pH, proc_next);                  SLIST_REMOVE_HEAD(&pH, proc_next);
                 FreeProc(&proc);                  FreeProc(&proc);
         }          }
   }
   
   
   int
   stopProcess(sched_root_task_t * __restrict root, proc_head_t * __restrict h, pid_t pid, sched_task_func_t func)
   {
           struct tagProc *p;
   
           FTRACE(3);
   
           SLIST_FOREACH(p, h, proc_next)
                   if (p->proc_pid == pid) {
                           break;
                   }
           VERB(3) LOG("pid=%d found=%p\n", pid, p);
           if (!p)
                   return 1;
   
           ioFreePTY(p->proc_pty, p->proc_ttyname);
           if (p->proc_pty)
                   schedCancelby(root, taskMAX, CRITERIA_FD, (void*) ((intptr_t) p->proc_pty), NULL);
   
           p->proc_pty = 0;
           p->proc_pid = 0;
           p->proc_seq = 0;
           p->proc_flg = ANSH_FLG_EOF;
           p->proc_rlen_[FD2NET] = 0;
   
           schedCallOnce(root, func, p, p->proc_sock, NULL, 0);
           return 0;
 }  }

Removed from v.1.1.1.1.2.1  
changed lines
  Added in v.1.5


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>