This file is indexed.

/usr/include/sphde/sassim.h is in libsphde-dev 1.3.0-1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
/*
 * Copyright (c) 2009-2014 IBM Corporation.
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * which accompanies this distribution, and is available at
 * http://www.eclipse.org/legal/epl-v10.html
 * 
 * Contributors:
 *     IBM Corporation, Steven Munroe - initial API and implementation
 */

#ifndef __SAS_SIM_H
#define __SAS_SIM_H

/**! \file sassim.h
*  \brief Shared Address Space, base runtime
*	for shared and persistent memory for multi-thread/multi-core applications.
*
*   Provides APIs to manage (setup and take-down) the SAS Region and
*   backing store for cooperating processes. The region is a contiguous
*   subrange of the process address space. The exact range varies based
*   on the platform on the platform (as defined in sasconf.h).
*
*   Associated with an active SAS region is SAS Store which is a
*   directory contain backing files which are memory mapped for the
*   active portions of the region.
*   A region is fully qualified by its SAS Store (directory)
*   path. Processes joined to the same SAS story are accessing the
*   same data at the same virtual address.
*
*   \note: For Linux this means memory mapping the pages from the
*   kernel's file cache, and so we are sharing the same real pages
*   across all partipating processes.
*   This enables zero copy sharing and persistence.
*
*   Processes using different SAS Store paths are accessing
*   logically different and disjoint regions. A process can only access
*   one SAS region but there is no limit (other than files system
*   capacity) to the number different SAS regions accessed by
*   different groups of cooperating processes.
*
*   The SAS region address range and backing file store are managed
*   via a power of 2 buddy system. Logically the region is divided into
*   segments and blocks. Segment are a fixed power of 2 size (defined
*   for the platform by sasconf.h) and alignment within the region.
*   Blocks are a variable power of 2 size and have an alignment
*   matching their size or better. Logically blocks are sub-allocated
*   from allocated segments (have a backing file and can be mmaped)
*   which are sub-allocated from the region.
*
*   \todo The current runtime restricts blocks to segment size or
*   smaller. Creating larger blocks would require creating (power of 2) multiple
*   segments (and backing files which have to memory mapped) while
*   holding the global anchor block lock. Future releases may remove
*   this restriction.
*
*   \note Segments and blocks inherit their virtual address (within the
*   process) from the region. The region has a fixed starting address
*   and segments always have a unique offset (and file index) within the
*   region. The segment's file index is used to generate the unique file
*   name within the SAS store directory. Obviously blocks inherit their
*   virtual address from the containing segment which inherits from the
*   region.
*
*   The segment is the granule of backing file allocation and memory
*   mapping. Segment backing files are always extended to the full
*   segment size at creation.  This minimizes OS overhead by minimizing
*   file system and memory mapping operations at runtime. Segments are
*   not allocated (and backing files created) until additional block
*   space is needed (when free block space, of the required size and
*   alignment, in currently allocated segments, is depleted).
*   This is done implicitly under the block allocate call.
*
*   \note SASJoinRegion and related functions (SASTHreadSetUp)
*   establish a sigaction handler for signal SIGSEGV.
*   This handles the case when one process,
*   sharing a named Region allocates a new segment and backing.  Other
*   processes (sharing the same Region) are not immediately aware of
*   this and need not perform any specific actions until or unless that
*   process references data in that segment.  This will generate a
*   SIGSEGV and the SAS sigaction handler will attach this segment by
*   mmapping the associated backing file into the faulting process at
*   the assigned address.
*
*   \note Applications that set their own signal to sigaction handlers
*   for SIGSEGV should be aware of this and plan for proper nesting.
*   Applications should establish their SIGSEGV handlers before
*   joining.  The SASJoinRegion will preserve the the "old action" as
*   part of setting it own SIGSEGV handler.
*
*   \note When the SPHDE runtime handler gets control it will verify
*   that the faulting address is within the SAS Region. If it is not,
*   it is likely a error or something that the application should
*   handle itself. The SPHDE runtime handler  will check if the
*   "old action" was SIG_DFL or has it own signal or sigaction handler.
*   If the application defined it own handler SPHDE will attempt to
*   call that handler.  Otherwise SPHDE runtime handler will print a
*   back trace and exit the effected process (or thread).
*
*   The runtime also sets up shared memory segments (shmat) for SAS locks.
*   SAS locks need to be shared but should not persist across reboot
*   (like memory mapped files do). Different SAS stores must have
*   independent locks (different lock segments).
*   So lock segments are allocated/attached via shmget/shmat using a
*   key generated (ftok) from the SAS Store path.
**/

