19 |
|
#include "func.h" |
20 |
|
#include "bsdf.h" |
21 |
|
|
22 |
+ |
char *shm_boundary = NULL; /* boundary of shared memory */ |
23 |
|
|
24 |
+ |
|
25 |
|
/* KEEP THIS ROUTINE CONSISTENT WITH THE DIFFERENT OBJECT FUNCTIONS! */ |
26 |
|
|
27 |
|
|
124 |
|
case MAT_METAL2: /* anisotropic metal */ |
125 |
|
getfunc(op, 3, 0x7, 1); |
126 |
|
return(1); |
127 |
+ |
case MAT_WGMDF: /* WGMDfunc material */ |
128 |
+ |
getfunc(op, 12, 0xEEE, 1); |
129 |
+ |
return(1); |
130 |
|
case MAT_BRTDF: /* BRDTfunc material */ |
131 |
|
getfunc(op, 9, 0x3f, 0); |
132 |
|
return(1); |
179 |
|
/* note that nobjects may change during loop */ |
180 |
|
for (on = 0; on < nobjects; on++) |
181 |
|
load_os(objptr(on)); |
182 |
+ |
} |
183 |
+ |
|
184 |
+ |
|
185 |
+ |
void |
186 |
+ |
cow_memshare(void) /* set up copy-on-write memory sharing */ |
187 |
+ |
{ |
188 |
+ |
if (shm_boundary != NULL) |
189 |
+ |
return; /* assume we're good */ |
190 |
+ |
|
191 |
+ |
preload_objs(); /* preload auxiliary data */ |
192 |
+ |
/* set shared memory boundary */ |
193 |
+ |
shm_boundary = (char *)malloc(16); |
194 |
+ |
strcpy(shm_boundary, "SHM_BOUNDARY"); |
195 |
+ |
} |
196 |
+ |
|
197 |
+ |
|
198 |
+ |
void |
199 |
+ |
cow_doneshare(void) /* clear memory sharing boundary */ |
200 |
+ |
{ |
201 |
+ |
if (shm_boundary == NULL) |
202 |
+ |
return; |
203 |
+ |
/* clear shared memory boundary */ |
204 |
+ |
free((void *)shm_boundary); |
205 |
+ |
shm_boundary = NULL; |
206 |
|
} |