Skip to content
Toggle navigation
P
Projects
G
Groups
S
Snippets
Help
FORMUS3IC_LAS3
/
embb
This project
Loading...
Sign in
Toggle navigation
Go to a project
Project
Repository
Issues
0
Merge Requests
0
Pipelines
Wiki
Members
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Commit
526d902a
authored
9 years ago
by
lucapegolotti
Browse files
Options
Browse Files
Download
Plain Diff
fix conflicts before merging embb571_blocking_map
parents
863eac1a
54757fc7
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
332 additions
and
0 deletions
+332
-0
containers_cpp/include/embb/containers/blocking_map.h
+65
-0
containers_cpp/include/embb/containers/internal/blocking_map-inl.h
+68
-0
containers_cpp/test/blocking_map_test-inl.h
+127
-0
containers_cpp/test/blocking_map_test.h
+67
-0
containers_cpp/test/main.cc
+5
-0
No files found.
containers_cpp/include/embb/containers/blocking_map.h
0 → 100755
View file @
526d902a
/*
* Copyright (c) 2014-2016, Siemens AG. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*/
#ifndef EMBB_CONTAINERS_BLOCKING_MAP_H_
#define EMBB_CONTAINERS_BLOCKING_MAP_H_
#include <embb/base/base.h>
#include <map>
namespace
embb
{
namespace
containers
{
template
<
typename
Key
,
typename
Value
>
class
BlockingMap
{
typedef
embb
::
base
::
Mutex
Mutex
;
typedef
embb
::
base
::
LockGuard
<>
LockGuard
;
private
:
std
::
map
<
Key
,
Value
>
internalMap
;
Mutex
mutex
;
public
:
BlockingMap
();
bool
Insert
(
const
Key
&
key
,
const
Value
&
value
);
bool
Erase
(
const
Key
&
key
);
bool
Contains
(
const
Key
&
key
);
Value
&
operator
[](
const
Key
&
key
);
};
}
}
#include <embb/containers/internal/blocking_map-inl.h>
#endif EMBB_CONTAINERS_BLOCKING_MAP_H_
This diff is collapsed.
Click to expand it.
containers_cpp/include/embb/containers/internal/blocking_map-inl.h
0 → 100755
View file @
526d902a
/*
* Copyright (c) 2014-2016, Siemens AG. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*/
#ifndef EMBB_CONTAINERS_INTERNAL_BLOCKING_MAP_INL_H_
#define EMBB_CONTAINERS_INTERNAL_BLOCKING_SET_INL_H_
namespace
embb
{
namespace
containers
{
template
<
typename
K
,
typename
V
>
BlockingMap
<
K
,
V
>::
BlockingMap
()
:
internalMap
()
{}
template
<
typename
K
,
typename
V
>
bool
BlockingMap
<
K
,
V
>::
Insert
(
const
K
&
key
,
const
V
&
value
)
{
LockGuard
lock
(
mutex
);
return
internalMap
.
insert
(
std
::
map
<
K
,
V
>::
value_type
(
key
,
value
)).
second
;
}
template
<
typename
K
,
typename
V
>
bool
BlockingMap
<
K
,
V
>::
Erase
(
const
K
&
key
)
{
LockGuard
lock
(
mutex
);
return
internalMap
.
erase
(
key
)
>
0
;
}
template
<
typename
K
,
typename
V
>
bool
BlockingMap
<
K
,
V
>::
Contains
(
const
K
&
key
)
{
LockGuard
lock
(
mutex
);
return
internalMap
.
count
(
key
)
>
0
;
}
template
<
typename
K
,
typename
V
>
V
&
BlockingMap
<
K
,
V
>::
operator
[](
const
K
&
key
)
{
LockGuard
lock
(
mutex
);
return
internalMap
[
key
];
}
}
}
#endif // EMBB_CONTAINERS_INTERNAL_BLOCKING_MAP_INL_H_
\ No newline at end of file
This diff is collapsed.
Click to expand it.
containers_cpp/test/blocking_map_test-inl.h
0 → 100755
View file @
526d902a
/*
* Copyright (c) 2014-2016, Siemens AG. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*/
#ifndef CONTAINERS_CPP_TEST_MAP_TEST_INL_H_
#define CONTAINERS_CPP_TEST_MAP_TEST_INL_H_
namespace
embb
{
namespace
containers
{
namespace
test
{
template
<
typename
T
>
MapTest
<
T
>::
MapTest
()
:
n_threads
(
static_cast
<
int
>
(
partest
::
TestSuite
::
GetDefaultNumThreads
())),
n_iterations
(
200
),
n_operations_per_iteration
(
200
),
n_map_elements_per_thread
(
100
),
map
(),
map_contain_vector
(
static_cast
<
unsigned
int
>
(
n_map_elements_per_thread
*
n_threads
))
{
CreateUnit
(
"MapTestThreadsInsertAndEraseToGlobalMap"
).
Pre
(
&
MapTest
::
MapTest1_Pre
,
this
).
Add
(
&
MapTest
::
MapTest1_ThreadMethod
,
this
,
static_cast
<
size_t
>
(
n_threads
),
static_cast
<
size_t
>
(
n_iterations
)).
Post
(
&
MapTest
::
MapTest1_Post
,
this
);
}
template
<
typename
T
>
void
MapTest
<
T
>::
MapTest1_Pre
()
{
embb_internal_thread_index_reset
();
thread_local_vectors_key
=
new
std
::
vector
<
int
>
[
static_cast
<
unsigned
int
>
(
n_threads
)];
thread_local_vectors_value
=
new
std
::
vector
<
int
>
[
static_cast
<
unsigned
int
>
(
n_threads
)];
for
(
int
i
=
0
;
i
!=
n_threads
;
++
i
)
{
int
offset
=
n_map_elements_per_thread
;
for
(
int
i2
=
0
;
i2
!=
n_map_elements_per_thread
;
++
i2
)
{
int
insert_element
=
i2
+
(
offset
*
i
);
thread_local_vectors_key
[
i
].
push_back
(
insert_element
);
thread_local_vectors_value
[
i
].
push_back
(
insert_element
*
2
);
map_contain_vector
[
static_cast
<
unsigned
int
>
(
insert_element
)]
=
false
;
}
}
}
template
<
typename
T
>
void
MapTest
<
T
>::
MapTest1_Post
()
{
unsigned
int
map_elements
=
map_contain_vector
.
size
();
for
(
unsigned
int
i
=
0
;
i
<
map_elements
;
i
++
)
{
PT_ASSERT
(
map_contain_vector
[
i
]
==
map
.
Contains
(
static_cast
<
int
>
(
i
)));
if
(
map_contain_vector
[
i
])
PT_ASSERT
((
map
[
i
]
==
i
*
2
));
}
}
template
<
typename
T
>
void
MapTest
<
T
>::
MapTest1_ThreadMethod
()
{
unsigned
int
thread_index
;
int
return_val
=
embb_internal_thread_index
(
&
thread_index
);
PT_ASSERT
((
EMBB_SUCCESS
==
return_val
));
srand
(
time
(
NULL
));
std
::
vector
<
int
>&
my_values
=
thread_local_vectors_value
[
thread_index
];
std
::
vector
<
int
>&
my_keys
=
thread_local_vectors_key
[
thread_index
];
for
(
int
i
=
0
;
i
<
n_operations_per_iteration
;
i
++
)
{
int
random_number
=
rand
()
%
100
;
int
inserting
=
rand
()
%
2
;
int
key
=
my_keys
[
static_cast
<
unsigned
int
>
(
random_number
)];
int
value
=
my_values
[
static_cast
<
unsigned
int
>
(
random_number
)];
if
(
inserting
)
{
PT_ASSERT
(
map
.
Insert
(
key
,
value
)
!=
map_contain_vector
[
static_cast
<
unsigned
int
>
(
key
)]);
map_contain_vector
[
static_cast
<
unsigned
int
>
(
key
)]
=
true
;
}
else
{
PT_ASSERT
(
map
.
Erase
(
key
)
==
map_contain_vector
[
static_cast
<
unsigned
int
>
(
key
)]);
map_contain_vector
[
static_cast
<
unsigned
int
>
(
key
)]
=
false
;
}
}
}
}
// namespace test
}
// namespace containers
}
// namespace embb
#endif // CONTAINERS_CPP_TEST_MAP_TEST_INL_H_
\ No newline at end of file
This diff is collapsed.
Click to expand it.
containers_cpp/test/blocking_map_test.h
0 → 100755
View file @
526d902a
/*
* Copyright (c) 2014-2016, Siemens AG. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*/
#ifndef CONTAINERS_CPP_TEST_MAP_TEST_H_
#define CONTAINERS_CPP_TEST_MAP_TEST_H_
#include <vector>
#include <partest/partest.h>
#include <time.h>
#include <embb/base/duration.h>
namespace
embb
{
namespace
containers
{
namespace
test
{
template
<
typename
Map_t
>
class
MapTest
:
public
partest
::
TestCase
{
private
:
int
n_threads
;
int
n_iterations
;
int
n_operations_per_iteration
;
int
n_map_elements_per_thread
;
Map_t
map
;
std
::
vector
<
int
>*
thread_local_vectors_key
;
std
::
vector
<
int
>*
thread_local_vectors_value
;
std
::
vector
<
bool
>
map_contain_vector
;
public
:
MapTest
();
void
MapTest1_Pre
();
void
MapTest1_Post
();
void
MapTest1_ThreadMethod
();
};
}
// namespace test
}
// namespace containers
}
// namespace embb
#include "./blocking_map_test-inl.h"
#endif
\ No newline at end of file
This diff is collapsed.
Click to expand it.
containers_cpp/test/main.cc
View file @
526d902a
...
...
@@ -33,6 +33,7 @@
#include <embb/containers/lock_free_mpmc_queue.h>
#include <embb/containers/blocking_queue.h>
#include <embb/containers/blocking_set.h>
#include <embb/containers/blocking_map.h>
#include <embb/base/c/memory_allocation.h>
#include <partest/partest.h>
...
...
@@ -46,6 +47,7 @@
#include "./hazard_pointer_test.h"
#include "./object_pool_test.h"
#include "./set_test.h"
#include "./blocking_map_test.h"
#define COMMA ,
...
...
@@ -59,6 +61,7 @@ using embb::containers::BlockingStack;
using
embb
::
containers
::
LockFreeTreeValuePool
;
using
embb
::
containers
::
WaitFreeArrayValuePool
;
using
embb
::
containers
::
BlockingSet
;
using
embb
::
containers
::
BlockingMap
;
using
embb
::
containers
::
test
::
PoolTest
;
using
embb
::
containers
::
test
::
HazardPointerTest
;
using
embb
::
containers
::
test
::
QueueTest
;
...
...
@@ -68,6 +71,7 @@ using embb::containers::test::BlockingStackTest;
using
embb
::
containers
::
test
::
SetTest
;
using
embb
::
containers
::
test
::
ObjectPoolTest
;
using
embb
::
containers
::
test
::
HazardPointerTest2
;
using
embb
::
containers
::
test
::
MapTest
;
PT_MAIN
(
"Data Structures C++"
)
{
...
...
@@ -85,6 +89,7 @@ PT_MAIN("Data Structures C++") {
PT_RUN
(
StackTest
<
LockFreeStack
<
int
>
>
);
PT_RUN
(
BlockingStackTest
<
BlockingStack
<
int
>
>
);
PT_RUN
(
SetTest
<
BlockingSet
<
int
>
>
);
PT_RUN
(
MapTest
<
BlockingMap
<
int
COMMA
int
>
>
);
PT_RUN
(
ObjectPoolTest
<
LockFreeTreeValuePool
<
bool
COMMA
false
>
>
);
PT_RUN
(
ObjectPoolTest
<
WaitFreeArrayValuePool
<
bool
COMMA
false
>
>
);
PT_EXPECT
(
embb_get_bytes_allocated
()
==
0
);
...
...
This diff is collapsed.
Click to expand it.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment