/* * Written by Ulrich Drepper . * Based on e_remainder by J.T. Conklin . * Public domain. */ #include #define PARMS 4 /* no space for saved regs */ #define DVDND PARMS #define DVSOR DVDND+8 #define QUOP DVSOR+8 .text ENTRY (__remquo) fldl DVSOR(%esp) fldl DVDND(%esp) 1: fprem1 fstsw %ax sahf jp 1b fstp %st(1) /* Compute the congruent of the quotient. */ movl %eax, %ecx shrl $8, %eax shrl $12, %ecx andl $4, %ecx andl $3, %eax orl %eax, %ecx leal (%ecx,%ecx,2),%ecx movl $0xef2a60, %eax shrl %cl, %eax andl $7, %eax movl QUOP(%esp), %ecx movl DVDND+4(%esp), %edx xorl DVSOR+4(%esp), %edx testl $0x80000000, %edx jz 1f negl %eax 1: movl %eax, (%ecx) ret END (__remquo) weak_alias (__remquo, remquo)