Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Menu
Open sidebar
gaoqiong
composable_kernel
Commits
c3107fd5
Commit
c3107fd5
authored
Oct 05, 2022
by
rocking
Browse files
Extract var
parent
5aa3c344
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
14 additions
and
11 deletions
+14
-11
include/ck/tensor_operation/gpu/device/device_gemm_multiple_d_layernorm_xdl_cshuffle.hpp
.../device/device_gemm_multiple_d_layernorm_xdl_cshuffle.hpp
+12
-10
include/ck/tensor_operation/gpu/grid/gridwise_gemm_multiple_d_welford_first_half_xdl_cshuffle.hpp
...dwise_gemm_multiple_d_welford_first_half_xdl_cshuffle.hpp
+2
-1
No files found.
include/ck/tensor_operation/gpu/device/device_gemm_multiple_d_layernorm_xdl_cshuffle.hpp
View file @
c3107fd5
...
@@ -340,22 +340,22 @@ struct DeviceGemmMultipleDLayernorm_Xdl_CShuffle : public BaseOperator
...
@@ -340,22 +340,22 @@ struct DeviceGemmMultipleDLayernorm_Xdl_CShuffle : public BaseOperator
b_grid_desc_n_k_
{
DeviceOp
::
MakeBGridDescriptor_N_K
(
KRaw
,
NRaw
,
StrideB
)},
b_grid_desc_n_k_
{
DeviceOp
::
MakeBGridDescriptor_N_K
(
KRaw
,
NRaw
,
StrideB
)},
ds_grid_desc_m_n_
{},
ds_grid_desc_m_n_
{},
e_grid_desc_m_n_
{
DeviceOp
::
MakeGridDescriptor_M_N
<
ELayout
>
(
MRaw
,
NRaw
,
StrideE
)},
e_grid_desc_m_n_
{
DeviceOp
::
MakeGridDescriptor_M_N
<
ELayout
>
(
MRaw
,
NRaw
,
StrideE
)},
f_grid_desc_m_n_
{
DeviceOp
::
MakeGridDescriptor_M_N
<
ELayout
>
(
f_grid_desc_m_n_
{},
MRaw
,
g_grid_desc_m_n_
{},
math
::
integer_divide_ceil
(
NRaw
,
NPerBlock
),
math
::
integer_divide_ceil
(
NRaw
,
NPerBlock
))},
g_grid_desc_m_n_
{
DeviceOp
::
MakeGridDescriptor_M_N
<
ELayout
>
(
MRaw
,
math
::
integer_divide_ceil
(
NRaw
,
NPerBlock
),
math
::
integer_divide_ceil
(
NRaw
,
NPerBlock
))},
h_grid_desc_m_n_
{
DeviceOp
::
MakeGridDescriptor_M_N
<
HLayout
>
(
MRaw
,
NRaw
,
StrideH
)},
h_grid_desc_m_n_
{
DeviceOp
::
MakeGridDescriptor_M_N
<
HLayout
>
(
MRaw
,
NRaw
,
StrideH
)},
block_2_etile_map_
{
GridwiseGemm
::
MakeDefaultBlock2ETileMap
(
e_grid_desc_m_n_
)},
block_2_etile_map_
{
GridwiseGemm
::
MakeDefaultBlock2ETileMap
(
e_grid_desc_m_n_
)},
a_element_op_
{
a_element_op
},
a_element_op_
{
a_element_op
},
b_element_op_
{
b_element_op
},
b_element_op_
{
b_element_op
},
cde_element_op_
{
cde_element_op
},
cde_element_op_
{
cde_element_op
},
h_element_op_
{
h_element_op
}
h_element_op_
{
h_element_op
},
blkGroupSize_
{
math
::
integer_divide_ceil
(
NRaw
,
NPerBlock
)}
{
{
int
welford_size
=
MRaw
*
math
::
integer_divide_ceil
(
NRaw
,
NPerBlock
);
f_grid_desc_m_n_
=
DeviceOp
::
MakeGridDescriptor_M_N
<
ELayout
>
(
MRaw
,
blkGroupSize_
,
blkGroupSize_
);
g_grid_desc_m_n_
=
DeviceOp
::
MakeGridDescriptor_M_N
<
ELayout
>
(
MRaw
,
blkGroupSize_
,
blkGroupSize_
);
int
welford_size
=
MRaw
*
blkGroupSize_
;
hip_check_error
(
hipMalloc
(
&
p_f_grid_
,
sizeof
(
FDataType
)
*
welford_size
));
hip_check_error
(
hipMalloc
(
&
p_f_grid_
,
sizeof
(
FDataType
)
*
welford_size
));
hip_check_error
(
hipMalloc
(
&
p_g_grid_
,
sizeof
(
GDataType
)
*
welford_size
));
hip_check_error
(
hipMalloc
(
&
p_g_grid_
,
sizeof
(
GDataType
)
*
welford_size
));
...
@@ -448,6 +448,8 @@ struct DeviceGemmMultipleDLayernorm_Xdl_CShuffle : public BaseOperator
...
@@ -448,6 +448,8 @@ struct DeviceGemmMultipleDLayernorm_Xdl_CShuffle : public BaseOperator
BElementwiseOperation
b_element_op_
;
BElementwiseOperation
b_element_op_
;
CDEElementwiseOperation
cde_element_op_
;
CDEElementwiseOperation
cde_element_op_
;
HElementwiseOperation
h_element_op_
;
HElementwiseOperation
h_element_op_
;
int
blkGroupSize_
;
};
};
// Invoker
// Invoker
...
...
include/ck/tensor_operation/gpu/grid/gridwise_gemm_multiple_d_welford_first_half_xdl_cshuffle.hpp
View file @
c3107fd5
...
@@ -851,7 +851,8 @@ struct GridwiseGemmMultipleDWelfordFirstHalf_xdl_cshuffle
...
@@ -851,7 +851,8 @@ struct GridwiseGemmMultipleDWelfordFirstHalf_xdl_cshuffle
BlockwiseWelford
<
AccDataType
,
BlockwiseWelford
<
AccDataType
,
BlockSize
,
BlockSize
,
CDRThreadTransferClusterLengths_MPerBlock_NPerBlock
,
CDRThreadTransferClusterLengths_MPerBlock_NPerBlock
,
Sequence
<
0
,
1
>>
;
Sequence
<
0
,
1
>
,
false
>
;
constexpr
int
num_shuffleM
=
constexpr
int
num_shuffleM
=
MPerBlock
/
(
CShuffleMXdlPerWavePerShuffle
*
MWave
*
MPerXdl
);
MPerBlock
/
(
CShuffleMXdlPerWavePerShuffle
*
MWave
*
MPerXdl
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment