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
a65f0a66
authored
Mar 24, 2015
by
Marcus Winter
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
examples: fixed tasks example, added mtapi_cpp
parent
104e7833
Show whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
105 additions
and
2 deletions
+105
-2
doc/examples/CMakeLists.txt
+2
-1
doc/examples/main.cc
+8
-0
doc/examples/mtapi/mtapi_cpp-fragmented.cc
+68
-0
doc/examples/mtapi/mtapi_cpp_calc_task-snippet.h
+3
-0
doc/examples/mtapi/mtapi_cpp_domain_node_id-snippet.h
+5
-0
doc/examples/mtapi/mtapi_cpp_finalize-snippet.h
+2
-0
doc/examples/mtapi/mtapi_cpp_get_node-snippet.h
+1
-0
doc/examples/mtapi/mtapi_cpp_initialize-snippet.h
+2
-0
doc/examples/mtapi/mtapi_cpp_register_action-snippet.h
+9
-0
doc/examples/mtapi/mtapi_cpp_start_task-snippet.h
+2
-0
doc/examples/mtapi/mtapi_cpp_wait_task-snippet.h
+2
-0
doc/examples/tasks/tasks_cpp-fragmented.cc
+1
-1
No files found.
doc/examples/CMakeLists.txt
View file @
a65f0a66
...
@@ -10,6 +10,7 @@ include_directories(
...
@@ -10,6 +10,7 @@ include_directories(
${
CMAKE_CURRENT_SOURCE_DIR
}
/../../base_cpp/include
${
CMAKE_CURRENT_SOURCE_DIR
}
/../../base_cpp/include
${
CMAKE_CURRENT_BINARY_DIR
}
/../../base_cpp/include
${
CMAKE_CURRENT_BINARY_DIR
}
/../../base_cpp/include
${
CMAKE_CURRENT_SOURCE_DIR
}
/../../mtapi_c/include
${
CMAKE_CURRENT_SOURCE_DIR
}
/../../mtapi_c/include
${
CMAKE_CURRENT_SOURCE_DIR
}
/../../mtapi_cpp/include
${
CMAKE_CURRENT_SOURCE_DIR
}
/../../tasks_cpp/include
${
CMAKE_CURRENT_SOURCE_DIR
}
/../../tasks_cpp/include
${
CMAKE_CURRENT_BINARY_DIR
}
/../../tasks_cpp/include
${
CMAKE_CURRENT_BINARY_DIR
}
/../../tasks_cpp/include
${
CMAKE_CURRENT_SOURCE_DIR
}
/../../containers_cpp/include
${
CMAKE_CURRENT_SOURCE_DIR
}
/../../containers_cpp/include
...
@@ -22,6 +23,6 @@ if(CMAKE_COMPILER_IS_GNUCXX)
...
@@ -22,6 +23,6 @@ if(CMAKE_COMPILER_IS_GNUCXX)
endif
()
endif
()
add_executable
(
examples
${
EXAMPLES_SOURCES
}
)
add_executable
(
examples
${
EXAMPLES_SOURCES
}
)
target_link_libraries
(
examples embb_dataflow_cpp embb_algorithms_cpp embb_tasks_cpp
target_link_libraries
(
examples embb_dataflow_cpp embb_algorithms_cpp embb_tasks_cpp
embb_mtapi_cpp
embb_mtapi_c embb_base_cpp embb_base_c embb_containers_cpp
${
compiler_libs
}
)
embb_mtapi_c embb_base_cpp embb_base_c embb_containers_cpp
${
compiler_libs
}
)
CopyBin
(
BIN examples DEST
${
local_install_dir
}
)
CopyBin
(
BIN examples DEST
${
local_install_dir
}
)
doc/examples/main.cc
View file @
a65f0a66
...
@@ -25,9 +25,11 @@
...
@@ -25,9 +25,11 @@
*/
*/
#include <iostream>
#include <iostream>
#include <embb/base/c/thread.h>
void
RunMTAPI_C
();
void
RunMTAPI_C
();
void
RunMTAPI_CPP
();
void
RunMTAPI_CPP
();
void
RunTasks
();
void
RunDataflowLinear
();
void
RunDataflowLinear
();
void
RunDataflowNonLinear
();
void
RunDataflowNonLinear
();
void
RunSTLForEach
();
void
RunSTLForEach
();
...
@@ -45,6 +47,8 @@ void RunQueueExamples();
...
@@ -45,6 +47,8 @@ void RunQueueExamples();
* Runs all examples and tests their correctness.
* Runs all examples and tests their correctness.
*/
*/
int
main
()
{
int
main
()
{
embb_thread_set_max_count
(
1024
);
std
::
cout
<<
"Running examples ..."
<<
std
::
endl
;
std
::
cout
<<
"Running examples ..."
<<
std
::
endl
;
std
::
cout
<<
"RunMTAPI_C() ..."
<<
std
::
endl
;
std
::
cout
<<
"RunMTAPI_C() ..."
<<
std
::
endl
;
...
@@ -55,6 +59,10 @@ int main() {
...
@@ -55,6 +59,10 @@ int main() {
RunMTAPI_CPP
();
RunMTAPI_CPP
();
std
::
cout
<<
"RunMTAPI_CPP() ... done"
<<
std
::
endl
;
std
::
cout
<<
"RunMTAPI_CPP() ... done"
<<
std
::
endl
;
std
::
cout
<<
"RunTasks() ..."
<<
std
::
endl
;
RunTasks
();
std
::
cout
<<
"RunTasks() ... done"
<<
std
::
endl
;
std
::
cout
<<
"RunDataflowLinear() ..."
<<
std
::
endl
;
std
::
cout
<<
"RunDataflowLinear() ..."
<<
std
::
endl
;
RunDataflowLinear
();
RunDataflowLinear
();
std
::
cout
<<
"RunDataflowLinear() ... done"
<<
std
::
endl
;
std
::
cout
<<
"RunDataflowLinear() ... done"
<<
std
::
endl
;
...
...
doc/examples/mtapi/mtapi_cpp-fragmented.cc
0 → 100644
View file @
a65f0a66
/*
* Copyright (c) 2014-2015, 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.
*/
#include <iostream>
#include <embb/mtapi/mtapi.h>
#include "mtapi/mtapi_check_status-snippet.h"
#include "mtapi/mtapi_cpp_domain_node_id-snippet.h"
static
#include "mtapi/mtapi_c_action_signature-snippet.h"
#include "mtapi/mtapi_c_validate_arguments-snippet.h"
#include "mtapi/mtapi_c_validate_result_buffer-snippet.h"
/* get the node instance */
#include "mtapi/mtapi_cpp_get_node-snippet.h"
/* calculate */
#include "mtapi/mtapi_terminating_condition-snippet.h"
/* first recursive call spawned as task (x = fib(n - 1);) */
#include "mtapi/mtapi_cpp_calc_task-snippet.h"
/* second recursive call can be called directly (y = fib(n - 2);) */
#include "mtapi/mtapi_c_calc_direct-snippet.h"
/* wait for completion */
#include "mtapi/mtapi_cpp_wait_task-snippet.h"
/* add the two preceeding numbers */
#include "mtapi/mtapi_write_back-snippet.h"
static
int
fibonacci
(
int
n
)
{
#include "mtapi/mtapi_cpp_initialize-snippet.h"
#include "mtapi/mtapi_cpp_register_action-snippet.h"
#include "mtapi/mtapi_cpp_get_node-snippet.h"
/* start calculation */
#include "mtapi/mtapi_cpp_start_task-snippet.h"
/* wait for task completion */
mtapi_status_t
status
=
task
.
Wait
(
MTAPI_INFINITE
);
MTAPI_CHECK_STATUS
(
status
);
#include "mtapi/mtapi_cpp_finalize-snippet.h"
return
result
;
}
void
RunMTAPI_CPP
()
{
int
result
=
fibonacci
(
6
);
std
::
cout
<<
"result: "
<<
result
<<
std
::
endl
;
}
doc/examples/mtapi/mtapi_cpp_calc_task-snippet.h
0 → 100644
View file @
a65f0a66
int
a
=
n
-
1
;
int
x
;
embb
::
mtapi
::
Task
task
=
node
.
Start
(
fibonacciJob
,
&
a
,
&
x
);
doc/examples/mtapi/mtapi_cpp_domain_node_id-snippet.h
0 → 100644
View file @
a65f0a66
#define THIS_DOMAIN_ID 1
#define THIS_NODE_ID 1
#define FIBONACCI_JOB 1
embb
::
mtapi
::
Job
fibonacciJob
;
doc/examples/mtapi/mtapi_cpp_finalize-snippet.h
0 → 100644
View file @
a65f0a66
/* finalize the node */
embb
::
mtapi
::
Node
::
Finalize
();
doc/examples/mtapi/mtapi_cpp_get_node-snippet.h
0 → 100644
View file @
a65f0a66
embb
::
mtapi
::
Node
&
node
=
embb
::
mtapi
::
Node
::
GetInstance
();
doc/examples/mtapi/mtapi_cpp_initialize-snippet.h
0 → 100644
View file @
a65f0a66
/* initialize the node with default attributes */
embb
::
mtapi
::
Node
::
Initialize
(
THIS_DOMAIN_ID
,
THIS_NODE_ID
);
doc/examples/mtapi/mtapi_cpp_register_action-snippet.h
0 → 100644
View file @
a65f0a66
/* create action */
embb
::
mtapi
::
Action
fibonacciAction
(
FIBONACCI_JOB
,
/* action ID, defined by the
application */
(
fibonacciActionFunction
)
/* action function */
);
/* get job */
fibonacciJob
=
embb
::
mtapi
::
Job
(
FIBONACCI_JOB
,
THIS_DOMAIN_ID
);
doc/examples/mtapi/mtapi_cpp_start_task-snippet.h
0 → 100644
View file @
a65f0a66
int
result
;
embb
::
mtapi
::
Task
task
=
node
.
Start
(
fibonacciJob
,
&
n
,
&
result
);
doc/examples/mtapi/mtapi_cpp_wait_task-snippet.h
0 → 100644
View file @
a65f0a66
mtapi_status_t
status
=
task
.
Wait
(
MTAPI_INFINITE
);
MTAPI_CHECK_STATUS
(
status
);
doc/examples/tasks/tasks_cpp-fragmented.cc
View file @
a65f0a66
...
@@ -58,7 +58,7 @@ int fibonacci(int n) {
...
@@ -58,7 +58,7 @@ int fibonacci(int n) {
return
result
;
return
result
;
}
}
void
Run
MTAPI_CPP
()
{
void
Run
Tasks
()
{
int
result
=
fibonacci
(
6
);
int
result
=
fibonacci
(
6
);
std
::
cout
<<
"result: "
<<
result
<<
std
::
endl
;
std
::
cout
<<
"result: "
<<
result
<<
std
::
endl
;
}
}
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