Move load_and_transpose to transpose_neon.h
Allows for use outside the idcts without pulling in idct_neon.h Change-Id: I4a94c1af3dac3e1b5bc8296ec9eab0ddcc8cfecf
This commit is contained in:
parent
7ba9d31e3f
commit
2c24f7178d
@ -13,6 +13,7 @@
|
|||||||
#include "./vpx_config.h"
|
#include "./vpx_config.h"
|
||||||
#include "./vpx_dsp_rtcd.h"
|
#include "./vpx_dsp_rtcd.h"
|
||||||
#include "vpx_dsp/arm/idct_neon.h"
|
#include "vpx_dsp/arm/idct_neon.h"
|
||||||
|
#include "vpx_dsp/arm/transpose_neon.h"
|
||||||
#include "vpx_dsp/txfm_common.h"
|
#include "vpx_dsp/txfm_common.h"
|
||||||
|
|
||||||
// Only for the first pass of the _34_ variant. Since it only uses values from
|
// Only for the first pass of the _34_ variant. Since it only uses values from
|
||||||
|
@ -120,30 +120,6 @@ static INLINE int16x8_t multiply_accumulate_shift_and_narrow_s16(
|
|||||||
return vcombine_s16(vrshrn_n_s32(temp_low, 14), vrshrn_n_s32(temp_high, 14));
|
return vcombine_s16(vrshrn_n_s32(temp_low, 14), vrshrn_n_s32(temp_high, 14));
|
||||||
}
|
}
|
||||||
|
|
||||||
static INLINE void load_and_transpose_s16_8x8(const int16_t *a, int a_stride,
|
|
||||||
int16x8_t *a0, int16x8_t *a1,
|
|
||||||
int16x8_t *a2, int16x8_t *a3,
|
|
||||||
int16x8_t *a4, int16x8_t *a5,
|
|
||||||
int16x8_t *a6, int16x8_t *a7) {
|
|
||||||
*a0 = vld1q_s16(a);
|
|
||||||
a += a_stride;
|
|
||||||
*a1 = vld1q_s16(a);
|
|
||||||
a += a_stride;
|
|
||||||
*a2 = vld1q_s16(a);
|
|
||||||
a += a_stride;
|
|
||||||
*a3 = vld1q_s16(a);
|
|
||||||
a += a_stride;
|
|
||||||
*a4 = vld1q_s16(a);
|
|
||||||
a += a_stride;
|
|
||||||
*a5 = vld1q_s16(a);
|
|
||||||
a += a_stride;
|
|
||||||
*a6 = vld1q_s16(a);
|
|
||||||
a += a_stride;
|
|
||||||
*a7 = vld1q_s16(a);
|
|
||||||
|
|
||||||
transpose_s16_8x8(a0, a1, a2, a3, a4, a5, a6, a7);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Shift the output down by 6 and add it to the destination buffer.
|
// Shift the output down by 6 and add it to the destination buffer.
|
||||||
static INLINE void add_and_store_u8_s16(const int16x8_t a0, const int16x8_t a1,
|
static INLINE void add_and_store_u8_s16(const int16x8_t a0, const int16x8_t a1,
|
||||||
const int16x8_t a2, const int16x8_t a3,
|
const int16x8_t a2, const int16x8_t a3,
|
||||||
|
@ -936,4 +936,27 @@ static INLINE void transpose_u8_16x16(
|
|||||||
*o15 = e7.val[1];
|
*o15 = e7.val[1];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static INLINE void load_and_transpose_s16_8x8(const int16_t *a, int a_stride,
|
||||||
|
int16x8_t *a0, int16x8_t *a1,
|
||||||
|
int16x8_t *a2, int16x8_t *a3,
|
||||||
|
int16x8_t *a4, int16x8_t *a5,
|
||||||
|
int16x8_t *a6, int16x8_t *a7) {
|
||||||
|
*a0 = vld1q_s16(a);
|
||||||
|
a += a_stride;
|
||||||
|
*a1 = vld1q_s16(a);
|
||||||
|
a += a_stride;
|
||||||
|
*a2 = vld1q_s16(a);
|
||||||
|
a += a_stride;
|
||||||
|
*a3 = vld1q_s16(a);
|
||||||
|
a += a_stride;
|
||||||
|
*a4 = vld1q_s16(a);
|
||||||
|
a += a_stride;
|
||||||
|
*a5 = vld1q_s16(a);
|
||||||
|
a += a_stride;
|
||||||
|
*a6 = vld1q_s16(a);
|
||||||
|
a += a_stride;
|
||||||
|
*a7 = vld1q_s16(a);
|
||||||
|
|
||||||
|
transpose_s16_8x8(a0, a1, a2, a3, a4, a5, a6, a7);
|
||||||
|
}
|
||||||
#endif // VPX_DSP_ARM_TRANSPOSE_NEON_H_
|
#endif // VPX_DSP_ARM_TRANSPOSE_NEON_H_
|
||||||
|
Loading…
Reference in New Issue
Block a user