mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-10-18 06:20:51 +00:00
Fix FBA
This commit is contained in:
parent
8483dfa272
commit
e317dfb6e4
@ -101,6 +101,8 @@ struct BinaryOperationImplBase
|
|||||||
static const constexpr bool allow_fixed_string = false;
|
static const constexpr bool allow_fixed_string = false;
|
||||||
|
|
||||||
static void vectorVector(const A * __restrict a, const B * __restrict b, ResultType * __restrict c, size_t size)
|
static void vectorVector(const A * __restrict a, const B * __restrict b, ResultType * __restrict c, size_t size)
|
||||||
|
{
|
||||||
|
if constexpr (UseMultitargetCode)
|
||||||
{
|
{
|
||||||
if (IsArchSupported(TargetArch::AVX512F))
|
if (IsArchSupported(TargetArch::AVX512F))
|
||||||
TargetSpecific::AVX512F::BinaryOperationImplBase<A, B, Op, ResultType>::vectorVector(a, b, c, size);
|
TargetSpecific::AVX512F::BinaryOperationImplBase<A, B, Op, ResultType>::vectorVector(a, b, c, size);
|
||||||
@ -113,8 +115,16 @@ struct BinaryOperationImplBase
|
|||||||
else
|
else
|
||||||
TargetSpecific::Default::BinaryOperationImplBase<A, B, Op, ResultType>::vectorVector(a, b, c, size);
|
TargetSpecific::Default::BinaryOperationImplBase<A, B, Op, ResultType>::vectorVector(a, b, c, size);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
TargetSpecific::Default::BinaryOperationImplBase<A, B, Op, ResultType>::vectorVector(a, b, c, size);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
static void vectorConstant(const A * __restrict a, B b, ResultType * __restrict c, size_t size)
|
static void vectorConstant(const A * __restrict a, B b, ResultType * __restrict c, size_t size)
|
||||||
|
{
|
||||||
|
if constexpr (UseMultitargetCode)
|
||||||
{
|
{
|
||||||
if (IsArchSupported(TargetArch::AVX512F))
|
if (IsArchSupported(TargetArch::AVX512F))
|
||||||
TargetSpecific::AVX512F::BinaryOperationImplBase<A, B, Op, ResultType>::vectorConstant(a, b, c, size);
|
TargetSpecific::AVX512F::BinaryOperationImplBase<A, B, Op, ResultType>::vectorConstant(a, b, c, size);
|
||||||
@ -127,8 +137,15 @@ struct BinaryOperationImplBase
|
|||||||
else
|
else
|
||||||
TargetSpecific::Default::BinaryOperationImplBase<A, B, Op, ResultType>::vectorConstant(a, b, c, size);
|
TargetSpecific::Default::BinaryOperationImplBase<A, B, Op, ResultType>::vectorConstant(a, b, c, size);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
TargetSpecific::Default::BinaryOperationImplBase<A, B, Op, ResultType>::vectorConstant(a, b, c, size);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void constantVector(A a, const B * __restrict b, ResultType * __restrict c, size_t size)
|
static void constantVector(A a, const B * __restrict b, ResultType * __restrict c, size_t size)
|
||||||
|
{
|
||||||
|
if constexpr (UseMultitargetCode)
|
||||||
{
|
{
|
||||||
if (IsArchSupported(TargetArch::AVX512F))
|
if (IsArchSupported(TargetArch::AVX512F))
|
||||||
TargetSpecific::AVX512F::BinaryOperationImplBase<A, B, Op, ResultType>::constantVector(a, b, c, size);
|
TargetSpecific::AVX512F::BinaryOperationImplBase<A, B, Op, ResultType>::constantVector(a, b, c, size);
|
||||||
@ -141,6 +158,11 @@ struct BinaryOperationImplBase
|
|||||||
else
|
else
|
||||||
TargetSpecific::Default::BinaryOperationImplBase<A, B, Op, ResultType>::constantVector(a, b, c, size);
|
TargetSpecific::Default::BinaryOperationImplBase<A, B, Op, ResultType>::constantVector(a, b, c, size);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
TargetSpecific::Default::BinaryOperationImplBase<A, B, Op, ResultType>::constantVector(a, b, c, size);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static ResultType constantConstant(A a, B b)
|
static ResultType constantConstant(A a, B b)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user