Support crc32 as a i386 target optimization node
* config/i386/i386.c (ix86_valid_target_attribute_inner_p): Handle crc32. * gcc.target/i386/crc32-5.c: New test. From-SVN: r240393
This commit is contained in:
parent
e70f01b561
commit
fab18cc4f7
|
@ -1,3 +1,8 @@
|
|||
2016-09-23 Martin Liska <mliska@suse.cz>
|
||||
|
||||
* config/i386/i386.c (ix86_valid_target_attribute_inner_p):
|
||||
Handle crc32.
|
||||
|
||||
2016-09-23 Martin Liska <mliska@suse.cz>
|
||||
|
||||
PR target/71652
|
||||
|
|
|
@ -6526,6 +6526,7 @@ ix86_valid_target_attribute_inner_p (tree args, char *p_strings[],
|
|||
IX86_ATTR_ISA ("mmx", OPT_mmmx),
|
||||
IX86_ATTR_ISA ("pclmul", OPT_mpclmul),
|
||||
IX86_ATTR_ISA ("popcnt", OPT_mpopcnt),
|
||||
IX86_ATTR_ISA ("crc32", OPT_mcrc32),
|
||||
IX86_ATTR_ISA ("sse", OPT_msse),
|
||||
IX86_ATTR_ISA ("sse2", OPT_msse2),
|
||||
IX86_ATTR_ISA ("sse3", OPT_msse3),
|
||||
|
|
|
@ -1,3 +1,7 @@
|
|||
2016-09-23 Martin Liska <mliska@suse.cz>
|
||||
|
||||
* gcc.target/i386/crc32-5.c: New test.
|
||||
|
||||
2016-09-23 Martin Liska <mliska@suse.cz>
|
||||
|
||||
* gcc.target/i386/pr71652.c: New test.
|
||||
|
|
|
@ -0,0 +1,25 @@
|
|||
/* { dg-do compile } */
|
||||
/* { dg-options "-O2" } */
|
||||
/* { dg-final { scan-assembler "crc32b\[^\\n\]*eax" } } */
|
||||
/* { dg-final { scan-assembler "crc32w\[^\\n\]*eax" } } */
|
||||
/* { dg-final { scan-assembler "crc32l\[^\\n\]*eax" } } */
|
||||
|
||||
#pragma GCC target ("crc32")
|
||||
|
||||
unsigned int
|
||||
crc32b (unsigned int x, unsigned char y)
|
||||
{
|
||||
return __builtin_ia32_crc32qi (x, y);
|
||||
}
|
||||
|
||||
unsigned int
|
||||
crc32w (unsigned int x, unsigned short y)
|
||||
{
|
||||
return __builtin_ia32_crc32hi (x, y);
|
||||
}
|
||||
|
||||
unsigned int
|
||||
crc32d (unsigned int x, unsigned int y)
|
||||
{
|
||||
return __builtin_ia32_crc32si (x, y);
|
||||
}
|
Loading…
Reference in New Issue