#include <stdlib.h>

/** \brief SAS segment ID.
*
*	Internal typedef that identifies a segment (process address range
*	and backing file name) within the SAS Store (directory).
*/
typedef unsigned long sasseg_t;

#ifdef __cplusplus
#define __C__ "C"
#else
#define __C__
#endif

/** \brief SAS clear on block deallocate flag.
*
*	Internal flag that requests the SAS runtime to clear blocks as they
*	are deallocated.
*/
extern __C__ int sasClearOnDealloc;

/** \brief Get the Region's lowest memory address.
*
*	With getMemHigh() defines the Region (starting process address and extent).
*
*	@return the address value for the lowest extent of the SAS Region.
*/
extern __C__ unsigned long getMemLow();

/** \brief Get the Region's highest memory address.
*
*	With getMemLow() defines the Region (starting process address and extent).
*
*	@return the address value for the highest extent (+1) of the SAS Region.
*/
extern __C__ unsigned long getMemHigh();

/** \brief Set the Region's low/high memory address for testing
*
*   @param low defines the regions starting address.
*   @param high defines the regions ending address.
*/
extern __C__ void
setSASmemrange (unsigned long low, unsigned long high);

/** \brief Join this process to a SAS Region.
*
*   Join this process to the SAS Region based on the anchor segment
*   in the SAS Store (either the default '.' directory or the path
*   specified in the environment variable SASSTOREPATH).
*   The anchor segment contains the anchor block including the indexes
*   that manage segments and (free and allocated) block space within the region.
*
*   If the backing file for the anchor segment does not exist in the SAS
*   Store directory, the runtime creates a "SegmentSize" backing file
*   and mmaps that file at SAS memLow. The lowest part of this segment
*   is initialed as the SAS anchor block.
*
*   Otherwise the the runtime mmaps the anchor segment at memLow and
*   proceeds to bring up the rest of the SAS environment.
*   This includes mmaping additional segments from the SAS Store.
*
*   The join function also checks for, and if needed initializes,
*   the matching lock segments.
*   The lock segments are allocated/attached via shmget/shmat using a
*   key generated from the SAS Store path. This insures that applications
*   using different SAS stores also have independent lock segments.
*
*	@return a 0 value indicates success, otherwise failure.
*/
extern __C__ int SASJoinRegion();

/** \brief Join this process to a named SAS Region.
*
*   Join this process to the SAS Region based on the anchor segment
*   backing file in the named SAS Store.
*   The anchor segment contains the anchor block including the indexes
*   that manage segments and (free and allocated) block space within the region.
*
*   If the backing file for the anchor segment does not exist in the SAS
*   Store directory, the runtime creates a "SegmentSize" backing file
*   and mmaps that file at SAS memLow. The lowest part of this segment
*   is initialed as the SAS anchor block.
*
*   Otherwise the the runtime mmaps the anchor segment at memLow and
*   proceeds to bring up the rest of the SAS environment.
*   This includes mmaping additional segments from the SAS Store.
*
*   The join function also checks for, and if needed initializes,
*   the matching lock segments.
*   The lock segments are allocated/attached via shmat using a key generated
*   from the SAS Store path. This insures that applications using different
*   SAS stores also have independent lock segments.
*
*   Finally the runtime sets up as sigsegv handler. This allows the SAS
*   runtime to automatically attach segments created by other processes
*   in this SAS store.
*
*   @param store_name C string containing the path to this SAS store directory.
*	@return a 0 value indicates success, otherwise failure.
*/
extern __C__ int SASJoinRegionByName (const char * store_name);

