Commit 37346951 authored by Heiko Carstens's avatar Heiko Carstens

s390/fpu: add vector instruction inline assemblies for crc32

Provide various vector instruction inline assemblies for crc32
calculations.

This is just preparation to keep the conversion of the existing crc32
implementations from assembly to C small.
Signed-off-by: default avatarHeiko Carstens <hca@linux.ibm.com>
parent ea8b75d2
...@@ -167,6 +167,22 @@ static __always_inline void fpu_vesravb(u8 v1, u8 v2, u8 v3) ...@@ -167,6 +167,22 @@ static __always_inline void fpu_vesravb(u8 v1, u8 v2, u8 v3)
: "memory"); : "memory");
} }
static __always_inline void fpu_vgfmag(u8 v1, u8 v2, u8 v3, u8 v4)
{
asm volatile("VGFMAG %[v1],%[v2],%[v3],%[v4]"
:
: [v1] "I" (v1), [v2] "I" (v2), [v3] "I" (v3), [v4] "I" (v4)
: "memory");
}
static __always_inline void fpu_vgfmg(u8 v1, u8 v2, u8 v3)
{
asm volatile("VGFMG %[v1],%[v2],%[v3]"
:
: [v1] "I" (v1), [v2] "I" (v2), [v3] "I" (v3)
: "memory");
}
#ifdef CONFIG_CC_IS_CLANG #ifdef CONFIG_CC_IS_CLANG
static __always_inline void fpu_vl(u8 v1, const void *vxr) static __always_inline void fpu_vl(u8 v1, const void *vxr)
...@@ -195,6 +211,22 @@ static __always_inline void fpu_vl(u8 v1, const void *vxr) ...@@ -195,6 +211,22 @@ static __always_inline void fpu_vl(u8 v1, const void *vxr)
#endif /* CONFIG_CC_IS_CLANG */ #endif /* CONFIG_CC_IS_CLANG */
static __always_inline void fpu_vleib(u8 v, s16 val, u8 index)
{
asm volatile("VLEIB %[v],%[val],%[index]"
:
: [v] "I" (v), [val] "K" (val), [index] "I" (index)
: "memory");
}
static __always_inline void fpu_vleig(u8 v, s16 val, u8 index)
{
asm volatile("VLEIG %[v],%[val],%[index]"
:
: [v] "I" (v), [val] "K" (val), [index] "I" (index)
: "memory");
}
static __always_inline u64 fpu_vlgvf(u8 v, u16 index) static __always_inline u64 fpu_vlgvf(u8 v, u16 index)
{ {
u64 val; u64 val;
...@@ -306,6 +338,14 @@ static __always_inline void fpu_vn(u8 v1, u8 v2, u8 v3) ...@@ -306,6 +338,14 @@ static __always_inline void fpu_vn(u8 v1, u8 v2, u8 v3)
: "memory"); : "memory");
} }
static __always_inline void fpu_vperm(u8 v1, u8 v2, u8 v3, u8 v4)
{
asm volatile("VPERM %[v1],%[v2],%[v3],%[v4]"
:
: [v1] "I" (v1), [v2] "I" (v2), [v3] "I" (v3), [v4] "I" (v4)
: "memory");
}
static __always_inline void fpu_vrepib(u8 v1, s16 i2) static __always_inline void fpu_vrepib(u8 v1, s16 i2)
{ {
asm volatile("VREPIB %[v1],%[i2]" asm volatile("VREPIB %[v1],%[i2]"
...@@ -314,6 +354,14 @@ static __always_inline void fpu_vrepib(u8 v1, s16 i2) ...@@ -314,6 +354,14 @@ static __always_inline void fpu_vrepib(u8 v1, s16 i2)
: "memory"); : "memory");
} }
static __always_inline void fpu_vsrlb(u8 v1, u8 v2, u8 v3)
{
asm volatile("VSRLB %[v1],%[v2],%[v3]"
:
: [v1] "I" (v1), [v2] "I" (v2), [v3] "I" (v3)
: "memory");
}
#ifdef CONFIG_CC_IS_CLANG #ifdef CONFIG_CC_IS_CLANG
static __always_inline void fpu_vst(u8 v1, const void *vxr) static __always_inline void fpu_vst(u8 v1, const void *vxr)
...@@ -410,6 +458,14 @@ static __always_inline void fpu_vstl(u8 v1, u32 index, const void *vxr) ...@@ -410,6 +458,14 @@ static __always_inline void fpu_vstl(u8 v1, u32 index, const void *vxr)
#endif /* CONFIG_CC_IS_CLANG */ #endif /* CONFIG_CC_IS_CLANG */
static __always_inline void fpu_vupllf(u8 v1, u8 v2)
{
asm volatile("VUPLLF %[v1],%[v2]"
:
: [v1] "I" (v1), [v2] "I" (v2)
: "memory");
}
static __always_inline void fpu_vx(u8 v1, u8 v2, u8 v3) static __always_inline void fpu_vx(u8 v1, u8 v2, u8 v3)
{ {
asm volatile("VX %[v1],%[v2],%[v3]" asm volatile("VX %[v1],%[v2],%[v3]"
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment