2021-02-05 08:48:47 +00:00
|
|
|
/* SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
* Copyright(c) 2016-2020 Intel Corporation
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _DLB2_INLINE_FNS_H_
|
|
|
|
#define _DLB2_INLINE_FNS_H_
|
|
|
|
|
2022-09-06 04:00:10 +00:00
|
|
|
#include <eventdev_pmd.h>
|
|
|
|
|
2021-02-05 08:48:47 +00:00
|
|
|
/* Inline functions required in more than one source file. */
|
|
|
|
|
|
|
|
static inline struct dlb2_eventdev *
|
|
|
|
dlb2_pmd_priv(const struct rte_eventdev *eventdev)
|
|
|
|
{
|
|
|
|
return eventdev->data->dev_private;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void
|
|
|
|
dlb2_movntdq_single(void *pp_addr, void *qe4)
|
|
|
|
{
|
|
|
|
long long *_qe = (long long *)qe4;
|
|
|
|
__m128i src_data0 = (__m128i){_qe[0], _qe[1]};
|
|
|
|
|
|
|
|
_mm_stream_si128(pp_addr, src_data0);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void
|
|
|
|
dlb2_movdir64b(void *dest, void *src)
|
|
|
|
{
|
|
|
|
asm volatile(".byte 0x66, 0x0f, 0x38, 0xf8, 0x02"
|
|
|
|
:
|
|
|
|
: "a" (dest), "d" (src));
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* _DLB2_INLINE_FNS_H_ */
|