SIONlib  1.6.2
Scalable I/O library for parallel access to task-local files
sion_filedesc.c
Go to the documentation of this file.
1 /****************************************************************************
2 ** SIONLIB http://www.fz-juelich.de/jsc/sionlib **
3 *****************************************************************************
4 ** Copyright (c) 2008-2016 **
5 ** Forschungszentrum Juelich, Juelich Supercomputing Centre **
6 ** **
7 ** See the file COPYRIGHT in the package base directory for details **
8 ****************************************************************************/
9 
14 #include <stdlib.h>
15 #include <stdio.h>
16 #include <string.h>
17 #include <time.h>
18 #include <assert.h>
19 
20 #include "sion.h"
21 #include "sion_debug.h"
22 #include "sion_internal.h"
23 #include "sion_filedesc.h"
24 #include "sion_keyvalue_keymngr.h"
25 
26 
27 #define DFUNCTION "_sion_init_filedesc"
28 
35 {
36 
37  int rc = SION_SUCCESS;
38 
39  if (sion_filedesc == NULL) {
40  return(_sion_errorprint(SION_NOT_SUCCESS,_SION_ERROR_RETURN, DFUNCTION ": cannot initalized, data structure is not allocated, aborting ...\n"));
41  }
42  sion_filedesc->fileptr = NULL;
43  sion_filedesc->fname = NULL;
44  sion_filedesc->sid = -1;
45  sion_filedesc->rank = -1;
46  sion_filedesc->lrank = -1;
47  sion_filedesc->globalrank = -1;
48  sion_filedesc->ntasks = -1;
49  sion_filedesc->state = SION_FILESTATE_UNKNOWN;
50  sion_filedesc->mode = SION_FILEMODE_UNKNOWN;
51  sion_filedesc->dup_mode = SION_DESCSTATE_ORIG;
52  sion_filedesc->dup_sel_rank = 0;
53  sion_filedesc->dup_sel_key = 0;
54  sion_filedesc->endianness = -1;
55  sion_filedesc->swapbytes = 0;
56  sion_filedesc->fileversion = SION_FILEFORMAT_VERSION;
57  sion_filedesc->filesionversion = 1000 * SION_MAIN_VERSION + SION_SUB_VERSION;
58  sion_filedesc->filesionpatchlevel = SION_SUB_VERSION;
59  sion_filedesc->fsblksize = -1; /* fs block size */
60  sion_filedesc->lastchunknr = -1; /* number of current block */
61  sion_filedesc->maxchunks = -1;
62  sion_filedesc->maxusedchunks = -1;
63 
64  sion_filedesc->startpos = -1;
65  sion_filedesc->chunksize = -1;
66  sion_filedesc->chunksize_req = -1;
67  sion_filedesc->blocksizes = NULL; /* vector of written bytes in each block for current task */
68 
69  sion_filedesc->globalskip = -1; /* number of bytes to skip to next block of same processor */
70  sion_filedesc->end_of_header = -1;
71  sion_filedesc->start_of_varheader = -1;
72  sion_filedesc->start_of_data = -1;
73 
74  sion_filedesc->all_chunksizes = NULL; /* only used if sion is opened from a single task for read */
75  sion_filedesc->all_globalranks = NULL; /* only used if sion is opened from a single task for read */
76  sion_filedesc->all_localranks = NULL; /* only used if sion is opened in mapped mode */
77  sion_filedesc->all_startpointers = NULL; /* only used if sion is opened from a single task for read */
78 
79  sion_filedesc->all_currentpos = NULL; /* only used if sion is opened from a single task for write */
80  sion_filedesc->all_currentblocknr = NULL; /* only used if sion is opened from a single task for write */
81 
82  sion_filedesc->all_coll_collector = NULL; /* only used on rank 0 if usecoll=1 */
83  sion_filedesc->all_coll_collsize = NULL; /* only used on rank 0 if usecoll=1 */
84  sion_filedesc->all_coll_capability = NULL; /* only used on rank 0 if usecoll=1 */
85 
86  sion_filedesc->all_blockcount = NULL; /* size, only used if sion is opened from a single task for read */
87  sion_filedesc->all_blocksizes = NULL; /* size*maxchunks, only used if sion is opened from a single task for read */
88 
89  sion_filedesc->currentpos = -1; /* only used if opened for one rank, reading */
90  sion_filedesc->currentblocknr = -1; /* only used if opened for one rank, reading */
91  sion_filedesc->debug = -1; /* 0 or 1 for debugging */
92 
93  sion_filedesc->nfiles = -1;
94  sion_filedesc->filenumber = -1;
95  sion_filedesc->mapping_size = -1;
96  sion_filedesc->mapping = NULL;
97 
98  sion_filedesc->ntotaltasksinfile = -1;
99  sion_filedesc->nlocaltasksinfile = -1;
100  sion_filedesc->filemanagedbytask = -1;
101 
102  sion_filedesc->ntasks = -1;
103 
104  sion_filedesc->multifiles = NULL;
105 
106  sion_filedesc->flag1 = _SION_FLAG1_NONE;
107  sion_filedesc->flag2 = _SION_FLAG2_NONE;
108  sion_filedesc->prefix = NULL;
109  sion_filedesc->newfname = NULL;
110 
111  sion_filedesc->dataptr = NULL;
112  sion_filedesc->keyvalptr = NULL;
113 
114  sion_filedesc->keyvalmode = SION_KEYVAL_NONE;
115  sion_filedesc->keyvalptr = NULL;
116  sion_filedesc->all_keyvalptr = NULL;
117 
118  sion_filedesc->fpbuffer = NULL;
119  sion_filedesc->fpbuffer_size = -1;
120 
121  sion_filedesc->usecache = 0;
122  sion_filedesc->cachesize = -1;
123  sion_filedesc->cacheid = -1;
124  if(SION_CACHE_FNLEN>0) {
125  sion_filedesc->cachefn[0]='\0';
126  }
127  sion_filedesc->cachemode = SION_CACHE_UNKNOWN;
128  sion_filedesc->cacheptr = NULL;
129 
130  sion_filedesc->usebuffer = 0;
131  sion_filedesc->buffer = NULL;
132  sion_filedesc->buffer_size = -1;
133  sion_filedesc->buffer_ptr = 0;
134 
135  sion_filedesc->compress = 0;
136 
137 
138  sion_filedesc->usecoll = 0;
139  sion_filedesc->collsize = -1;
140  sion_filedesc->collector = -1;
141  sion_filedesc->coll_capability = SION_CAPABILITY_FULL;
142  sion_filedesc->colldebug = 0;
143  sion_filedesc->collcmdused = 0;
144  sion_filedesc->fileptr_exported = 0;
145  sion_filedesc->collmergemode = 0;
146 
147  sion_filedesc->usehints = 0;
148  sion_filedesc->hinttype = SION_HINTS_TYPE_UNKNOWN;
149 
150  return (rc);
151 }
152 #undef DFUNCTION
153 
154 
155 #define DFUNCTION "_sion_alloc_filedesc"
156 
161 {
162  _sion_filedesc *sion_filedesc;
163 
164  sion_filedesc = (_sion_filedesc *) malloc(sizeof(_sion_filedesc));
165  if (sion_filedesc == NULL) {
166  _sion_errorprint(SION_NOT_SUCCESS,_SION_ERROR_RETURN,"cannot allocate filedescriptor structure of size %lu (sion_filedesc), aborting ...\n", (unsigned long) sizeof(sion_filedesc));
167  return(NULL);
168  }
169 
170  return(sion_filedesc);
171 }
172 #undef DFUNCTION
173 
174 
175 #define DFUNCTION "_sion_realloc_filedesc_blocklist"
176 
183 int _sion_realloc_filedesc_blocklist(_sion_filedesc *sion_filedesc, sion_int32 maxchunks)
184 {
185  int rc = SION_SUCCESS;
186  int i;
187  if (sion_filedesc->maxchunks <= 0) {
188  sion_filedesc->blocksizes = (sion_int64 *) malloc(maxchunks * sizeof(sion_int64));
189  if (sion_filedesc->blocksizes == NULL) {
190  return(_sion_errorprint(SION_NOT_SUCCESS,_SION_ERROR_RETURN, DFUNCTION ": cannot allocate temporary memory of size %lu (sion_blocksizes), aborting ...\n",
191  (unsigned long) maxchunks * sizeof(sion_int64)));
192  }
193  for (i = 0; i < maxchunks; i++)
194  sion_filedesc->blocksizes[i] = 0; /* init */
195  sion_filedesc->maxchunks = maxchunks;
196  DPRINTFP((2, DFUNCTION, -1, " alloc for %d chunks\n", maxchunks ));
197  }
198  else {
199  if (sion_filedesc->maxchunks <= maxchunks) {
200  sion_filedesc->blocksizes = (sion_int64 *) realloc(sion_filedesc->blocksizes, maxchunks * sizeof(sion_int64));
201  for (i = sion_filedesc->maxchunks; i < maxchunks; i++)
202  sion_filedesc->blocksizes[i] = 0; /* init */
203  DPRINTFP((2, DFUNCTION, -1, " realloc from %d to %d chunks\n", sion_filedesc->maxchunks, maxchunks ));
204  sion_filedesc->maxchunks = maxchunks;
205  }
206  else {
207  fprintf(stderr, "allocate temporary memory of size %lu (sion_blocksizes) not necessary (allocated size %lu) ...\n",
208  (unsigned long) maxchunks * sizeof(sion_int64), (unsigned long) sion_filedesc->maxchunks * sizeof(sion_int64));
209  DPRINTFP((2, DFUNCTION, -1, "allocate temporary memory of size %lu (sion_blocksizes) not necessary (allocated size %lu) ...\n",
210  (unsigned long) maxchunks * sizeof(sion_int64), (unsigned long) sion_filedesc->maxchunks * sizeof(sion_int64) ));
211  }
212  }
213  return (rc);
214 }
215 #undef DFUNCTION
216 
217 
218 #define DFUNCTION "_sion_alloc_filedesc_all_chunksizes"
219 int _sion_alloc_filedesc_all_chunksizes(_sion_filedesc *sion_filedesc)
220 {
221  int i, rc = SION_SUCCESS;
222  sion_int64 *p;
223 
224  if (sion_filedesc->ntasks<0) {
225  return(_sion_errorprint(SION_NOT_SUCCESS,_SION_ERROR_RETURN, DFUNCTION ": cannot allocate internal arrays ntasks<0, aborting ...\n"));
226  }
227 
228  DPRINTFP((2, DFUNCTION, -1, "enter alloc arrays size=%d (%lu bytes)\n", sion_filedesc->ntasks, (unsigned long) sion_filedesc->ntasks * sizeof(sion_int64)));
229  sion_filedesc->all_chunksizes = p = (sion_int64 *) malloc(sion_filedesc->ntasks * sizeof(sion_int64));
230  if (sion_filedesc->all_chunksizes == NULL) {
231  return(_sion_errorprint(SION_NOT_SUCCESS,_SION_ERROR_RETURN, DFUNCTION ": cannot allocate temporary memory of size %lu (sion_chunksizes), aborting ...\n",
232  (unsigned long) sion_filedesc->ntasks * sizeof(sion_int64)));
233  }
234  for (i = 0; i < sion_filedesc->ntasks; i++) p[i] = -1;
235  return(rc);
236 }
237 #undef DFUNCTION
238 
239 #define DFUNCTION "_sion_alloc_filedesc_all_startpointers"
240 int _sion_alloc_filedesc_all_startpointers(_sion_filedesc *sion_filedesc)
241 {
242  int i, rc = SION_SUCCESS;
243  sion_int64 *p;
244 
245  if (sion_filedesc->ntasks<0) {
246  return(_sion_errorprint(SION_NOT_SUCCESS,_SION_ERROR_RETURN, DFUNCTION ": cannot allocate internal arrays ntasks<0, aborting ...\n"));
247  }
248  sion_filedesc->all_startpointers = p = (sion_int64 *) malloc(sion_filedesc->ntasks * sizeof(sion_int64));
249  if (sion_filedesc->all_startpointers == NULL) {
250  return(_sion_errorprint(SION_NOT_SUCCESS,_SION_ERROR_RETURN, DFUNCTION ": cannot allocate temporary memory of size %lu (sion_all_startpointers), aborting ...\n",
251  (unsigned long) sion_filedesc->ntasks * sizeof(sion_int64)));
252  }
253  for (i = 0; i < sion_filedesc->ntasks; i++) p[i] = -1;
254 
255  return(rc);
256 }
257 #undef DFUNCTION
258 
259 #define DFUNCTION "_sion_alloc_filedesc_all_globalranks"
260 int _sion_alloc_filedesc_all_globalranks(_sion_filedesc *sion_filedesc)
261 {
262  int i, rc = SION_SUCCESS;
263  sion_int64 *p;
264 
265  if (sion_filedesc->ntasks<0) {
266  return(_sion_errorprint(SION_NOT_SUCCESS,_SION_ERROR_RETURN, DFUNCTION ": cannot allocate internal arrays ntasks<0, aborting ...\n"));
267  }
268  sion_filedesc->all_globalranks = p = (sion_int64 *) malloc(sion_filedesc->ntasks * sizeof(sion_int64));
269  if (sion_filedesc->all_globalranks == NULL) {
270  return(_sion_errorprint(SION_NOT_SUCCESS,_SION_ERROR_RETURN, DFUNCTION ": cannot allocate temporary memory of size %lu (sion_all_globalranks), aborting ...\n",
271  (unsigned long) sion_filedesc->ntasks * sizeof(sion_int64)));
272  }
273  for (i = 0; i < sion_filedesc->ntasks; i++) p[i] = -1;
274 
275  return(rc);
276 }
277 #undef DFUNCTION
278 
279 #define DFUNCTION "_sion_alloc_filedesc_all_localranks"
280 int _sion_alloc_filedesc_all_localranks(_sion_filedesc *sion_filedesc)
281 {
282  int i, rc = SION_SUCCESS;
283  sion_int64 *p;
284 
285  if (sion_filedesc->ntasks<0) {
286  return(_sion_errorprint(SION_NOT_SUCCESS,_SION_ERROR_RETURN, DFUNCTION ": cannot allocate internal arrays ntasks<0, aborting ...\n"));
287  }
288  sion_filedesc->all_localranks = p = (sion_int64 *) malloc(sion_filedesc->ntasks * sizeof(sion_int64));
289  if (sion_filedesc->all_localranks == NULL) {
290  return(_sion_errorprint(SION_NOT_SUCCESS,_SION_ERROR_RETURN, DFUNCTION ": cannot allocate temporary memory of size %lu (sion_all_localranks), aborting ...\n",
291  (unsigned long) sion_filedesc->ntasks * sizeof(sion_int64)));
292  }
293  for (i = 0; i < sion_filedesc->ntasks; i++) p[i] = -1;
294 
295  return(rc);
296 }
297 #undef DFUNCTION
298 
299 #define DFUNCTION "_sion_alloc_filedesc_all_keyvalptr"
300 int _sion_alloc_filedesc_all_keyvalptr(_sion_filedesc *sion_filedesc)
301 {
302  int i, rc = SION_SUCCESS;
303  void **p;
304 
305  if (sion_filedesc->ntasks<0) {
306  return(_sion_errorprint(SION_NOT_SUCCESS,_SION_ERROR_RETURN, DFUNCTION ": cannot allocate internal arrays ntasks<0, aborting ...\n"));
307  }
308 
309  DPRINTFP((2, DFUNCTION, -1, "enter alloc arrays size=%d (%lu bytes)\n", sion_filedesc->ntasks, (unsigned long) sion_filedesc->ntasks * sizeof(sion_int64)));
310  sion_filedesc->all_keyvalptr = p = (void *) malloc(sion_filedesc->ntasks * sizeof(void *));
311  if (sion_filedesc->all_keyvalptr == NULL) {
312  return(_sion_errorprint(SION_NOT_SUCCESS,_SION_ERROR_RETURN, DFUNCTION ": cannot allocate temporary memory of size %lu (sion_all_keyvalptr), aborting ...\n",
313  (unsigned long) sion_filedesc->ntasks * sizeof(sion_int64)));
314  }
315  for (i = 0; i < sion_filedesc->ntasks; i++) p[i] = NULL;
316  return(rc);
317 }
318 #undef DFUNCTION
319 
320 
321 #define DFUNCTION "_sion_alloc_filedesc_arrays"
322 
329 {
330  DPRINTFP((2, DFUNCTION, -1, "enter alloc arrays size=%d (%lu bytes)\n", sion_filedesc->ntasks, (unsigned long) sion_filedesc->ntasks * sizeof(sion_int64)));
331 
332  _sion_alloc_filedesc_all_chunksizes(sion_filedesc);
333  _sion_alloc_filedesc_all_startpointers(sion_filedesc);
334  _sion_alloc_filedesc_all_globalranks(sion_filedesc);
335 
336  DPRINTFP((2, DFUNCTION, -1, "leave alloc arrays size=%d\n", sion_filedesc->ntasks));
337  return (1);
338 }
339 #undef DFUNCTION
340 
341 
342 #define DFUNCTION "_sion_free_filedesc_all_chunksizes"
343 int _sion_free_filedesc_all_chunksizes(_sion_filedesc *sion_filedesc)
344 {
345  DPRINTFP((2, DFUNCTION, -1, "enter free arrays\n"));
346  if (sion_filedesc->all_chunksizes != NULL) {
347  free(sion_filedesc->all_chunksizes);
348  sion_filedesc->all_chunksizes=NULL;
349  }
350  DPRINTFP((2, DFUNCTION, -1, "leave free arrays\n"));
351  return (1);
352 }
353 #undef DFUNCTION
354 
355 #define DFUNCTION "_sion_free_filedesc_all_globalranks"
356 int _sion_free_filedesc_all_globalranks(_sion_filedesc *sion_filedesc)
357 {
358  DPRINTFP((2, DFUNCTION, -1, "enter free arrays\n"));
359  if (sion_filedesc->all_globalranks != NULL) {
360  free(sion_filedesc->all_globalranks);
361  sion_filedesc->all_globalranks=NULL;
362  }
363  DPRINTFP((2, DFUNCTION, -1, "leave free arrays\n"));
364  return (1);
365 }
366 #undef DFUNCTION
367 
368 #define DFUNCTION "_sion_free_filedesc_all_startpointers"
369 int _sion_free_filedesc_all_startpointers(_sion_filedesc *sion_filedesc)
370 {
371  DPRINTFP((2, DFUNCTION, -1, "enter free arrays\n"));
372  if (sion_filedesc->all_startpointers != NULL) {
373  free(sion_filedesc->all_startpointers);
374  sion_filedesc->all_startpointers=NULL;
375  }
376  DPRINTFP((2, DFUNCTION, -1, "leave free arrays\n"));
377  return (1);
378 }
379 #undef DFUNCTION
380 
381 #define DFUNCTION "_sion_free_filedesc_all_localranks"
382 int _sion_free_filedesc_all_localranks(_sion_filedesc *sion_filedesc)
383 {
384  DPRINTFP((2, DFUNCTION, -1, "enter free arrays\n"));
385  if (sion_filedesc->all_localranks != NULL) {
386  free(sion_filedesc->all_localranks);
387  sion_filedesc->all_localranks=NULL;
388  }
389  DPRINTFP((2, DFUNCTION, -1, "leave free arrays\n"));
390  return (1);
391 }
392 #undef DFUNCTION
393 
394 #define DFUNCTION "_sion_free_filedesc_all_keyvalptr"
395 int _sion_free_filedesc_all_keyvalptr(_sion_filedesc *sion_filedesc)
396 {
397  int tasknr = 0;
398  DPRINTFP((2, DFUNCTION, -1, "enter free arrays\n"));
399  if (sion_filedesc->all_keyvalptr != NULL) {
400  for(tasknr=0;tasknr<sion_filedesc->ntasks;tasknr++) {
401  if (sion_filedesc->all_keyvalptr[tasknr]) {
402  DPRINTFP((2, DFUNCTION, -1, "free now KEYVALPTR all_keyvalptr[%d] = %x\n",tasknr,sion_filedesc->all_keyvalptr[tasknr]));
403  _sion_keyvalue_keymngr_destroy((_sion_keyvalue_keymngr *)sion_filedesc->all_keyvalptr[tasknr]);
404  }
405  }
406  free(sion_filedesc->all_keyvalptr);
407  sion_filedesc->all_keyvalptr=NULL;
408  }
409  DPRINTFP((2, DFUNCTION, -1, "leave free arrays\n"));
410  return (1);
411 }
412 #undef DFUNCTION
413 
414 #define DFUNCTION "_sion_free_filedesc_arrays"
415 
422 {
423 
424  _sion_free_filedesc_all_chunksizes(sion_filedesc);
425  _sion_free_filedesc_all_globalranks(sion_filedesc);
426  _sion_free_filedesc_all_startpointers(sion_filedesc);
427  return (1);
428 }
429 #undef DFUNCTION
430 
431 
432 #define DFUNCTION "_sion_alloc_filedesc_coll_arrays"
433 
440 {
441  int i;
442  sion_int32 *p;
443 
444  if (sion_filedesc->ntasks<0) {
445  return(_sion_errorprint(SION_NOT_SUCCESS,_SION_ERROR_RETURN, DFUNCTION ": cannot allocate internal arrays ntasks<0, aborting ...\n"));
446  }
447 
448  DPRINTFP((2, DFUNCTION, -1, "enter alloc arrays size=%d (%lu bytes)\n", sion_filedesc->ntasks, (unsigned long) sion_filedesc->ntasks * sizeof(sion_int32)));
449  sion_filedesc->all_coll_collsize = p = (sion_int32 *) malloc(sion_filedesc->ntasks * sizeof(sion_int32));
450  if (sion_filedesc->all_coll_collsize == NULL) {
451  return(_sion_errorprint(SION_NOT_SUCCESS,_SION_ERROR_RETURN, DFUNCTION ": cannot allocate temporary memory of size %lu (sion_all_collsize), aborting ...\n",
452  (unsigned long) sion_filedesc->ntasks * sizeof(sion_int32)));
453  }
454  for (i = 0; i < sion_filedesc->ntasks; i++) p[i] = -1;
455 
456  DPRINTFP((2, DFUNCTION, -1, "enter alloc arrays size=%d (%lu bytes)\n", sion_filedesc->ntasks, (unsigned long) sion_filedesc->ntasks * sizeof(sion_int32)));
457  sion_filedesc->all_coll_collector = p = (sion_int32 *) malloc(sion_filedesc->ntasks * sizeof(sion_int32));
458  if (sion_filedesc->all_coll_collector == NULL) {
459  return(_sion_errorprint(SION_NOT_SUCCESS,_SION_ERROR_RETURN, DFUNCTION ": cannot allocate temporary memory of size %lu (sion_all_collector), aborting ...\n",
460  (unsigned long) sion_filedesc->ntasks * sizeof(sion_int32)));
461  }
462  for (i = 0; i < sion_filedesc->ntasks; i++) p[i] = -1;
463 
464  DPRINTFP((2, DFUNCTION, -1, "enter alloc arrays size=%d (%lu bytes)\n", sion_filedesc->ntasks, (unsigned long) sion_filedesc->ntasks * sizeof(sion_int32)));
465  sion_filedesc->all_coll_capability = p = (sion_int32 *) malloc(sion_filedesc->ntasks * sizeof(sion_int32));
466  if (sion_filedesc->all_coll_capability == NULL) {
467  return(_sion_errorprint(SION_NOT_SUCCESS,_SION_ERROR_RETURN, DFUNCTION ": cannot allocate temporary memory of size %lu (sion_all_capability), aborting ...\n",
468  (unsigned long) sion_filedesc->ntasks * sizeof(sion_int32)));
469  }
470  for (i = 0; i < sion_filedesc->ntasks; i++) p[i] = -1;
471 
472 
473  DPRINTFP((2, DFUNCTION, -1, "leave alloc arrays size=%d\n", sion_filedesc->ntasks));
474  return (1);
475 }
476 #undef DFUNCTION
477 
478 
479 #define DFUNCTION "_sion_free_filedesc_coll_arrays"
480 
487 {
488 
489  DPRINTFP((2, DFUNCTION, -1, "enter free arrays\n"));
490  if (sion_filedesc->all_coll_collsize != NULL) {
491  free(sion_filedesc->all_coll_collsize);
492  sion_filedesc->all_coll_collsize=NULL;
493  }
494  if (sion_filedesc->all_coll_collector != NULL) {
495  free(sion_filedesc->all_coll_collector);
496  sion_filedesc->all_coll_collector=NULL;
497  }
498  if (sion_filedesc->all_coll_capability != NULL) {
499  free(sion_filedesc->all_coll_capability);
500  sion_filedesc->all_coll_capability=NULL;
501  }
502  DPRINTFP((2, DFUNCTION, -1, "leave free arrays\n"));
503  return (1);
504 }
505 #undef DFUNCTION
506 
507 #define DFUNCTION "_sion_alloc_filedesc_block_arrays"
508 
515 {
516  int i;
517  sion_int64 *p;
518 
519  DPRINTFP((2, DFUNCTION, -1, "enter alloc locations size=%d, maxblocks=%d\n", sion_filedesc->ntasks, sion_filedesc->maxchunks));
520  sion_filedesc->all_blockcount = p = (sion_int64 *) malloc(sion_filedesc->ntasks * sizeof(sion_int64));
521  if (sion_filedesc->all_blockcount == NULL) {
522  return(_sion_errorprint(SION_NOT_SUCCESS,_SION_ERROR_RETURN, DFUNCTION ": cannot allocate temporary memory of size %lu (sion_blockcount), aborting ...\n",
523  (unsigned long) sion_filedesc->ntasks * sizeof(sion_int64)));
524  }
525  for (i = 0; i < sion_filedesc->ntasks; i++) p[i] = -1;
526 
527  sion_filedesc->all_currentpos = p = (sion_int64 *) malloc(sion_filedesc->ntasks * sizeof(sion_int64));
528  if (sion_filedesc->all_currentpos == NULL) {
529  return(_sion_errorprint(SION_NOT_SUCCESS,_SION_ERROR_RETURN, DFUNCTION ": cannot allocate temporary memory of size %lu (sion_currentpos), aborting ...\n",
530  (unsigned long) sion_filedesc->ntasks * sizeof(sion_int64)));
531  }
532  for (i = 0; i < sion_filedesc->ntasks; i++) p[i] = -1;
533 
534  sion_filedesc->all_currentblocknr = p = (sion_int64 *) malloc(sion_filedesc->ntasks * sizeof(sion_int64));
535  if (sion_filedesc->all_currentblocknr == NULL) {
536  return(_sion_errorprint(SION_NOT_SUCCESS,_SION_ERROR_RETURN, DFUNCTION ": cannot allocate temporary memory of size %lu (sion_currentblocknr), aborting ...\n",
537  (unsigned long) sion_filedesc->ntasks * sizeof(sion_int64)));
538  }
539  for (i = 0; i < sion_filedesc->ntasks; i++) p[i] = -1;
540 
541  sion_filedesc->all_blocksizes = p = (sion_int64 *) malloc(sion_filedesc->maxchunks * sion_filedesc->ntasks * sizeof(sion_int64));
542  if (sion_filedesc->all_blocksizes == NULL) {
543  return(_sion_errorprint(SION_NOT_SUCCESS,_SION_ERROR_RETURN, DFUNCTION ": cannot allocate temporary memory of size %lu (sion_blocksizes), aborting ...\n",
544  (unsigned long) sion_filedesc->ntasks * sizeof(sion_int64)));
545  }
546  for (i = 0; i < sion_filedesc->maxchunks * sion_filedesc->ntasks; i++) p[i] = -1;
547 
548 
549  DPRINTFP((2, DFUNCTION, -1, "leave alloc locations size=%d, maxblocks=%d\n", sion_filedesc->ntasks, sion_filedesc->maxchunks));
550  return (1);
551 }
552 #undef DFUNCTION
553 
554 
555 #define DFUNCTION "_sion_alloc_filedesc_block_arrays_only"
556 
563 {
564  int i;
565  sion_int64 *p;
566 
567  DPRINTFP((2, DFUNCTION, -1, "enter alloc locations size=%d, maxblocks=%d\n", sion_filedesc->ntasks, sion_filedesc->maxchunks));
568  sion_filedesc->all_blockcount = p = (sion_int64 *) malloc(sion_filedesc->ntasks * sizeof(sion_int64));
569  if (sion_filedesc->all_blockcount == NULL) {
570  return(_sion_errorprint(SION_NOT_SUCCESS,_SION_ERROR_RETURN, DFUNCTION ": cannot allocate temporary memory of size %lu (sion_blockcount), aborting ...\n",
571  (unsigned long) sion_filedesc->ntasks * sizeof(sion_int64)));
572  }
573  for (i = 0; i < sion_filedesc->ntasks; i++) p[i] = -1;
574 
575  sion_filedesc->all_blocksizes = p = (sion_int64 *) malloc(sion_filedesc->maxchunks * sion_filedesc->ntasks * sizeof(sion_int64));
576  if (sion_filedesc->all_blocksizes == NULL) {
577  return(_sion_errorprint(SION_NOT_SUCCESS,_SION_ERROR_RETURN, DFUNCTION ": cannot allocate temporary memory of size %lu (sion_blocksizes), aborting ...\n",
578  (unsigned long) sion_filedesc->ntasks * sizeof(sion_int64)));
579  }
580  for (i = 0; i < sion_filedesc->maxchunks * sion_filedesc->ntasks; i++) p[i] = -1;
581 
582  DPRINTFP((2, DFUNCTION, -1, "leave alloc locations size=%d, maxblocks=%d\n", sion_filedesc->ntasks, sion_filedesc->maxchunks));
583  return (1);
584 }
585 #undef DFUNCTION
586 
587 #define DFUNCTION "_sion_free_filedesc"
588 int _sion_free_filedesc(_sion_filedesc *sion_filedesc)
589 {
590 
591  int rc = SION_SUCCESS;
592 
593  if (sion_filedesc == NULL) {
594  return (0);
595  }
596 
597  if (sion_filedesc->fname)
598  free(sion_filedesc->fname);
599  if (sion_filedesc->blocksizes)
600  free(sion_filedesc->blocksizes);
601  if (sion_filedesc->all_chunksizes)
602  free(sion_filedesc->all_chunksizes);
603  if (sion_filedesc->all_globalranks)
604  free(sion_filedesc->all_globalranks);
605  if (sion_filedesc->all_localranks)
606  free(sion_filedesc->all_localranks);
607  if (sion_filedesc->all_startpointers)
608  free(sion_filedesc->all_startpointers);
609  if (sion_filedesc->all_currentpos)
610  free(sion_filedesc->all_currentpos);
611  if (sion_filedesc->all_currentblocknr)
612  free(sion_filedesc->all_currentblocknr);
613  if (sion_filedesc->all_blockcount)
614  free(sion_filedesc->all_blockcount);
615  if (sion_filedesc->all_blocksizes)
616  free(sion_filedesc->all_blocksizes);
617  if (sion_filedesc->all_coll_collsize)
618  free(sion_filedesc->all_coll_collsize);
619  if (sion_filedesc->all_coll_collector)
620  free(sion_filedesc->all_coll_collector);
621  if (sion_filedesc->all_keyvalptr)
622  _sion_free_filedesc_all_keyvalptr(sion_filedesc);
623  if (sion_filedesc->keyvalptr)
624  _sion_keyvalue_keymngr_destroy((_sion_keyvalue_keymngr *)sion_filedesc->keyvalptr);
625  if (sion_filedesc->prefix)
626  free(sion_filedesc->prefix);
627  if (sion_filedesc->newfname)
628  free(sion_filedesc->newfname);
629  if (sion_filedesc->mapping)
630  free(sion_filedesc->mapping);
631  /* is only a payload pointer, memory should not freed here */
632  /* if (sion_filedesc->dataptr) */
633  /* free(sion_filedesc->dataptr); */
634  if (sion_filedesc->fpbuffer)
635  free(sion_filedesc->fpbuffer);
636  if (sion_filedesc->buffer)
637  free(sion_filedesc->buffer);
638 
639  free(sion_filedesc);
640 
641  return (rc);
642 }
643 #undef DFUNCTION
644 
645 #define DFUNCTION "_sion_print_filedesc"
646 
650 int _sion_print_filedesc(_sion_filedesc *sion_filedesc, int level, char *desc, int flag)
651 {
652 
653  int rc = SION_SUCCESS;
654  int i;
655 
656  if (sion_filedesc == NULL) {
657  return(_sion_errorprint(SION_NOT_SUCCESS,_SION_ERROR_RETURN, DFUNCTION ": cannot print, data structure is not allocated, aborting ...\n"));
658  }
659 
660  DPRINTFP((level, desc, sion_filedesc->rank, "DUMP: sion_filedesc\n"));
661  DPRINTFP((level, desc, sion_filedesc->rank, "-------------------\n"));
662 
663  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%x\n", "fileptr", sion_filedesc->fileptr));
664  if(sion_filedesc->fileptr) {
665  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d %s\n", "fileptr->flags", sion_filedesc->fileptr->flags,_sion_get_fileptr_desc(sion_filedesc->fileptr)));
666  }
667  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%s\n", "fname", sion_filedesc->fname));
668  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "sid", sion_filedesc->sid));
669  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "rank", sion_filedesc->rank));
670  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "globalrank", sion_filedesc->globalrank));
671  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "ntasks", sion_filedesc->ntasks));
672  if(sion_filedesc->state==SION_FILESTATE_PAROPEN) DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d (SION_FILESTATE_PAROPEN)\n", "state", sion_filedesc->state));
673  else if(sion_filedesc->state==SION_FILESTATE_SEROPEN) DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d (SION_FILESTATE_SEROPEN)\n", "state", sion_filedesc->state));
674  else if(sion_filedesc->state==SION_FILESTATE_SEROPENRANK) DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d (SION_FILESTATE_SEROPENRANK)\n", "state", sion_filedesc->state));
675  else if(sion_filedesc->state==SION_FILESTATE_SEROPENMASTER)DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d (SION_FILESTATE_SEROPENMASTER)\n", "state", sion_filedesc->state));
676  else if(sion_filedesc->state==SION_FILESTATE_CLOSE) DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d (SION_FILESTATE_CLOSE)\n", "state", sion_filedesc->state));
677  else if(sion_filedesc->state==SION_FILESTATE_PAROPENMAPPED) DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d (SION_FILESTATE_PAROPENMAPPED)\n", "state", sion_filedesc->state));
678  else if(sion_filedesc->state==SION_FILESTATE_PAROPENMAPPEDMANAGED)DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d (SION_FILESTATE_PAROPENMAPPEDMANAGED)\n", "state", sion_filedesc->state));
679  else if(sion_filedesc->state==SION_FILESTATE_PAROPENMAPPEDMASTER) DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d (SION_FILESTATE_PAROPENMAPPEDMASTER)\n", "state", sion_filedesc->state));
680  else DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d (unknown)\n", "state", sion_filedesc->state));
681  if(sion_filedesc->mode==SION_FILEMODE_WRITE) DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d (SION_FILEMODE_WRITE)\n", "mode", sion_filedesc->mode));
682  else if(sion_filedesc->mode==SION_FILEMODE_READ) DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d (SION_FILEMODE_READ)\n", "mode", sion_filedesc->mode));
683  else DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d (unknown)\n", "mode", sion_filedesc->mode));
684  if(sion_filedesc->dup_mode==SION_DESCSTATE_ORIG) DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d (SION_DESCSTATE_ORIG)\n", "dup", sion_filedesc->dup_mode));
685  else if(sion_filedesc->dup_mode==SION_DESCSTATE_DUP) DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d (SION_DESCSTATE_DUP)\n", "dup", sion_filedesc->dup_mode));
686  else if(sion_filedesc->dup_mode==SION_DESCSTATE_DUP_SEL_RANK) DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d (SION_DESCSTATE_DUP_SEL_RANK)\n", "dup", sion_filedesc->dup_mode));
687  else if(sion_filedesc->dup_mode==SION_DESCSTATE_DUP_SEL_RANK_KEY) DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d (SION_DESCSTATE_DUP_SEL_RANK_KEY)\n", "dup", sion_filedesc->dup_mode));
688  else DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d (unknown)\n", "dup", sion_filedesc->dup_mode));
689  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "endianness", sion_filedesc->endianness));
690  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "swapbytes", sion_filedesc->swapbytes));
691  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "fileversion", sion_filedesc->fileversion));
692  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "filesionversion", sion_filedesc->filesionversion));
693  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "filesionpatchlevel", sion_filedesc->filesionpatchlevel));
694  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "fsblksize", sion_filedesc->fsblksize));
695  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "lastchunknr", sion_filedesc->lastchunknr));
696  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "maxchunks", sion_filedesc->maxchunks));
697  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "maxusedchunks", sion_filedesc->maxusedchunks));
698 
699  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "currentpos", sion_filedesc->currentpos));
700  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "currentblocknr", sion_filedesc->currentblocknr));
701 
702  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%lld\n", "startpos", sion_filedesc->startpos));
703  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%lld\n", "chunksize", sion_filedesc->chunksize));
704  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%lld\n", "chunksize_req", sion_filedesc->chunksize_req));
705  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%lld\n", "globalskip", sion_filedesc->globalskip));
706  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%lld\n", "end_of_header", sion_filedesc->end_of_header));
707  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%lld\n", "start_of_varheader", sion_filedesc->start_of_varheader));
708  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%lld\n", "start_of_data", sion_filedesc->start_of_data));
709 
710  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "nfiles", sion_filedesc->nfiles));
711  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "filenumber", sion_filedesc->filenumber));
712  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=\"%s\"\n", "prefix", sion_filedesc->prefix));
713  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=\"%s\"\n", "newfname", sion_filedesc->newfname));
714  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%x\n", "fpbuffer", sion_filedesc->fpbuffer));
715  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "fpbuffer_size", sion_filedesc->fpbuffer_size));
716  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%x\n", "buffer", sion_filedesc->buffer));
717  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "buffer_size", sion_filedesc->buffer_size));
718  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "buffer_ptr", sion_filedesc->buffer_ptr));
719 
720  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "compress", sion_filedesc->compress));
721 
722  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "usecache", sion_filedesc->usecache));
723  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "cachesize", sion_filedesc->cachesize));
724 
725  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "usecoll", sion_filedesc->usecoll));
726  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "collsize", sion_filedesc->collsize));
727  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "collector", sion_filedesc->collector));
728  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "colldebug", sion_filedesc->colldebug));
729  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "collcmdused", sion_filedesc->collcmdused));
730  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "collmergemode", sion_filedesc->collmergemode));
731  if(sion_filedesc->coll_capability==SION_CAPABILITY_FULL) DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%s\n", "coll_capability", "FULL"));
732  if(sion_filedesc->coll_capability==SION_CAPABILITY_ONLY_SENDER) DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%s\n", "coll_capability", "ONLY_SENDER"));
733  if(sion_filedesc->coll_capability==SION_CAPABILITY_NONE) DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%s\n", "coll_capability", "NONE"));
734 
735  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "fileptr_exported", sion_filedesc->fileptr_exported));
736 
737  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "usehints", sion_filedesc->usehints));
738  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "hinttype", sion_filedesc->hinttype));
739 
740  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "lrank", sion_filedesc->lrank));
741  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "nlocaltasksinfile", sion_filedesc->nlocaltasksinfile));
742  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "ntotaltasksinfile", sion_filedesc->ntotaltasksinfile));
743  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%d\n", "filemanagedbytask", sion_filedesc->filemanagedbytask));
744 
745 
746  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%x\n", "dataptr", sion_filedesc->dataptr));
747 
748  if(sion_filedesc->keyvalmode==SION_KEYVAL_NONE) DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%s\n", "keyvalmode", "NONE"));
749  if(sion_filedesc->keyvalmode==SION_KEYVAL_INLINE) DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%s\n", "keyvalmode", "INLINE"));
750  if(sion_filedesc->keyvalmode==SION_KEYVAL_UNKNOWN) DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%s\n", "keyvalmode", "UNKNOWN"));
751  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%x\n", "keyvalptr", sion_filedesc->keyvalptr));
752  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s=%x\n", "all_keyvalptr", sion_filedesc->all_keyvalptr));
753 
754  /* if (sion_filedesc->nfiles > 1) */
755  /* for(i=0;i<sion_filedesc->nfiles;i++) */
756  /* DPRINTFP(( level,desc,sion_filedesc->rank,"D: file[%d]=%s\n", i, sion_filedesc->files[i])); */
757 
758 
759  if(sion_filedesc->blocksizes !=NULL) {
760  int maxprintblocks=sion_filedesc->lastchunknr;
761  if (maxprintblocks>20) maxprintblocks=20;
762  for (i = 0; i <= maxprintblocks; i++) {
763  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s[%4d]=%lld\n", "blocksizes", i, sion_filedesc->blocksizes[i]));
764  }
765  if(maxprintblocks<sion_filedesc->lastchunknr) {
766  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s[....]=...\n", "blocksizes"));
767  }
768 
769  }
770 
771  if( (sion_filedesc->state==SION_FILESTATE_SEROPENMASTER) || (sion_filedesc->state==SION_FILESTATE_PAROPENMAPPEDMASTER) ) {
772  for (i = 0; i < sion_filedesc->nfiles; i++) {
773  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s[%4d]=%s\n", "file:", i, sion_filedesc->multifiles[i]->fname));
774  }
775  }
776 
777  if (flag&_SION_DEBUG_PRINT_ALL) {
778 
779  if(sion_filedesc->all_chunksizes !=NULL) {
780  for (i = 0; i < sion_filedesc->ntasks; i++) {
781  DPRINTFP((2048, desc, sion_filedesc->rank, "D: %-20s[%4d]=%lld\n", "all_chunksizes", i, sion_filedesc->all_chunksizes[i]));
782  }
783  }
784 
785  if(sion_filedesc->all_globalranks !=NULL) {
786  for (i = 0; i < sion_filedesc->ntasks; i++) {
787  DPRINTFP((2048, desc, sion_filedesc->rank, "D: %-20s[%4d]=%lld\n", "all_globalranks", i, sion_filedesc->all_globalranks[i]));
788  }
789  }
790 
791  if(sion_filedesc->all_localranks !=NULL) {
792  for (i = 0; i < sion_filedesc->ntasks; i++) {
793  DPRINTFP((2048, desc, sion_filedesc->rank, "D: %-20s[%4d]=%lld\n", "all_localranks", i, sion_filedesc->all_localranks[i]));
794  }
795  }
796 
797  if(sion_filedesc->all_startpointers !=NULL) {
798  for (i = 0; i < sion_filedesc->ntasks; i++) {
799  DPRINTFP((2048, desc, sion_filedesc->rank, "D: %-20s[%4d]=%lld\n", "all_startpointers", i, sion_filedesc->all_startpointers[i]));
800  }
801  }
802 
803  if(sion_filedesc->all_currentpos !=NULL) {
804  for (i = 0; i < sion_filedesc->ntasks; i++) {
805  DPRINTFP((2048, desc, sion_filedesc->rank, "D: %-20s[%4d]=%lld\n", "all_currentpos", i, sion_filedesc->all_currentpos[i]));
806  }
807  }
808 
809  if(sion_filedesc->all_currentblocknr !=NULL) {
810  for (i = 0; i < sion_filedesc->ntasks; i++) {
811  DPRINTFP((2048, desc, sion_filedesc->rank, "D: %-20s[%4d]=%lld\n", "all_currentblocknr", i, sion_filedesc->all_currentblocknr[i]));
812  }
813  }
814 
815  if(sion_filedesc->all_blockcount !=NULL) {
816  for (i = 0; i < sion_filedesc->ntasks; i++) {
817  DPRINTFP((2048, desc, sion_filedesc->rank, "D: %-20s[%4d]=%lld\n", "all_blockcount", i, sion_filedesc->all_blockcount[i]));
818  }
819  }
820 
821  if(sion_filedesc->all_blocksizes !=NULL) {
822  for (i = 0; i < sion_filedesc->ntasks; i++) {
823  int b;
824  int maxprintblocks=sion_filedesc->all_blockcount[i];
825  if (maxprintblocks>20) maxprintblocks=20;
826  for (b = 0; b < maxprintblocks ; b++) {
827  DPRINTFP((2048, desc, sion_filedesc->rank, "D: %-20s[%4d][%d]=%lld\n", "all_blocksizes", i, b,
828  sion_filedesc->all_blocksizes[b*sion_filedesc->ntasks+i]));
829  }
830  if(maxprintblocks<sion_filedesc->all_blockcount[i]) {
831  DPRINTFP((level, desc, sion_filedesc->rank, "D: %-20s[%4d][..]=...\n", "all_blocksizes", i));
832  }
833  }
834  }
835  }
836 
837  if( (sion_filedesc->state==SION_FILESTATE_SEROPENMASTER) || (sion_filedesc->state==SION_FILESTATE_PAROPENMAPPEDMASTER) ) {
838  if (flag&_SION_DEBUG_PRINT_RECURSIVE) {
839  for (i = 0; i < sion_filedesc->nfiles; i++) {
840  DPRINTFP((level, desc, sion_filedesc->rank, "\n"));
841  DPRINTFP((level, desc, sion_filedesc->rank, "*** DUMP of multifile[%d] ***\n",i));
842  _sion_print_filedesc(sion_filedesc->multifiles[i], level, desc, flag&~(_SION_DEBUG_PRINT_RECURSIVE));
843  }
844  }
845  }
846 
847  return (rc);
848 }
849 #undef DFUNCTION
850 
851 #define DFUNCTION "_sion_get_size_of_filedesc"
852 
858 int _sion_get_size_of_filedesc(_sion_filedesc *sion_filedesc, int *numbytes, int *numfds)
859 {
860  int rc=SION_SUCCESS;
861  int bytes=0, fds=0, help_bytes, help_fds, i;
862 
863  if(sion_filedesc==NULL) return(bytes);
864 
865  DPRINTFP((2, DFUNCTION, -1, "start sid=%d nfiles=%d ntasks=%d maxchunks=%d mapping_size=%d\n", sion_filedesc->sid,
866  sion_filedesc->nfiles,sion_filedesc->ntasks,sion_filedesc->maxchunks,sion_filedesc->mapping_size));
867 
868  help_bytes=sizeof(_sion_filedesc);
869  DPRINTFP((512, DFUNCTION, -1, " sizeof(sion_filedesc)= %5d\n", help_bytes));
870  bytes+=help_bytes;
871 
872  if( (sion_filedesc->blocksizes!=NULL) ) {
873  help_bytes=sion_filedesc->maxchunks*sizeof(sion_filedesc->blocksizes[0]);
874  DPRINTFP((512, DFUNCTION, -1, " sizeof blocksizes= %5d\n", help_bytes));
875  bytes+=help_bytes;
876  }
877 
878  if( (sion_filedesc->all_chunksizes!=NULL) ) {
879  help_bytes=sion_filedesc->ntasks*sizeof(sion_filedesc->all_chunksizes[0]);
880  DPRINTFP((512, DFUNCTION, -1, " sizeof all_chunksizes= %5d\n", help_bytes));
881  bytes+=help_bytes;
882  }
883 
884  if( (sion_filedesc->all_globalranks!=NULL) ) {
885  help_bytes=sion_filedesc->ntasks*sizeof(sion_filedesc->all_globalranks[0]);
886  DPRINTFP((512, DFUNCTION, -1, " sizeof all_globalranks= %5d\n", help_bytes));
887  bytes+=help_bytes;
888  }
889 
890  if( (sion_filedesc->state!=SION_FILESTATE_SEROPENMASTER) && (sion_filedesc->state!=SION_FILESTATE_PAROPENMAPPEDMASTER) ) {
891  if(sion_filedesc->fileptr!=NULL) {
892  fds++;
893  }
894  }
895 
896  if( (sion_filedesc->all_localranks!=NULL) ) {
897  help_bytes=sion_filedesc->ntasks*sizeof(sion_filedesc->all_localranks[0]);
898  DPRINTFP((512, DFUNCTION, -1, " sizeof all_localranks= %5d\n", help_bytes));
899  bytes+=help_bytes;
900  }
901 
902  if( (sion_filedesc->all_startpointers!=NULL) ) {
903  help_bytes=sion_filedesc->ntasks*sizeof(sion_filedesc->all_startpointers[0]);
904  DPRINTFP((512, DFUNCTION, -1, " sizeof all_startpointers= %5d\n", help_bytes));
905  bytes+=help_bytes;
906  }
907 
908  if( (sion_filedesc->all_currentpos!=NULL) ) {
909  help_bytes=sion_filedesc->ntasks*sizeof(sion_filedesc->all_currentpos[0]);
910  DPRINTFP((512, DFUNCTION, -1, " sizeof all_currentpos= %5d\n", help_bytes));
911  bytes+=help_bytes;
912  }
913 
914  if( (sion_filedesc->all_currentblocknr!=NULL) ) {
915  help_bytes=sion_filedesc->ntasks*sizeof(sion_filedesc->all_currentblocknr[0]);
916  DPRINTFP((512, DFUNCTION, -1, " sizeof all_currentblocknr= %5d\n", help_bytes));
917  bytes+=help_bytes;
918  }
919 
920  if( (sion_filedesc->all_coll_collector!=NULL) ) {
921  help_bytes=sion_filedesc->ntasks*sizeof(sion_filedesc->all_coll_collector[0]);
922  DPRINTFP((512, DFUNCTION, -1, " sizeof all_coll_collector= %5d\n", help_bytes));
923  bytes+=help_bytes;
924  }
925 
926  if( (sion_filedesc->all_coll_collsize!=NULL) ) {
927  help_bytes=sion_filedesc->ntasks*sizeof(sion_filedesc->all_coll_collsize[0]);
928  DPRINTFP((512, DFUNCTION, -1, " sizeof all_coll_collsize= %5d\n", help_bytes));
929  bytes+=help_bytes;
930  }
931 
932  if( (sion_filedesc->all_blockcount!=NULL) ) {
933  help_bytes=sion_filedesc->ntasks*sizeof(sion_filedesc->all_blockcount[0]);
934  DPRINTFP((512, DFUNCTION, -1, " sizeof all_blockcount= %5d\n", help_bytes));
935  bytes+=help_bytes;
936  }
937 
938  if( (sion_filedesc->all_blocksizes!=NULL) ) {
939  help_bytes=sion_filedesc->maxchunks * sion_filedesc->ntasks*sizeof(sion_filedesc->all_blocksizes[0]);
940  DPRINTFP((512, DFUNCTION, -1, " sizeof all_blocksizes= %5d\n", help_bytes));
941  bytes+=help_bytes;
942  }
943 
944  if( (sion_filedesc->mapping!=NULL) ) {
945  help_bytes=sion_filedesc->mapping_size * 2 * sizeof(sion_filedesc->mapping[0]);
946  DPRINTFP((512, DFUNCTION, -1, " sizeof mapping= %5d\n", help_bytes));
947  bytes+=help_bytes;
948  }
949 
950  if( (sion_filedesc->prefix!=NULL) ) {
951  help_bytes=strlen(sion_filedesc->prefix);
952  DPRINTFP((512, DFUNCTION, -1, " sizeof prefix= %5d\n", help_bytes));
953  bytes+=help_bytes;
954  }
955 
956  if( (sion_filedesc->newfname!=NULL) ) {
957  help_bytes=strlen(sion_filedesc->newfname);
958  DPRINTFP((512, DFUNCTION, -1, " sizeof newfname= %5d\n", help_bytes));
959  bytes+=help_bytes;
960  }
961 
962  if( (sion_filedesc->fpbuffer!=NULL) ) {
963  help_bytes=sion_filedesc->fpbuffer_size;
964  DPRINTFP((512, DFUNCTION, -1, " sizeof fpbuffer= %5d\n", help_bytes));
965  bytes+=help_bytes;
966  }
967 
968  if( (sion_filedesc->buffer!=NULL) ) {
969  help_bytes=sion_filedesc->buffer_size;
970  DPRINTFP((512, DFUNCTION, -1, " sizeof buffer= %5d\n", help_bytes));
971  bytes+=help_bytes;
972  }
973 
974 
975  if( (sion_filedesc->state==SION_FILESTATE_PAROPEN) || (sion_filedesc->state==SION_FILESTATE_SEROPENRANK) ) {
976  if( (sion_filedesc->keyvalptr!=NULL) ) {
977  help_bytes=_sion_keyvalue_keymngr_key_get_sizeof(sion_filedesc->keyvalptr);
978  DPRINTFP((512, DFUNCTION, -1, " sizeof keyvalptr= %5d\n", help_bytes));
979  bytes+=help_bytes;
980  }
981  }
982 
983  if( (sion_filedesc->state==SION_FILESTATE_SEROPEN) || (sion_filedesc->state==SION_FILESTATE_SEROPENMASTER)
985  || (sion_filedesc->state==SION_FILESTATE_PAROPENMAPPED) ) {
986 
987  if( (sion_filedesc->all_keyvalptr!=NULL) ) {
988  for (i = 0; i < sion_filedesc->ntasks; i++) {
989  if(sion_filedesc->all_keyvalptr[i]!=NULL) {
990  help_bytes=_sion_keyvalue_keymngr_key_get_sizeof(sion_filedesc->all_keyvalptr[i]);
991  DPRINTFP((512, DFUNCTION, -1, " sizeof all_keyvalptr[%d]= %5d\n", i, help_bytes));
992  bytes+=help_bytes;
993  }
994  }
995  }
996  }
997 
998  if( (sion_filedesc->state==SION_FILESTATE_SEROPENMASTER) || (sion_filedesc->state==SION_FILESTATE_PAROPENMAPPEDMASTER) ) {
999 
1000  help_bytes=sion_filedesc->nfiles*sizeof(sion_filedesc->multifiles[0]);
1001  DPRINTFP((512, DFUNCTION, -1, " sizeof multifiles= %5d\n", help_bytes));
1002  bytes+=help_bytes;
1003 
1004  for (i = 0; i < sion_filedesc->nfiles; i++) {
1005 
1006  rc=_sion_get_size_of_filedesc(sion_filedesc->multifiles[i], &help_bytes, &help_fds);
1007  DPRINTFP((512, DFUNCTION, -1, " sizeof multifile[%d]= %5d + %1d\n", i, help_bytes, help_fds));
1008  bytes+=help_bytes;
1009  fds+=help_fds;
1010  }
1011  }
1012 
1013  *numbytes=bytes;*numfds=fds;
1014  DPRINTFP((2, DFUNCTION, -1, "leave total_size =%5d + %d fds\n", bytes, fds));
1015 
1016  return(rc);
1017 }
1018 #undef DFUNCTION
1019 
1020 #define DFUNCTION "_sion_dup_filedesc"
1021 
1027 {
1028  _sion_filedesc *new_fd=NULL;
1029 
1030  new_fd=_sion_alloc_filedesc();
1031  if (sion_filedesc == NULL) {
1032  _sion_errorprint(SION_NOT_SUCCESS,_SION_ERROR_RETURN,"cannot allocate filedescriptor structure (sion_filedesc), aborting ...\n");
1033  return(NULL);
1034  }
1035 
1036  new_fd->dup_mode = SION_DESCSTATE_DUP;
1037 
1038  /* values which will not be copied */
1039  new_fd->fileptr = NULL;
1040  new_fd->sid = -1;
1041  new_fd->dataptr = NULL; /* not needed in a dup fd */
1042  new_fd->keyvalptr = NULL; /* not needed in a dup fd */
1043  new_fd->usecoll = 0;
1044  new_fd->maxchunks = -1;
1045 
1046  /* copy scalar values */
1047  new_fd->fname = strdup(sion_filedesc->fname);
1048  new_fd->rank = sion_filedesc->rank;
1049  new_fd->lrank = sion_filedesc->lrank;
1050  new_fd->globalrank = sion_filedesc->globalrank;
1051 
1052  new_fd->ntasks = sion_filedesc->ntasks;
1053  new_fd->state = sion_filedesc->state;
1054  new_fd->mode = sion_filedesc->mode;
1055  new_fd->endianness = sion_filedesc->endianness;
1056  new_fd->swapbytes = sion_filedesc->swapbytes;
1057  new_fd->fileversion = sion_filedesc->fileversion;
1058  new_fd->filesionversion = sion_filedesc->filesionversion;
1059  new_fd->filesionpatchlevel = sion_filedesc->filesionpatchlevel;
1060  new_fd->fsblksize = sion_filedesc->fsblksize;
1061  new_fd->lastchunknr = sion_filedesc->lastchunknr;
1062  new_fd->maxusedchunks = sion_filedesc->maxusedchunks;
1063  new_fd->startpos = sion_filedesc->startpos;
1064  new_fd->chunksize = sion_filedesc->chunksize;
1065  new_fd->chunksize_req = sion_filedesc->chunksize_req;
1066 
1067  new_fd->globalskip = sion_filedesc->globalskip;
1068  new_fd->end_of_header = sion_filedesc->end_of_header;
1069  new_fd->start_of_varheader = sion_filedesc->start_of_varheader;
1070  new_fd->start_of_data = sion_filedesc->start_of_data;
1071 
1072  new_fd->currentpos = sion_filedesc->currentpos;
1073  new_fd->currentblocknr = sion_filedesc->currentblocknr;
1074  new_fd->debug = sion_filedesc->debug;
1075 
1076  new_fd->nfiles = sion_filedesc->nfiles;
1077  new_fd->filenumber = sion_filedesc->filenumber;
1078  new_fd->mapping_size = sion_filedesc->mapping_size;
1079 
1080  new_fd->ntotaltasksinfile = sion_filedesc->ntotaltasksinfile;
1081  new_fd->nlocaltasksinfile = sion_filedesc->nlocaltasksinfile;
1082  new_fd->filemanagedbytask = sion_filedesc->filemanagedbytask;
1083 
1084  new_fd->ntasks = sion_filedesc->ntasks;
1085  new_fd->flag1 = sion_filedesc->flag1;
1086  new_fd->flag2 = sion_filedesc->flag2;
1087  new_fd->fpbuffer_size = sion_filedesc->fpbuffer_size;
1088 
1089  new_fd->usecache = sion_filedesc->usecache;
1090  new_fd->cachesize = sion_filedesc->cachesize;
1091  new_fd->cacheid = sion_filedesc->cacheid;
1092  strcpy(new_fd->cachefn,sion_filedesc->cachefn);
1093 
1094  new_fd->cachemode = sion_filedesc->cachemode;
1095  new_fd->usebuffer = sion_filedesc->usebuffer;
1096  new_fd->buffer_size = sion_filedesc->buffer_size;
1097  new_fd->buffer_ptr = sion_filedesc->buffer_ptr;
1098  new_fd->compress = sion_filedesc->compress;
1099  new_fd->keyvalmode = sion_filedesc->keyvalmode;
1100 
1101  new_fd->collsize = sion_filedesc->collsize;
1102  new_fd->coll_capability = sion_filedesc->coll_capability;
1103  new_fd->collector = sion_filedesc->collector;
1104  new_fd->colldebug = sion_filedesc->colldebug;
1105  new_fd->collcmdused = sion_filedesc->collcmdused;
1106  new_fd->usehints = sion_filedesc->usehints;
1107  new_fd->hinttype = sion_filedesc->hinttype;
1108  new_fd->fileptr_exported = sion_filedesc->fileptr_exported;
1109  new_fd->collmergemode = sion_filedesc->collmergemode;
1110 
1111  new_fd->prefix=NULL;
1112  if(sion_filedesc->prefix) new_fd->prefix = strdup(sion_filedesc->prefix);
1113  new_fd->newfname=NULL;
1114  if(sion_filedesc->newfname) new_fd->newfname = strdup(sion_filedesc->newfname);
1115 
1116  new_fd->blocksizes = NULL; /* vector of written bytes in each block for current task */
1117  new_fd->all_chunksizes = NULL; /* only used if sion is opened from a single task for read */
1118  new_fd->all_globalranks = NULL; /* only used if sion is opened from a single task for read */
1119  new_fd->all_localranks = NULL; /* only used if sion is opened in mapped mode */
1120  new_fd->all_startpointers = NULL; /* only used if sion is opened from a single task for read */
1121 
1122  new_fd->all_currentpos = NULL; /* only used if sion is opened from a single task for write */
1123  new_fd->all_currentblocknr = NULL; /* only used if sion is opened from a single task for write */
1124 
1125  new_fd->all_coll_collector = NULL; /* only used on rank 0 if usecoll=1 */
1126  new_fd->all_coll_collsize = NULL; /* only used on rank 0 if usecoll=1 */
1127 
1128  new_fd->all_blockcount = NULL; /* size, only used if sion is opened from a single task for read */
1129  new_fd->all_blocksizes = NULL; /* size*maxchunks, only used if sion is opened from a single task for read */
1130 
1131  new_fd->all_keyvalptr = NULL;
1132 
1133  new_fd->mapping = NULL;
1134  new_fd->multifiles = NULL;
1135 
1136  new_fd->fpbuffer = NULL;
1137  new_fd->cacheptr = NULL;
1138  new_fd->buffer = NULL;
1139 
1140  return (new_fd);
1141 }
1142 #undef DFUNCTION
sion_int32 filemanagedbytask
_sion_filedesc * _sion_alloc_filedesc()
Allocates memory for internal sion structure.
Sion File Descriptor Structure.
Definition: sion_filedesc.h:77
#define _SION_FLAG1_NONE
Definition: sion_filedesc.h:17
sion_int64 * all_blockcount
#define SION_FILESTATE_SEROPEN
Definition: sion_filedesc.h:25
sion_int64 * all_currentpos
sion_int32 filesionpatchlevel
sion_int64 * all_globalranks
#define _SION_FLAG2_NONE
Definition: sion_filedesc.h:18
#define SION_KEYVAL_INLINE
Definition: sion_const.h:81
#define SION_CAPABILITY_FULL
Definition: sion_filedesc.h:50
int _sion_alloc_filedesc_arrays(_sion_filedesc *sion_filedesc)
Allocate memory for the internal sion arrays.
int _sion_get_size_of_filedesc(_sion_filedesc *sion_filedesc, int *numbytes, int *numfds)
get size of internal data structure sion_filedesc
int _sion_free_filedesc_arrays(_sion_filedesc *sion_filedesc)
free memory for the internal sion arrays
sion_int64 * all_currentblocknr
int _sion_alloc_filedesc_block_arrays_only(_sion_filedesc *sion_filedesc)
Allocate memory for the internal sion structure, fields for all chunksizes of all tasks.
int _sion_realloc_filedesc_blocklist(_sion_filedesc *sion_filedesc, sion_int32 maxchunks)
Increase the memory used by the internal sion structure for the blocklist.
#define SION_DESCSTATE_DUP_SEL_RANK_KEY
Definition: sion_filedesc.h:44
sion_int32 * all_coll_collector
sion_int32 fileptr_exported
#define SION_KEYVAL_NONE
Definition: sion_const.h:80
#define SION_KEYVAL_UNKNOWN
Definition: sion_const.h:84
sion_int32 * all_coll_capability
#define SION_CAPABILITY_NONE
Definition: sion_filedesc.h:52
#define SION_DESCSTATE_DUP_SEL_RANK
Definition: sion_filedesc.h:43
#define SION_CAPABILITY_ONLY_SENDER
Definition: sion_filedesc.h:51
#define SION_FILEMODE_READ
Definition: sion_filedesc.h:33
char * _sion_get_fileptr_desc(_sion_fileptr *sion_fileptr)
Definition: sion_file.c:1462
sion_int64 * all_startpointers
#define SION_CACHE_UNKNOWN
Definition: sion_filedesc.h:38
int _sion_errorprint(int rc, int level, const char *format,...)
Internal SION error.
#define SION_FILESTATE_PAROPENMAPPEDMANAGED
Definition: sion_filedesc.h:29
char cachefn[SION_CACHE_FNLEN]
#define SION_FILEMODE_UNKNOWN
Definition: sion_filedesc.h:32
#define SION_FILESTATE_PAROPEN
Definition: sion_filedesc.h:24
#define SION_CACHE_FNLEN
Definition: sion_filedesc.h:39
int _sion_free_filedesc_coll_arrays(_sion_filedesc *sion_filedesc)
free memory for the internal sion arrays
sion_int32 coll_capability
sion_int32 fpbuffer_size
Definition: sion_filedesc.h:86
sion_int64 * blocksizes
Definition: sion_filedesc.h:98
#define SION_FILESTATE_PAROPENMAPPEDMASTER
Definition: sion_filedesc.h:28
sion_int32 currentblocknr
Definition: sion_filedesc.h:95
int _sion_alloc_filedesc_block_arrays(_sion_filedesc *sion_filedesc)
Allocate memory for the internal sion structure, fields for all chunksizes of all tasks.
#define SION_FILESTATE_SEROPENRANK
Definition: sion_filedesc.h:26
sion_int64 * all_chunksizes
int _sion_print_filedesc(_sion_filedesc *sion_filedesc, int level, char *desc, int flag)
Print the initialized sion file description.
#define SION_DESCSTATE_DUP
Definition: sion_filedesc.h:42
#define SION_FILESTATE_CLOSE
Definition: sion_filedesc.h:31
sion_int64 * all_localranks
int _sion_alloc_filedesc_coll_arrays(_sion_filedesc *sion_filedesc)
Allocate memory for the internal sion arrays.
int _sion_init_filedesc(_sion_filedesc *sion_filedesc)
Initialize the sion file description.
Definition: sion_filedesc.c:34
#define SION_FILEMODE_WRITE
Definition: sion_filedesc.h:34
_sion_filedesc * _sion_dup_filedesc(_sion_filedesc *sion_filedesc)
duplicates a filedesc data structure, not copying/reopen active file pointers
#define SION_FILESTATE_UNKNOWN
Definition: sion_filedesc.h:23
sion_int32 filesionversion
sion_int32 * all_coll_collsize
sion_int64 start_of_varheader
#define SION_DESCSTATE_ORIG
Definition: sion_filedesc.h:41
#define SION_FILESTATE_SEROPENMASTER
Definition: sion_filedesc.h:27
sion_int64 * all_blocksizes
sion_int32 ntotaltasksinfile
struct _sion_filedesc_struct _sion_filedesc
SION File Descriptor Alias.
Definition: sion_filedesc.h:62
sion_int32 nlocaltasksinfile
#define SION_HINTS_TYPE_UNKNOWN
Definition: sion_filedesc.h:46
_sion_filedesc ** multifiles
_sion_fileptr * fileptr
Definition: sion_filedesc.h:80
#define SION_FILESTATE_PAROPENMAPPED
Definition: sion_filedesc.h:30