-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathREADME
346 lines (250 loc) · 10.8 KB
/
README
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
========================================================================
OpenVX 1.0 Sample Implementation
========================================================================
This document outlines the purpose of this sample implementation as well
as provide build and execution instructions.
CONTENTS:
1 PURPOSE
2 BUILDING & EXECUTING
2.1 CMAKE
2.2 Concerto
3 INCLUDED UNIT TESTS
4 DEBUGGING
5 PACKAGING and INSTALLING
6 BUG REPORTING
1 PURPOSE:
------------------------------------------------------------------------
The purpose of this software package is to provide a sample implementation
of the OpenVX 1.0 Specification that passes the conformance test. It is
NOT intended to be a reference implementation. If there are any discrepancies
with the OpenVX 1.0 specification, they are not intentional and the
specification should take precedence. Many of the design decisions made
in this sample implementation were motivated out of convenience rather
than optimizing for performance. It is expected that vendor's implementations
would choose to make different design choices based on their priorities,
and the specification was written in such a way as to allow freedom to do
so. Beyond the conformance tests, there was very limited testing, as this
was not intended to be directly used as production software.
This sample implementation contains additional 'experimental' or 'internally
proposed' features which are not included in OpenVX 1.0. Since these are
not part of OpenVX, these are disabled by default in the build by using
preprocessor definitions. These features may potentially be modified or
may never be added to the OpenVX spec, and should not be relied on as such.
Additional details on these preprocessor definitions can be found in the
BUILD_DEFINES document in this same folder.
Future revisions of the OpenVX sample implementation may or may not be
released, and Khronos is not actively maintaining a public open source sample
implementation project.
The following is a summary of what this sample implementation IS and IS NOT:
IS:
- passing OpenVX 1.0 compliance tests
IS NOT:
- a reference implementation
- optimized
- production ready
- actively maintained by Khronos publically
2 BUILDING & EXECUTING
------------------------------------------------------------------------
The sample implementation contains two different build system options:
cmake and concerto (non-standard makefile-based system). The build and
execution instructions for each are shown below.
2.1 CMAKE
---------
Supported systems:
------------------
1. Linux
2. Android
3. Windows (Visual studio or Cygwin)
Pre-requisite:
--------------
python 2.x (Tested with python 2.7)
CMAKE 2.8.12 or higher. (should be in PATH)
Windows:
--------
Visual studio 12 (2013) or higher in order to create VS solution and use VS compiler to build OpenVX and related projects. (Need DEVENV in PATH)
Or Cygwin.
Android:
--------
NDK tool chain.
Building:
---------
Windows:
--------
From VS / Cygwin command prompt:
> python Build.py --help
In case of Visual Studio solution, the default CMAKE_GENERATOR is "Visual Studio 12", you can change it with --gen option. (cmake --help present the supported generators)
Linux:
------
From shell:
> python Build.py --help
The command above will present the available build options, please follow these options.
VS solution will create in:
---------------------------
${OUTPUT_PATH}/build/${OS}/${ARCH}/OpenVX.sln
In order to build and install all the sample projects from VS, build the 'INSTALL' project. (Build.py trigger it by default)
Make files will create in:
--------------------------
${OUTPUT_PATH}/build/${OS}/${ARCH}/${CONF}
In order to build and install all the sample projects, call to 'make install'. (Build.py trigger it by default)
OUTPUT_PATH - The path to output, default the root directory.
OS - Win / Linux / Android. (Cygwin is equal to Linux)
ARCH - 32 / 64
CONF - Release / Debug.
Install:
--------
The build process installs the OpenVX headers in 'include' folder / executables and libraries in 'bin' folder / libs in 'lib' folder under:
${OUTPUT_PATH}/install/${OS}/${ARCH}/${CONF}
Running:
--------
Windows:
--------
Add ${OUTPUT_PATH}/install/${OS}/${ARCH}/${CONF}/bin to PATH
Linux:
------
Set LD_LIBRARY_PATH ${OUTPUT_PATH}/install/${OS}/${ARCH}/${CONF}/bin
$ cd raw
$ ${OUTPUT_PATH}/install/${OS}/${ARCH}/${CONF}/bin/vx_test
2.2 Concerto
------------
The following systems are supported by the concerto build:
1. Linux (GCC or CLANG)
2. Darwin/Mac OSX
3. Windows NT (Cygwin or native Visual Studio 2013)
For each system, consider the following prerequisites:
1. Linux
--------
gcc is the default compiler. If clang is desired, then it can be chosen
by setting the HOST_COMPILER environment variable to CLANG.
If using gcc, version 4.3.0 or above should be used.
2. Darwin/OSX
-------------
Mac OSX Users need to use either MacPorts or Fink (or other favorite
package manager) to install the same set of packages above.
3. Windows NT (Cygwin or native)
-----------------------------
(Cygwin)
--------
It is recommended that Windows users install Cygwin to build OpenVX.
Obtain and run the setup utility at:
http://cygwin.com/setup.exe
In addition to the defaults, you MUST manually select the gcc-core,
make, and gcc-g++ packages in the cygwin setup utility. All are in
the "Devel" category. gcc version 4.3.0 or above should be used.
(native MS Visual Studio 2013)
--------
Required packages to build:
- Microsoft Visual Studio 2013 (at least)
- A make utility compiled for windows (examples):
- mingw32-make.exe (http://www.mingw.org)
- gmake from XDCTools (http://downloads.ti.com/dsps/dsps_public_sw/sdo_sb/targetcontent/rtsc/)
For building the code, adding the path to "make.exe" to
the PATH is required after the "vcvarsall.bat" batch file (which
configures the environment for compiling with VC) is executed from a
CMD window.
Building OpenVX using Concerto
------------------------------
Once the correct packages above are installed, the sample
implementation can be built by typing "make" in the OpenVX
installation directory (e.g., "openvx_sample").
$ cd openvx_sample
$ make
Outputs are placed in
out/$(TARGET_OS)/$(TARGET_CPU)/$(TARGET_BUILD)/
These variables are visible in the make output. This will be referred to
as TARGET_OUT, though this may not be present in the actual environment
(users could define this themselves).
In order to see a list and description of all make commands for concerto,
type:
$ make help
Executing OpenVX using Concerto
-------------------------------
The tests can be manually run as follows. In any environment, PATHs may
need to be altered to allow loading dynamic modules. The $(TARGET_OUT)
variable below should be replaced with the actual path to the output
file where the libraries and executables are placed, as per the description
in section 1: BUILD.
On Linux
--------
TARGET_OUT is usually out/LINUX/x86_64/release
$ cd raw
$ LD_LIBRARY_PATH=../$(TARGET_OUT) ../$(TARGET_OUT)/vx_test
On Windows (Cygwin)
-------------------
TARGET_OUT is usually
out/CYGWIN/X86/release
Commands:
$ cd raw
$ LD_LIBRARY_PATH=../$(TARGET_OUT) ../$(TARGET_OUT)/vx_test
On Windows (native)
-------------------
TARGET_OUT is usually
out\Windows_NT\x86\release
Commands:
C:\> copy raw\*.* %TARGET_OUT%
C:\> pushd %TARGET_OUT% && vx_test.exe
On Mac OSX (from openvx_sample)
------------------------------------
TARGET_OUT is usually
out/DARWIN/x86_64/release
Commands:
$ cd raw
$ DYLD_LIBRARY_PATH=../$(TARGET_OUT) ../$(TARGET_OUT)/vx_test
3 INCLUDED UNIT TESTS
------------------------------------------------------------------------
The sample implementation comes with a few unit sanity tests that exercises
some examples of the specification. The executables are called:
vx_test:
- main function is in source file: openvx_sample/tests/vx_test.c
- No arguments will run all included unit tests.
- -? argument will list the tests to be run
- Single tests can be run by specifying test number using -t <testnum>
- expects to be run from the raw directory (the program looks for
image files in the execution directory).
vx_query:
- main function is in source file: openvx_sample/tools/query/vx_query.c
- Queries the implementation and prints out details about all kernels
vx_example:
- main function is in source file: openvx_sample/examples/vx_graph_factory.c
- This is an example of creating and running a graph using what is
called a graph factory. This example is beyond the scope of the
openvx specification, but is an example of how graph parameters
can be use to abstract the details of a graph to clients.
4 DEBUGGING
------------------------------------------------------------------------
To build in debug mode (this will output in the out/.../debug folder rather
than out/.../release, thus if you defined TARGET_OUT, you'll have to change it.
$ export NO_OPTIMIZE=1
$ make
or
$ make TARGET_BUILD=debug
To enable traces (printfs/logs/etc), use either the mask (higher priority) or
list of zones to enable. In the mask, the zones are the bit places. Express the
mask as a hex number.
$ export VX_ZONE_MASK=0x<hexnumber>
or use the list as a comma delimited set of zone numbers (see 'sample/include/vx_debug.h')
$ export VX_ZONE_LIST=0,1,2,3,6,9,14
The list of mapping zones to bits can be found in openvx_sample/debug/vx_debug.h
If you want these variable as part of the command line:
$ unset VX_ZONE_MASK
$ unset VX_ZONE_LIST
$ make
$ cd raw
$ VX_ZONE_LIST=0,3,16 vx_test <options>
Note: VX_ZONE_MASK will override VX_ZONE_LIST. So if you have both set, only
VX_ZONE_MASK is being seen by the implementation.
Now run your tests again.
5 PACKAGING and INSTALLING
------------------------------------------------------------------------
On Linux, the sample implementation for OpenVX is packaged after a make in
out/LINUX/x86_64/openvx-*.deb
Installing DEB package
$ dpkg-deb -i <path>/openvx-*.deb
6 BUG REPORTING
------------------------------------------------------------------------
Although Khronos is not actively maintaining a public project of this
sample implementation, bug reports can be reported back to the working
group in an effort to make sure that we don't overlook related specification
and implementation issues going forward.
If any bugs are found in the sample implementation, you can notify the
Khronos working group via the OpenVX feedback forum:
https://www.khronos.org/openvx/feedback_forum