x86: string_32.h: workaround for broken gcc 4.0
gcc 4.0 fails to allocate %eax for the pattern operand in the rep store instructions used by memset; force it to do so by declaring a register variable. Signed-off-by: H. Peter Anvin <hpa@zytor.com>
This commit is contained in:
parent
4b6011bc6e
commit
1a20d3ecf5
|
@ -267,11 +267,18 @@ void *__constant_c_and_count_memset(void *s, unsigned long pattern,
|
||||||
asm volatile("rep ; stosl" \
|
asm volatile("rep ; stosl" \
|
||||||
x \
|
x \
|
||||||
: "=&c" (d0), "=&D" (d1) \
|
: "=&c" (d0), "=&D" (d1) \
|
||||||
: "a" (pattern), "0" (count/4), "1" ((long)s) \
|
: "a" (eax), "0" (count/4), "1" ((long)s) \
|
||||||
: "memory")
|
: "memory")
|
||||||
|
|
||||||
{
|
{
|
||||||
int d0, d1;
|
int d0, d1;
|
||||||
|
#if __GNUC__ == 4 && __GNUC_MINOR__ == 0
|
||||||
|
/* Workaround for broken gcc 4.0 */
|
||||||
|
register unsigned long eax asm("%eax") = pattern;
|
||||||
|
#else
|
||||||
|
unsigned long eax = pattern;
|
||||||
|
#endif
|
||||||
|
|
||||||
switch (count % 4) {
|
switch (count % 4) {
|
||||||
case 0:
|
case 0:
|
||||||
COMMON("");
|
COMMON("");
|
||||||
|
|
Loading…
Reference in New Issue