X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/2070401863db92e8198b0b8e5f29fbf0f7af2ff2..b16e6e644a2b398d2618a70c1b2f49c94c65d73c:/src/smpi/smpi_shared.cpp diff --git a/src/smpi/smpi_shared.cpp b/src/smpi/smpi_shared.cpp index 731f4ae29d..e629da93ea 100644 --- a/src/smpi/smpi_shared.cpp +++ b/src/smpi/smpi_shared.cpp @@ -295,11 +295,12 @@ void *smpi_shared_malloc_global__(size_t size, const char *file, int line, int * if(shared_block_offsets[0] > 0) { newmeta.private_blocks.push_back(std::make_pair(0, shared_block_offsets[0])); } - for(int i_block = 0; i_block < nb_shared_blocks-1; i_block ++) { + int i_block; + for(i_block = 0; i_block < nb_shared_blocks-1; i_block ++) { newmeta.private_blocks.push_back(std::make_pair(shared_block_offsets[2*i_block+1], shared_block_offsets[2*i_block+2])); } - if(shared_block_offsets[nb_shared_blocks-1] < size) { - newmeta.private_blocks.push_back(std::make_pair(shared_block_offsets[nb_shared_blocks-1], size)); + if(shared_block_offsets[2*i_block+1] < size) { + newmeta.private_blocks.push_back(std::make_pair(shared_block_offsets[2*i_block+1], size)); } allocs_metadata[mem] = newmeta; @@ -337,7 +338,7 @@ void *smpi_shared_malloc(size_t size, const char *file, int line) { return mem; } -int smpi_is_shared(void* ptr, std::vector> &private_blocks){ +int smpi_is_shared(void* ptr, std::vector> &private_blocks, int *offset){ private_blocks.clear(); // being paranoid if (allocs_metadata.empty()) return 0; @@ -345,12 +346,15 @@ int smpi_is_shared(void* ptr, std::vector> &private_blocks){ auto low = allocs_metadata.lower_bound(ptr); if (low->first==ptr) { private_blocks = low->second.private_blocks; + *offset = 0; return 1; } if (low == allocs_metadata.begin()) return 0; low --; if (ptr < (char*)low->first + low->second.size) { + xbt_assert(ptr > (char*)low->first, "Oops, there seems to be a bug in the shared memory metadata."); + *offset = ((uint8_t*)ptr) - ((uint8_t*) low->first); private_blocks = low->second.private_blocks; return 1; } @@ -360,6 +364,49 @@ int smpi_is_shared(void* ptr, std::vector> &private_blocks){ } } +std::vector> shift_private_blocks(const std::vector> vec, int offset) { + std::vector> result; + for(auto block: vec) { + auto new_block = std::make_pair(std::max(0, block.first-offset), std::max(0, block.second-offset)); + if(new_block.second > 0) + result.push_back(new_block); + } + return result; +} + +void append_or_merge_block(std::vector> &vec, std::pair &block) { + if(vec.size() > 0 && block.first <= vec.back().second) { // overlapping with the last block inserted + vec.back().second = std::max(vec.back().second, block.second); + } + else { // not overlapping, we insert a new block + vec.push_back(block); + } +} + +std::vector> merge_private_blocks(std::vector> src, std::vector> dst) { + std::vector> result; + unsigned i_src=0, i_dst=0; + while(i_src < src.size() && i_dst < dst.size()) { + std::pair block; + if(src[i_src].first < dst[i_dst].first) { + block = src[i_src]; + i_src ++; + } + else { + block = dst[i_dst]; + i_dst ++; + } + append_or_merge_block(result, block); + } + for(; i_src < src.size(); i_src++) { + append_or_merge_block(result, src[i_src]); + } + for(; i_dst < dst.size(); i_dst++) { + append_or_merge_block(result, dst[i_dst]); + } + return result; +} + void smpi_shared_free(void *ptr) { if (smpi_cfg_shared_malloc == shmalloc_local) {