ViewVC Help
View File | Revision Log | Show Annotations | Download File | Root Listing
root/radiance/ray/src/rt/rc3.c
(Generate patch)

Comparing ray/src/rt/rc3.c (file contents):
Revision 2.11 by greg, Sat Jun 16 17:30:13 2012 UTC vs.
Revision 2.14 by greg, Wed Jun 20 21:36:34 2012 UTC

# Line 6 | Line 6 | static const char RCSid[] = "$Id$";
6   * Controlling process for multiple children
7   */
8  
9 + #include <signal.h>
10   #include "rcontrib.h"
11   #include "platform.h"
12   #include "rtprocess.h"
# Line 315 | Line 316 | in_rchild()
316  
317   /* Close child processes */
318   void
319 < end_children()
319 > end_children(int immed)
320   {
321          int     status;
322          
323          while (nchild > 0) {
324                  nchild--;
325 <                if ((status = close_process(&kida[nchild].pr)) > 0) {
325 >                if (immed)              /* error mode -- quick exit */
326 >                        kill(kida[nchild].pr.pid, SIGKILL);
327 >                if ((status = close_process(&kida[nchild].pr)) > 0 && !immed) {
328                          sprintf(errmsg,
329                                  "rendering process returned bad status (%d)",
330                                          status);
# Line 537 | Line 540 | feeder_loop()
540                  lastray += kida[i].nr = ninq;
541                  ninq = 0;
542          }
543 <        for (i = nchild; i--; ) {               /* get results */
544 <                close(kida[i].pr.w);
543 >        memset(orgdir, 0, sizeof(FVECT)*2);     /* get results */
544 >        for (i = nchild; i--; ) {
545 >                writebuf(kida[i].pr.w, (char *)orgdir, sizeof(FVECT)*2);
546                  queue_results(i);
547          }
548          if (recover)                            /* and from before? */
549                  queue_modifiers();
550 <        end_children();                         /* free up file descriptors */
550 >        end_children(0);                        /* free up file descriptors */
551          for (i = 0; i < nmods; i++)
552                  mod_output(out_bq->mca[i]);     /* output accumulated record */
553          end_record();

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines