arch/arm: only compare callee-saved registers for fpu
Registers S0-S15 (D0-D7, Q0-Q3) do not need to be preserved. They can be used for passing arguments or returning results in standard procedure-call variants. Registers D16-D31 (Q8-Q15), do not need to be preserved. Signed-off-by: zhangyuan21 <zhangyuan21@xiaomi.com>
This commit is contained in:
parent
6711b37662
commit
ffd2eb5b14
5 changed files with 36 additions and 9 deletions
|
@ -36,6 +36,8 @@
|
||||||
|
|
||||||
#ifdef CONFIG_ARCH_FPU
|
#ifdef CONFIG_ARCH_FPU
|
||||||
|
|
||||||
|
# define FPU_CALLEE_REGS (16)
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Public Functions
|
* Public Functions
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
@ -60,6 +62,10 @@ bool up_fpucmp(const void *saveregs1, const void *saveregs2)
|
||||||
const uint32_t *regs1 = saveregs1;
|
const uint32_t *regs1 = saveregs1;
|
||||||
const uint32_t *regs2 = saveregs2;
|
const uint32_t *regs2 = saveregs2;
|
||||||
|
|
||||||
return memcmp(®s1[REG_S0], ®s2[REG_S0], 4 * FPU_CONTEXT_REGS) == 0;
|
/* Only compare callee-saved registers, caller-saved registers do not
|
||||||
|
* need to be preserved.
|
||||||
|
*/
|
||||||
|
|
||||||
|
return memcmp(®s1[REG_S16], ®s2[REG_S16], 4 * FPU_CALLEE_REGS) == 0;
|
||||||
}
|
}
|
||||||
#endif /* CONFIG_ARCH_FPU */
|
#endif /* CONFIG_ARCH_FPU */
|
||||||
|
|
|
@ -60,10 +60,12 @@ bool up_fpucmp(const void *saveregs1, const void *saveregs2)
|
||||||
const uint32_t *regs1 = saveregs1;
|
const uint32_t *regs1 = saveregs1;
|
||||||
const uint32_t *regs2 = saveregs2;
|
const uint32_t *regs2 = saveregs2;
|
||||||
|
|
||||||
|
/* Only compare callee-saved registers, caller-saved registers do not
|
||||||
|
* need to be preserved.
|
||||||
|
*/
|
||||||
|
|
||||||
/* compare of hardware fp registers should skip REG_FP_RESERVED */
|
/* compare of hardware fp registers should skip REG_FP_RESERVED */
|
||||||
|
|
||||||
return memcmp(®s1[REG_S0], ®s2[REG_S0],
|
return memcmp(®s1[REG_S16], ®s2[REG_S16], 4 * SW_FPU_REGS) == 0;
|
||||||
4 * (HW_FPU_REGS - 1)) == 0 &&
|
|
||||||
memcmp(®s1[REG_S16], ®s2[REG_S16], 4 * SW_FPU_REGS) == 0;
|
|
||||||
}
|
}
|
||||||
#endif /* CONFIG_ARCH_FPU */
|
#endif /* CONFIG_ARCH_FPU */
|
||||||
|
|
|
@ -36,6 +36,8 @@
|
||||||
|
|
||||||
#ifdef CONFIG_ARCH_FPU
|
#ifdef CONFIG_ARCH_FPU
|
||||||
|
|
||||||
|
# define FPU_CALLEE_REGS (16)
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Public Functions
|
* Public Functions
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
@ -60,6 +62,10 @@ bool up_fpucmp(const void *saveregs1, const void *saveregs2)
|
||||||
const uint32_t *regs1 = saveregs1;
|
const uint32_t *regs1 = saveregs1;
|
||||||
const uint32_t *regs2 = saveregs2;
|
const uint32_t *regs2 = saveregs2;
|
||||||
|
|
||||||
return memcmp(®s1[REG_S0], ®s2[REG_S0], 4 * FPU_CONTEXT_REGS) == 0;
|
/* Only compare callee-saved registers, caller-saved registers do not
|
||||||
|
* need to be preserved.
|
||||||
|
*/
|
||||||
|
|
||||||
|
return memcmp(®s1[REG_S16], ®s2[REG_S16], 4 * FPU_CALLEE_REGS) == 0;
|
||||||
}
|
}
|
||||||
#endif /* CONFIG_ARCH_FPU */
|
#endif /* CONFIG_ARCH_FPU */
|
||||||
|
|
|
@ -60,10 +60,12 @@ bool up_fpucmp(const void *saveregs1, const void *saveregs2)
|
||||||
const uint32_t *regs1 = saveregs1;
|
const uint32_t *regs1 = saveregs1;
|
||||||
const uint32_t *regs2 = saveregs2;
|
const uint32_t *regs2 = saveregs2;
|
||||||
|
|
||||||
|
/* Only compare callee-saved registers, caller-saved registers do not
|
||||||
|
* need to be preserved.
|
||||||
|
*/
|
||||||
|
|
||||||
/* compare of hardware fp registers should skip REG_FP_RESERVED */
|
/* compare of hardware fp registers should skip REG_FP_RESERVED */
|
||||||
|
|
||||||
return memcmp(®s1[REG_S0], ®s2[REG_S0],
|
return memcmp(®s1[REG_S16], ®s2[REG_S16], 4 * SW_FPU_REGS) == 0;
|
||||||
4 * (HW_FPU_REGS - 1)) == 0 &&
|
|
||||||
memcmp(®s1[REG_S16], ®s2[REG_S16], 4 * SW_FPU_REGS) == 0;
|
|
||||||
}
|
}
|
||||||
#endif /* CONFIG_ARCH_FPU */
|
#endif /* CONFIG_ARCH_FPU */
|
||||||
|
|
|
@ -41,6 +41,12 @@
|
||||||
#include "arm64_fatal.h"
|
#include "arm64_fatal.h"
|
||||||
#include "arm64_fpu.h"
|
#include "arm64_fpu.h"
|
||||||
|
|
||||||
|
/***************************************************************************
|
||||||
|
* Pre-processor Definitions
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
#define FPU_CALLEE_REGS (8)
|
||||||
|
|
||||||
/***************************************************************************
|
/***************************************************************************
|
||||||
* Private Data
|
* Private Data
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
@ -245,5 +251,10 @@ bool up_fpucmp(const void *saveregs1, const void *saveregs2)
|
||||||
const uint64_t *regs1 = saveregs1 + XCPTCONTEXT_GP_SIZE;
|
const uint64_t *regs1 = saveregs1 + XCPTCONTEXT_GP_SIZE;
|
||||||
const uint64_t *regs2 = saveregs2 + XCPTCONTEXT_GP_SIZE;
|
const uint64_t *regs2 = saveregs2 + XCPTCONTEXT_GP_SIZE;
|
||||||
|
|
||||||
return memcmp(regs1, regs2, 8 * XCPTCONTEXT_FPU_REGS) == 0;
|
/* Only compare callee-saved registers, caller-saved registers do not
|
||||||
|
* need to be preserved.
|
||||||
|
*/
|
||||||
|
|
||||||
|
return memcmp(®s1[FPU_REG_Q4], ®s2[FPU_REG_Q4],
|
||||||
|
8 * FPU_CALLEE_REGS) == 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue