2 // Copyright 2012 Francisco Jerez
4 // Permission is hereby granted, free of charge, to any person obtaining a
5 // copy of this software and associated documentation files (the "Software"),
6 // to deal in the Software without restriction, including without limitation
7 // the rights to use, copy, modify, merge, publish, distribute, sublicense,
8 // and/or sell copies of the Software, and to permit persons to whom the
9 // Software is furnished to do so, subject to the following conditions:
11 // The above copyright notice and this permission notice shall be included in
12 // all copies or substantial portions of the Software.
14 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15 // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
17 // THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
18 // OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
19 // ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
20 // OTHER DEALINGS IN THE SOFTWARE.
23 #include "core/compiler.hpp"
24 #include "core/program.hpp"
26 using namespace clover
;
28 program::program(clover::context
&ctx
, const std::string
&source
) :
29 has_source(true), context(ctx
), _devices(ctx
.devices()), _source(source
),
30 _kernel_ref_counter(0) {
33 program::program(clover::context
&ctx
,
34 const ref_vector
<device
> &devs
,
35 const std::vector
<module
> &binaries
) :
36 has_source(false), context(ctx
),
37 _devices(devs
), _kernel_ref_counter(0) {
38 for_each([&](device
&dev
, const module
&bin
) {
39 _builds
[&dev
] = { bin
};
45 program::compile(const ref_vector
<device
> &devs
, const std::string
&opts
,
46 const header_map
&headers
) {
50 for (auto &dev
: devs
) {
55 compiler::compile_program(_source
, headers
, dev
, opts
, log
);
56 _builds
[&dev
] = { m
, opts
, log
};
58 _builds
[&dev
] = { module(), opts
, log
};
66 program::link(const ref_vector
<device
> &devs
, const std::string
&opts
,
67 const ref_vector
<program
> &progs
) {
70 for (auto &dev
: devs
) {
71 const std::vector
<module
> ms
= map([&](const program
&prog
) {
72 return prog
.build(dev
).binary
;
74 std::string log
= _builds
[&dev
].log
;
77 const module m
= compiler::link_program(ms
, dev
, opts
, log
);
78 _builds
[&dev
] = { m
, opts
, log
};
80 _builds
[&dev
] = { module(), opts
, log
};
87 program::source() const {
92 program::devices() const {
93 return map(evals(), _devices
);
97 program::build::status() const {
98 if (!binary
.secs
.empty())
99 return CL_BUILD_SUCCESS
;
101 return CL_BUILD_ERROR
;
103 return CL_BUILD_NONE
;
106 cl_program_binary_type
107 program::build::binary_type() const {
108 if (any_of(type_equals(module::section::text_intermediate
), binary
.secs
))
109 return CL_PROGRAM_BINARY_TYPE_COMPILED_OBJECT
;
110 else if (any_of(type_equals(module::section::text_library
), binary
.secs
))
111 return CL_PROGRAM_BINARY_TYPE_LIBRARY
;
112 else if (any_of(type_equals(module::section::text_executable
), binary
.secs
))
113 return CL_PROGRAM_BINARY_TYPE_EXECUTABLE
;
115 return CL_PROGRAM_BINARY_TYPE_NONE
;
118 const struct program::build
&
119 program::build(const device
&dev
) const {
120 static const struct build null
;
121 return _builds
.count(&dev
) ? _builds
.find(&dev
)->second
: null
;
124 const std::vector
<module::symbol
> &
125 program::symbols() const {
127 throw error(CL_INVALID_PROGRAM_EXECUTABLE
);
129 return _builds
.begin()->second
.binary
.syms
;
133 program::kernel_ref_count() const {
134 return _kernel_ref_counter
.ref_count();