blob: fca7305040d6c59dbc367e049c193b072c6211b7 [file] [log] [blame]
#include <linux/smp.h>
#include <linux/types.h>
#include <asm/simd.h>
#define LZ4_FAST_MARGIN (128)
#if defined(CONFIG_ARM64) && defined(CONFIG_KERNEL_MODE_NEON)
#include <asm/neon.h>
#include <asm/cputype.h>
asmlinkage int _lz4_decompress_asm(uint8_t **dst_ptr, uint8_t *dst_begin,
uint8_t *dst_end, const uint8_t **src_ptr,
const uint8_t *src_end, bool dip);
asmlinkage int _lz4_decompress_asm_noprfm(uint8_t **dst_ptr, uint8_t *dst_begin,
uint8_t *dst_end, const uint8_t **src_ptr,
const uint8_t *src_end, bool dip);
static inline int lz4_decompress_accel_enable(void)
{
return may_use_simd();
}
extern int (*lz4_decompress_asm_fn[])(uint8_t **dst_ptr, uint8_t *dst_begin,
uint8_t *dst_end, const uint8_t **src_ptr,
const uint8_t *src_end, bool dip);
static inline ssize_t lz4_decompress_asm(
uint8_t **dst_ptr, uint8_t *dst_begin, uint8_t *dst_end,
const uint8_t **src_ptr, const uint8_t *src_end, bool dip)
{
int ret;
kernel_neon_begin();
ret = lz4_decompress_asm_fn[smp_processor_id()](dst_ptr, dst_begin,
dst_end, src_ptr,
src_end, dip);
kernel_neon_end();
return (ssize_t)ret;
}
#define __ARCH_HAS_LZ4_ACCELERATOR
#else
static inline int lz4_decompress_accel_enable(void)
{
return 0;
}
static inline ssize_t lz4_decompress_asm(
uint8_t **dst_ptr, uint8_t *dst_begin, uint8_t *dst_end,
const uint8_t **src_ptr, const uint8_t *src_end, bool dip)
{
return 0;
}
#endif