Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
天地威能
oceanbase
提交
d77929b0
O
oceanbase
项目概览
天地威能
/
oceanbase
与 Fork 源项目一致
Fork自
oceanbase / oceanbase
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
O
oceanbase
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
d77929b0
编写于
11月 17, 2022
作者:
O
obdev
提交者:
wangzelin.wzl
11月 17, 2022
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Bugfix for API common_copy_string_zf when vectorization is ON
上级
58f03c70
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
18 addition
and
18 deletion
+18
-18
src/sql/engine/expr/ob_datum_cast.cpp
src/sql/engine/expr/ob_datum_cast.cpp
+6
-18
src/sql/engine/expr/ob_expr.cpp
src/sql/engine/expr/ob_expr.cpp
+11
-0
src/sql/engine/expr/ob_expr.h
src/sql/engine/expr/ob_expr.h
+1
-0
未找到文件。
src/sql/engine/expr/ob_datum_cast.cpp
浏览文件 @
d77929b0
...
...
@@ -515,16 +515,10 @@ static int common_copy_string(const ObExpr &expr,
int
ret
=
OB_SUCCESS
;
char
*
out_ptr
=
NULL
;
int64_t
len
=
align_offset
+
src
.
length
();
if
(
expr
.
res_buf_len_
<
len
)
{
if
(
OB_ISNULL
(
out_ptr
=
expr
.
get_str_res_mem
(
ctx
,
len
)))
{
ret
=
OB_ALLOCATE_MEMORY_FAILED
;
LOG_WARN
(
"allocate memory failed"
,
K
(
ret
));
}
if
(
OB_ISNULL
(
out_ptr
=
expr
.
get_str_res_mem
(
ctx
,
len
)))
{
ret
=
OB_ALLOCATE_MEMORY_FAILED
;
LOG_WARN
(
"allocate memory failed"
,
K
(
ret
));
}
else
{
out_ptr
=
const_cast
<
char
*>
(
res_datum
.
ptr_
);
}
if
(
OB_SUCC
(
ret
))
{
MEMMOVE
(
out_ptr
+
align_offset
,
src
.
ptr
(),
len
-
align_offset
);
MEMSET
(
out_ptr
,
0
,
align_offset
);
res_datum
.
set_string
(
out_ptr
,
len
);
...
...
@@ -552,16 +546,10 @@ static int common_copy_string_zf(const ObExpr &expr,
}
else
if
(
CM_IS_ZERO_FILL
(
expr
.
extra_
)
&&
out_len
>
src
.
length
())
{
char
*
out_ptr
=
NULL
;
// out_ptr may overlap with src, so memmove is used.
if
(
expr
.
res_buf_len_
<
out_len
)
{
if
(
OB_ISNULL
(
out_ptr
=
expr
.
get_str_res_mem
(
ctx
,
out_len
)))
{
ret
=
OB_ALLOCATE_MEMORY_FAILED
;
LOG_WARN
(
"allocate memory failed"
,
K
(
ret
));
}
if
(
OB_ISNULL
(
out_ptr
=
expr
.
get_str_res_mem
(
ctx
,
out_len
)))
{
ret
=
OB_ALLOCATE_MEMORY_FAILED
;
LOG_WARN
(
"allocate memory failed"
,
K
(
ret
));
}
else
{
out_ptr
=
const_cast
<
char
*>
(
res_datum
.
ptr_
);
}
if
(
OB_SUCC
(
ret
))
{
int64_t
zf_len
=
out_len
-
src
.
length
();
if
(
0
<
zf_len
)
{
MEMMOVE
(
out_ptr
+
zf_len
,
src
.
ptr
(),
src
.
length
());
...
...
src/sql/engine/expr/ob_expr.cpp
浏览文件 @
d77929b0
...
...
@@ -574,6 +574,16 @@ void ObExpr::reset_datums_ptr(char *frame, const int64_t size) const
}
}
void
ObExpr
::
reset_datum_ptr
(
char
*
frame
,
const
int64_t
size
,
const
int64_t
idx
)
const
{
ObDatum
*
datum
=
reinterpret_cast
<
ObDatum
*>
(
frame
+
datum_off_
);
datum
+=
idx
;
char
*
ptr
=
frame
+
res_buf_off_
+
(
batch_idx_mask_
&
idx
)
*
res_buf_len_
;
if
(
datum
->
ptr_
!=
ptr
&&
idx
<
size
)
{
datum
->
ptr_
=
ptr
;
}
}
int
ObExpr
::
eval_one_datum_of_batch
(
ObEvalCtx
&
ctx
,
common
::
ObDatum
*&
datum
)
const
{
int
ret
=
OB_SUCCESS
;
...
...
@@ -599,6 +609,7 @@ int ObExpr::eval_one_datum_of_batch(ObEvalCtx &ctx, common::ObDatum *&datum) con
}
datum
=
reinterpret_cast
<
ObDatum
*>
(
frame
+
datum_off_
)
+
ctx
.
get_batch_idx
();
if
(
need_evaluate
)
{
reset_datum_ptr
(
frame
,
ctx
.
get_batch_size
(),
ctx
.
get_batch_idx
());
ret
=
eval_func_
(
*
this
,
ctx
,
*
datum
);
if
(
OB_SUCC
(
ret
))
{
ObBitVector
*
evaluated_flags
=
to_bit_vector
(
frame
+
eval_flags_off_
);
...
...
src/sql/engine/expr/ob_expr.h
浏览文件 @
d77929b0
...
...
@@ -571,6 +571,7 @@ private:
char
*
alloc_str_res_mem
(
ObEvalCtx
&
ctx
,
const
int64_t
size
,
const
int64_t
idx
)
const
;
// reset datums pointer to reserved buffer.
void
reset_datums_ptr
(
char
*
frame
,
const
int64_t
size
)
const
;
void
reset_datum_ptr
(
char
*
frame
,
const
int64_t
size
,
const
int64_t
idx
)
const
;
int
eval_one_datum_of_batch
(
ObEvalCtx
&
ctx
,
common
::
ObDatum
*&
datum
)
const
;
int
do_eval_batch
(
ObEvalCtx
&
ctx
,
const
ObBitVector
&
skip
,
const
int64_t
size
)
const
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录