mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-27 11:05:07 +07:00
c0e50d4112
The original implementation could clobber registers under certain conditions. The Xtensa processor architecture uses windowed registers and the original implementation was using a4 as a temporary register, which under certain conditions could be register a0 of the oldest window frame, and didn't always restore the content correctly. By moving the _spill_registers routine inside the fast system call, it frees up one more register (the return address is not required anymore) for the spill routine. Signed-off-by: Chris Zankel <chris@zankel.net>
130 lines
2.8 KiB
C
130 lines
2.8 KiB
C
/*
|
|
* arch/xtensa/kernel/xtensa_ksyms.c
|
|
*
|
|
* Export Xtensa-specific functions for loadable modules.
|
|
*
|
|
* This file is subject to the terms and conditions of the GNU General Public
|
|
* License. See the file "COPYING" in the main directory of this archive
|
|
* for more details.
|
|
*
|
|
* Copyright (C) 2001 - 2005 Tensilica Inc.
|
|
*
|
|
* Joe Taylor <joe@tensilica.com>
|
|
*/
|
|
|
|
#include <linux/module.h>
|
|
#include <linux/string.h>
|
|
#include <linux/mm.h>
|
|
#include <linux/interrupt.h>
|
|
#include <asm/irq.h>
|
|
#include <linux/in6.h>
|
|
|
|
#include <asm/uaccess.h>
|
|
#include <asm/checksum.h>
|
|
#include <asm/dma.h>
|
|
#include <asm/io.h>
|
|
#include <asm/page.h>
|
|
#include <asm/pgalloc.h>
|
|
#include <asm/ftrace.h>
|
|
#ifdef CONFIG_BLK_DEV_FD
|
|
#include <asm/floppy.h>
|
|
#endif
|
|
#ifdef CONFIG_NET
|
|
#include <net/checksum.h>
|
|
#endif /* CONFIG_NET */
|
|
|
|
|
|
/*
|
|
* String functions
|
|
*/
|
|
EXPORT_SYMBOL(memset);
|
|
EXPORT_SYMBOL(memcpy);
|
|
EXPORT_SYMBOL(memmove);
|
|
EXPORT_SYMBOL(__strncpy_user);
|
|
EXPORT_SYMBOL(clear_page);
|
|
EXPORT_SYMBOL(copy_page);
|
|
|
|
EXPORT_SYMBOL(empty_zero_page);
|
|
|
|
/*
|
|
* gcc internal math functions
|
|
*/
|
|
extern long long __ashrdi3(long long, int);
|
|
extern long long __ashldi3(long long, int);
|
|
extern long long __lshrdi3(long long, int);
|
|
extern int __divsi3(int, int);
|
|
extern int __modsi3(int, int);
|
|
extern long long __muldi3(long long, long long);
|
|
extern int __mulsi3(int, int);
|
|
extern unsigned int __udivsi3(unsigned int, unsigned int);
|
|
extern unsigned int __umodsi3(unsigned int, unsigned int);
|
|
extern unsigned long long __umoddi3(unsigned long long, unsigned long long);
|
|
extern unsigned long long __udivdi3(unsigned long long, unsigned long long);
|
|
extern int __ucmpdi2(int, int);
|
|
|
|
EXPORT_SYMBOL(__ashldi3);
|
|
EXPORT_SYMBOL(__ashrdi3);
|
|
EXPORT_SYMBOL(__lshrdi3);
|
|
EXPORT_SYMBOL(__divsi3);
|
|
EXPORT_SYMBOL(__modsi3);
|
|
EXPORT_SYMBOL(__muldi3);
|
|
EXPORT_SYMBOL(__mulsi3);
|
|
EXPORT_SYMBOL(__udivsi3);
|
|
EXPORT_SYMBOL(__umodsi3);
|
|
EXPORT_SYMBOL(__udivdi3);
|
|
EXPORT_SYMBOL(__umoddi3);
|
|
EXPORT_SYMBOL(__ucmpdi2);
|
|
|
|
void __xtensa_libgcc_window_spill(void)
|
|
{
|
|
BUG();
|
|
}
|
|
EXPORT_SYMBOL(__xtensa_libgcc_window_spill);
|
|
|
|
unsigned long __sync_fetch_and_and_4(unsigned long *p, unsigned long v)
|
|
{
|
|
BUG();
|
|
}
|
|
EXPORT_SYMBOL(__sync_fetch_and_and_4);
|
|
|
|
unsigned long __sync_fetch_and_or_4(unsigned long *p, unsigned long v)
|
|
{
|
|
BUG();
|
|
}
|
|
EXPORT_SYMBOL(__sync_fetch_and_or_4);
|
|
|
|
#ifdef CONFIG_NET
|
|
/*
|
|
* Networking support
|
|
*/
|
|
EXPORT_SYMBOL(csum_partial);
|
|
EXPORT_SYMBOL(csum_partial_copy_generic);
|
|
#endif /* CONFIG_NET */
|
|
|
|
/*
|
|
* Architecture-specific symbols
|
|
*/
|
|
EXPORT_SYMBOL(__xtensa_copy_user);
|
|
|
|
/*
|
|
* Kernel hacking ...
|
|
*/
|
|
|
|
#if defined(CONFIG_VGA_CONSOLE) || defined(CONFIG_DUMMY_CONSOLE)
|
|
// FIXME EXPORT_SYMBOL(screen_info);
|
|
#endif
|
|
|
|
EXPORT_SYMBOL(outsb);
|
|
EXPORT_SYMBOL(outsw);
|
|
EXPORT_SYMBOL(outsl);
|
|
EXPORT_SYMBOL(insb);
|
|
EXPORT_SYMBOL(insw);
|
|
EXPORT_SYMBOL(insl);
|
|
|
|
extern long common_exception_return;
|
|
EXPORT_SYMBOL(common_exception_return);
|
|
|
|
#ifdef CONFIG_FUNCTION_TRACER
|
|
EXPORT_SYMBOL(_mcount);
|
|
#endif
|