/** \brief Allocate a block of memory within SAS Storage.
*
*	Blocks are allocated within the SAS region.
*	Blocks must be a power of 2 in size (256 bytes >= and <= segmentSize).
*	Allocated blocks always have alignment equal to their size or better.
*
*	If the required space is not found within a segment backed by existing files
*	in the SAS store, a new segment backing file is created in the SAS store
*	directory and mmaped into the region and added to region free space.
*   This automatically extends the SAS Store as needed to satisfy block
*   allocate requests.
*
*   @param blockSize size of the block to be allocated.
*	@return the address of the start of the allocated block,
*	or NULL if the allocation fails.
*/
extern __C__ void *SASBlockAlloc (unsigned long blockSize);

/** \brief Deallocate a block of memory within SAS Storage.
*
*	Blocks within the SAS Region are freed by adding the block range
*	to the free list. Adjacent free blocks of equal size and
*	appropriate alignment are combined into larger free blocks.
*
*   @param blockAddr address of start of the block to be deallocated.
*   @param blockSize size of the block to be deallocated.
*/
extern __C__ void SASBlockDealloc (void *blockAddr, unsigned long blockSize);

/** \brief Return lists of currently free segment block addresses and sizes.
*
*	Returns the addresses and sizes of power of 2 sized segment blocks
*	in the regions free list.
*	It is possible for the free list to cover combined segment blocks of
*	(power of 2) multiple segments.
*	Blocks on the regions free list will not have backing files in the SAS store directory.
*
*   @param blockAddr address of an array or addresses to be filled in.
*   @param blockSize address of an array of block size values to be filled in.
*   @param count address of a int to be filled in with the actual count of entries.
*
*   \todo should change this API to pass the max array size as a parm and return the actual count.
*/
extern __C__ void SASListFreeRegion (	void **blockAddr, 
                                            unsigned long *blockSize,
                                            int *count);

/** \brief Return lists of currently allocated segment block addresses and sizes.
*
*	Returns the addresses and sizes of power of 2 sized segment blocks currently
*	allocated within the region.
*	It is possible for the allocated list to cover combined segment blocks of
*	(power of 2) multiple segments.
*	Blocks on the regions allocated list always represent
*	segments with a backing file in the SAS Store directory.
*
*   @param blockAddr address of an array or addresses to be filled in.
*   @param blockSize address of an array of block size values to be filled in.
*   @param count address of a int to be filled in with the actual count of entries.
*
*   \todo should change this API to pass the max array size as a parm and return the actual count.
*/
extern __C__ void SASListAllocatedRegion (void **blockAddr, 
                                                   unsigned long *blockSize, 
                                                   int *count);

/** \brief Return lists of currently allocated block addresses and sizes.
*
*	Returns the addresses and sizes of power of 2 sized blocks currently
*	allocated within the region.
*	Blocks on the allocated list are a sub range of existing
*	segments with a backing file in the SAS Store directory.
*
*   @param blockAddr address of an array or addresses to be filled in.
*   @param blockSize address of an array of block size values to be filled in.
*   @param count address of a int to be filled in with the actual count of entries.
*
*   \todo should change this API to pass the max array size as a parm and return the actual count.
*/
extern __C__ void SASListInUseMem (void **blockAddr, unsigned long *blockSize,
                                           int *count);

/** \brief Return lists of freed block addresses and sizes.
*
*	Returns the addresses and sizes of power of 2 sized blocks currently
*	freed within the region.
*	Blocks on the freed list are a sub range of existing
*	segments with a backing file in the SAS Store directory.
*	It is possible for the free list to cover combined blocks of
*	multiple (power of 2) segments.
*
*   @param blockAddr address of an array or addresses to be filled in.
*   @param blockSize address of an array of block size values to be filled in.
*   @param count address of a int to be filled in with the actual count of entries.
*
*   \todo should change this API to pass the max array size as a parm and return the actual count.
*/
extern __C__ void SASListFreeMem (void **blockAddr, unsigned long *blockSize,
                                        int *count);

/** \brief Return lists of currently uncommitted block addresses and sizes.
*
*	Returns the addresses and sizes of power of 2 sized blocks
*	uncommitted blocks within the region.
*	Uncommitted blocks are a sub range of existing segments with a
*	backing file in the SAS Store directory, but have never been allocated.
*	Newly created segments start as uncommitted storage and can be
*	assumed to be initialized to zero.
*
*   @param blockAddr address of an array or addresses to be filled in.
*   @param blockSize address of an array of block size values to be filled in.
*   @param count address of a int to be filled in with the actual count of entries.
*
*   \todo should change this API to pass the max array size as a parm and return the actual count.
*/
extern __C__ void SASListUncommittedMem (void **blockAddr, unsigned long *blockSize,
                                                       int *count);

/** \brief Get the current number of free bytes within the Anchor blocks
*   internal heap.
*
*	\note Low values can prevent managing large or fragmented regions.
*	In this case consider increasing the anchor block size.
*
*	@return the number of free bytes remaining in the anchor blocks heap.
*/
extern __C__ unsigned int SASAnchorFreeSpace();

/** \brief Reset the SAS Region back to initial state.
*
*	\warning SASReset will result in the immediate lose of user data within the SAS Region.
*
*	Unmap any segments and delete backing files beyond the anchor segment.
*	Reinitialize the anchor block and lock segments to initial region state.
*
*/
extern __C__ void SASReset();

/** \brief Seize the anchor block master lock.
*
*   Used to serialize access to the anchor block and internal data structures.
*
*/
extern __C__ void SASSeize();

/** \brief Release the anchor block master lock.
*
*/
extern __C__ void SASRelease();

/** \brief Reset the internal Semaphores used by Seize/Release the SAS lock manager.
*
*	\warning Should not be called when multiple cooperating processes or
*	threads are accessing the SAS region. Should only be used to recover
*	from an application crash.
*
*	Reset internal semaphore to their initial state.
*
*/
extern __C__ void SASResetSem();

/** \brief Process wide cleanup for the SAS runtime.
+*
+*	\warning Do not attempt to use SAS/SPH APIs or access the SAS region after this call.
+*
+*	\warning Threaded applications should pthread_join their child threads before this call.
+*
+*	Unmap all SAS segments and detach the shmem segments used for locks.
+*   The runtime disables the sigsegv handler for the main thread.
+*
+*/
extern __C__ void SASCleanUp ();

/** \brief Thread specific setup for secondary thread accessing the SAS region.
*
*	\warning Each secondary thread of a SAS/SPH application should call
*	this function before accessing data within the SAS Region.
*
*   The runtime sets up a sigsegv handler for this thread. This allows the SAS
*   runtime to automatically attach SAS segments created by other processes.
*
*/
extern __C__ void SASThreadSetUp ();

/** \brief Thread specific cleanup for secondary thread accessing the SAS region.
*
*   For secondary threads that called SASThreadSetUp(), SASThreadCleanUp()
*   should be called before thread exit.
*   The runtime disables the sigsegv handler for this thread.
*
*/
extern __C__ void SASThreadCleanUp ();

/** \brief Remove the SAS Region.
*
*	\warning SASRemove will result in the immediate lose of user data within the SAS Region.
*
*	Unmap all segments and delete all backing files. Remove the shmem segments used for locks.
*
*/
extern __C__ void SASRemove();

/** \brief Sets the SAS finder pointer to a SAS block or utility object.

*	\warning The finder address is a shared SAS resource and must point to
*	a block or utility object within the SAS region.
*
*	Stores the region wide finder address within the anchor block.
*
*	\note the finder is normally a SPHContext containing name / address
*	associations for application data and other utility objects with the
*	SAS region. This helps the application find it's data and data
*	created by cooperating applications during startup. While setting
*	the finder to a context is normal it can be any data structure or
*	other utility object useful to the application.
*
*/
extern __C__ void setSASFinder (void *);

/** \brief Get the SAS finder address.
*
*	@return the SAS finder address from the anchor block.
*
*/
extern __C__ void *getSASFinder();

#endif /* __SAS_SIM_H */