File: README.md

package info (click to toggle)
openmpi 5.0.8-3
  • links: PTS, VCS
  • area: main
  • in suites:
  • size: 201,692 kB
  • sloc: ansic: 613,078; makefile: 42,353; sh: 11,194; javascript: 9,244; f90: 7,052; java: 6,404; perl: 5,179; python: 1,859; lex: 740; fortran: 61; cpp: 20; tcl: 12
file content (71 lines) | stat: -rw-r--r-- 3,093 bytes parent folder | download | duplicates (5)
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
# MEMHEAP infrastructure documentation

Copyright (c) 2013      Mellanox Technologies, Inc.
                        All rights reserved

MEMHEAP Infrastructure is responsible for managing the symmetric heap.
The framework currently has following components: buddy and
ptmalloc. buddy which uses a buddy allocator in order to manage the
Memory allocations on the symmetric heap. Ptmalloc is an adaptation of
ptmalloc3.

Additional components may be added easily to the framework by defining
the component's and the module's base and extended structures, and
their functionalities.

The buddy allocator has the following data structures:

1. Base component - of type struct mca_memheap_base_component_2_0_0_t
2. Base module - of type struct mca_memheap_base_module_t
3. Buddy component - of type struct mca_memheap_base_component_2_0_0_t
4. Buddy module - of type struct mca_memheap_buddy_module_t extending
   the base module (struct mca_memheap_base_module_t)

Each data structure includes the following fields:

1. Base component - memheap_version, memheap_data and memheap_init
2. Base module - Holds pointers to the base component and to the
   functions: alloc, free and finalize
3. Buddy component - is a base component.
4. Buddy module - Extends the base module and holds additional data on
   the components's priority, buddy allocator,
   maximal order of the symmetric heap, symmetric heap, pointer to the
   symmetric heap and hashtable maintaining the size of each allocated
   address.

In the case that the user decides to implement additional components,
the Memheap infrastructure chooses a component with the maximal
priority.  Handling the component opening is done under the base
directory, in three stages:
1. Open all available components. Implemented by memheap_base_open.c
   and called from shmem_init.
2. Select the maximal priority component. This procedure involves the
   initialization of all components and then their finalization except
   to the chosen component. It is implemented by memheap_base_select.c
   and called from shmem_init.
3. Close the max priority active cmponent. Implemented by
   memheap_base_close.c and called from shmem finalize.


## Buddy Component/Module

Responsible for handling the entire activities of the symmetric heap.
The supported activities are:

1. buddy_init (Initialization)
1. buddy_alloc (Allocates a variable on the symmetric heap)
1. buddy_free (frees a variable previously allocated on the symmetric heap)
1. buddy_finalize (Finalization).

Data members of buddy module:

1. priority. The module's priority.
1. buddy allocator: bits, num_free, lock and the maximal order (log2
   of the maximal size) of a variable on the symmetric heap. Buddy
   Allocator gives the offset in the symmetric heap where a variable
   should be allocated.
1. symmetric_heap: a range of reserved addresses (equal in all
   executing PE's) dedicated to "shared memory" allocation.
1. symmetric_heap_hashtable (holding the size of an allocated variable
   on the symmetric heap.  used to free an allocated variable on the
   symmetric heap)