Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Greenplum
Opencv
提交
1e8b72f8
O
Opencv
项目概览
Greenplum
/
Opencv
11 个月 前同步成功
通知
7
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
O
Opencv
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
1e8b72f8
编写于
10月 22, 2013
作者:
A
Andrey Pavlenko
提交者:
OpenCV Buildbot
10月 22, 2013
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #1658 from alalek:ocl_fixes
上级
a54d36bd
e7fd0534
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
25 addition
and
20 deletion
+25
-20
modules/ocl/src/cl_programcache.cpp
modules/ocl/src/cl_programcache.cpp
+23
-18
modules/ocl/src/cl_programcache.hpp
modules/ocl/src/cl_programcache.hpp
+0
-1
modules/ocl/src/fft.cpp
modules/ocl/src/fft.cpp
+2
-1
未找到文件。
modules/ocl/src/cl_programcache.cpp
浏览文件 @
1e8b72f8
...
...
@@ -61,12 +61,16 @@ namespace cv { namespace ocl {
cv
::
Mutex
ProgramCache
::
mutexFiles
;
cv
::
Mutex
ProgramCache
::
mutexCache
;
std
::
auto_ptr
<
ProgramCache
>
_programCache
;
ProgramCache
*
_programCache
=
NULL
;
ProgramCache
*
ProgramCache
::
getProgramCache
()
{
if
(
NULL
==
_programCache
.
get
())
_programCache
.
reset
(
new
ProgramCache
());
return
_programCache
.
get
();
if
(
NULL
==
_programCache
)
{
cv
::
AutoLock
lock
(
getInitializationMutex
());
if
(
NULL
==
_programCache
)
_programCache
=
new
ProgramCache
();
}
return
_programCache
;
}
ProgramCache
::
ProgramCache
()
...
...
@@ -78,6 +82,12 @@ ProgramCache::ProgramCache()
ProgramCache
::~
ProgramCache
()
{
releaseProgram
();
if
(
this
==
_programCache
)
{
cv
::
AutoLock
lock
(
getInitializationMutex
());
if
(
this
==
_programCache
)
_programCache
=
NULL
;
}
}
cl_program
ProgramCache
::
progLookup
(
const
string
&
srcsign
)
...
...
@@ -420,22 +430,17 @@ struct ProgramFileCache
{
if
(
status
==
CL_BUILD_PROGRAM_FAILURE
)
{
cl_int
logStatus
;
char
*
buildLog
=
NULL
;
size_t
buildLogSize
=
0
;
logStatus
=
clGetProgramBuildInfo
(
program
,
getClDeviceID
(
ctx
),
CL_PROGRAM_BUILD_LOG
,
buildLogSize
,
buildLog
,
&
buildLogSize
);
if
(
logStatus
!=
CL_SUCCESS
)
std
::
cout
<<
"Failed to build the program and get the build info."
<<
endl
;
buildLog
=
new
char
[
buildLogSize
];
CV_DbgAssert
(
!!
buildLog
);
memset
(
buildLog
,
0
,
buildLogSize
);
openCLSafeCall
(
clGetProgramBuildInfo
(
program
,
getClDeviceID
(
ctx
),
CL_PROGRAM_BUILD_LOG
,
buildLogSize
,
buildLog
,
NULL
));
std
::
cout
<<
"
\n
BUILD LOG: "
<<
options
<<
"
\n
"
;
std
::
cout
<<
buildLog
<<
endl
;
delete
[]
buildLog
;
CL_PROGRAM_BUILD_LOG
,
0
,
NULL
,
&
buildLogSize
));
std
::
vector
<
char
>
buildLog
;
buildLog
.
resize
(
buildLogSize
);
memset
(
&
buildLog
[
0
],
0
,
buildLogSize
);
openCLSafeCall
(
clGetProgramBuildInfo
(
program
,
getClDeviceID
(
ctx
),
CL_PROGRAM_BUILD_LOG
,
buildLogSize
,
&
buildLog
[
0
],
NULL
));
std
::
cout
<<
std
::
endl
<<
"BUILD LOG: "
<<
(
source
->
name
?
source
->
name
:
"dynamic program"
)
<<
": "
<<
options
<<
"
\n
"
;
std
::
cout
<<
&
buildLog
[
0
]
<<
endl
;
}
openCLVerifyCall
(
status
);
}
...
...
modules/ocl/src/cl_programcache.hpp
浏览文件 @
1e8b72f8
...
...
@@ -52,7 +52,6 @@ class ProgramCache
protected:
ProgramCache
();
~
ProgramCache
();
friend
class
std
::
auto_ptr
<
ProgramCache
>
;
public:
static
ProgramCache
*
getProgramCache
();
...
...
modules/ocl/src/fft.cpp
浏览文件 @
1e8b72f8
...
...
@@ -126,7 +126,8 @@ void cv::ocl::fft_setup()
{
return
;
}
pCache
.
setupData
=
new
clAmdFftSetupData
;
if
(
pCache
.
setupData
==
NULL
)
pCache
.
setupData
=
new
clAmdFftSetupData
;
openCLSafeCall
(
clAmdFftInitSetupData
(
pCache
.
setupData
));
pCache
.
started
=
true
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录