Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
2401d14e
Commit
2401d14e
authored
Oct 25, 2017
by
Jun Su
Committed by
Vladislav Vaintroub
Nov 16, 2017
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Support CRC32 SSE2 implementation under Windows
parent
88cc6db0
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
41 additions
and
4 deletions
+41
-4
storage/innobase/ut/ut0crc32.cc
storage/innobase/ut/ut0crc32.cc
+41
-4
No files found.
storage/innobase/ut/ut0crc32.cc
View file @
2401d14e
...
@@ -86,6 +86,10 @@ mysys/my_perf.c, contributed by Facebook under the following license.
...
@@ -86,6 +86,10 @@ mysys/my_perf.c, contributed by Facebook under the following license.
#include "univ.i"
#include "univ.i"
#include "ut0crc32.h"
#include "ut0crc32.h"
#ifdef _MSC_VER
#include <intrin.h>
#endif
/** Pointer to CRC32 calculation function. */
/** Pointer to CRC32 calculation function. */
ut_crc32_func_t
ut_crc32
;
ut_crc32_func_t
ut_crc32
;
...
@@ -135,7 +139,7 @@ ut_crc32_power8(
...
@@ -135,7 +139,7 @@ ut_crc32_power8(
}
}
#endif
#endif
#if
defined(__GNUC__) && defined(__x86_64__
)
#if
(defined(__GNUC__) && defined(__x86_64__)) || defined(_MSC_VER
)
/********************************************************************//**
/********************************************************************//**
Fetches CPU info */
Fetches CPU info */
static
static
...
@@ -150,10 +154,29 @@ ut_cpuid(
...
@@ -150,10 +154,29 @@ ut_cpuid(
uint32_t
*
features_edx
)
/*!< out: CPU features edx */
uint32_t
*
features_edx
)
/*!< out: CPU features edx */
{
{
uint32_t
sig
;
uint32_t
sig
;
#ifdef _MSC_VER
int
data
[
4
];
__cpuid
(
data
,
0
);
/* ebx */
vend
[
0
]
=
data
[
1
];
/* edx */
vend
[
1
]
=
data
[
3
];
/* ecx */
vend
[
2
]
=
data
[
2
];
__cpuid
(
data
,
1
);
/* eax */
sig
=
data
[
0
];
/* ecx */
*
features_ecx
=
data
[
2
];
/* edx */
*
features_edx
=
data
[
3
];
#else
asm
(
"cpuid"
:
"=b"
(
vend
[
0
]),
"=c"
(
vend
[
2
]),
"=d"
(
vend
[
1
])
:
"a"
(
0
));
asm
(
"cpuid"
:
"=b"
(
vend
[
0
]),
"=c"
(
vend
[
2
]),
"=d"
(
vend
[
1
])
:
"a"
(
0
));
asm
(
"cpuid"
:
"=a"
(
sig
),
"=c"
(
*
features_ecx
),
"=d"
(
*
features_edx
)
asm
(
"cpuid"
:
"=a"
(
sig
),
"=c"
(
*
features_ecx
),
"=d"
(
*
features_edx
)
:
"a"
(
1
)
:
"a"
(
1
)
:
"ebx"
);
:
"ebx"
);
#endif
*
model
=
((
sig
>>
4
)
&
0xF
);
*
model
=
((
sig
>>
4
)
&
0xF
);
*
family
=
((
sig
>>
8
)
&
0xF
);
*
family
=
((
sig
>>
8
)
&
0xF
);
...
@@ -180,11 +203,15 @@ ut_crc32_8_hw(
...
@@ -180,11 +203,15 @@ ut_crc32_8_hw(
const
byte
**
data
,
const
byte
**
data
,
ulint
*
len
)
ulint
*
len
)
{
{
#ifdef _MSC_VER
*
crc
=
_mm_crc32_u8
(
*
crc
,
(
*
data
)[
0
]);
#else
asm
(
"crc32b %1, %0"
asm
(
"crc32b %1, %0"
/* output operands */
/* output operands */
:
"+r"
(
*
crc
)
:
"+r"
(
*
crc
)
/* input operands */
/* input operands */
:
"rm"
((
*
data
)[
0
]));
:
"rm"
((
*
data
)[
0
]));
#endif
(
*
data
)
++
;
(
*
data
)
++
;
(
*
len
)
--
;
(
*
len
)
--
;
...
@@ -201,12 +228,22 @@ ut_crc32_64_low_hw(
...
@@ -201,12 +228,22 @@ ut_crc32_64_low_hw(
uint64_t
data
)
uint64_t
data
)
{
{
uint64_t
crc_64bit
=
crc
;
uint64_t
crc_64bit
=
crc
;
#ifdef _MSC_VER
#ifdef _M_X64
crc_64bit
=
_mm_crc32_u64
(
crc_64bit
,
data
);
#elif defined(_M_IX86)
crc
=
_mm_crc32_u32
(
crc
,
static_cast
<
uint32_t
>
(
data
));
crc_64bit
=
_mm_crc32_u32
(
crc
,
static_cast
<
uint32_t
>
(
data
>>
32
));
#else
#error Not Supported processors type.
#endif
#else
asm
(
"crc32q %1, %0"
asm
(
"crc32q %1, %0"
/* output operands */
/* output operands */
:
"+r"
(
crc_64bit
)
:
"+r"
(
crc_64bit
)
/* input operands */
/* input operands */
:
"rm"
(
data
));
:
"rm"
(
data
));
#endif
return
(
static_cast
<
uint32_t
>
(
crc_64bit
));
return
(
static_cast
<
uint32_t
>
(
crc_64bit
));
}
}
...
@@ -429,7 +466,7 @@ ut_crc32_byte_by_byte_hw(
...
@@ -429,7 +466,7 @@ ut_crc32_byte_by_byte_hw(
return
(
~
crc
);
return
(
~
crc
);
}
}
#endif
/* defined(__GNUC__) && defined(__x86_64__) */
#endif
/* defined(__GNUC__) && defined(__x86_64__)
|| (_WIN64)
*/
/* CRC32 software implementation. */
/* CRC32 software implementation. */
...
@@ -704,7 +741,7 @@ ut_crc32_init()
...
@@ -704,7 +741,7 @@ ut_crc32_init()
ut_crc32_byte_by_byte
=
ut_crc32_byte_by_byte_sw
;
ut_crc32_byte_by_byte
=
ut_crc32_byte_by_byte_sw
;
ut_crc32_implementation
=
"Using generic crc32 instructions"
;
ut_crc32_implementation
=
"Using generic crc32 instructions"
;
#if
defined(__GNUC__) && defined(__x86_64__
)
#if
(defined(__GNUC__) && defined(__x86_64__)) || defined(_MSC_VER
)
uint32_t
vend
[
3
];
uint32_t
vend
[
3
];
uint32_t
model
;
uint32_t
model
;
uint32_t
family
;
uint32_t
family
;
...
...
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