Blame sysdeps/unix/sysv/linux/m68k/m68k-helpers.S

Packit 6c4009
/* Copyright (C) 2010-2018 Free Software Foundation, Inc.
Packit 6c4009
   This file is part of the GNU C Library.
Packit 6c4009
   Contributed by Maxim Kuvyrkov <maxim@codesourcery.com>, 2010.
Packit 6c4009
Packit 6c4009
   The GNU C Library is free software; you can redistribute it and/or
Packit 6c4009
   modify it under the terms of the GNU Lesser General Public
Packit 6c4009
   License as published by the Free Software Foundation; either
Packit 6c4009
   version 2.1 of the License, or (at your option) any later version.
Packit 6c4009
Packit 6c4009
   In addition to the permissions in the GNU Lesser General Public
Packit 6c4009
   License, the Free Software Foundation gives you unlimited
Packit 6c4009
   permission to link the compiled version of this file with other
Packit 6c4009
   programs, and to distribute those programs without any restriction
Packit 6c4009
   coming from the use of this file. (The GNU Lesser General Public
Packit 6c4009
   License restrictions do apply in other respects; for example, they
Packit 6c4009
   cover modification of the file, and distribution when not linked
Packit 6c4009
   into another program.)
Packit 6c4009
Packit 6c4009
   Note that people who make modified versions of this file are not
Packit 6c4009
   obligated to grant this special exception for their modified
Packit 6c4009
   versions; it is their choice whether to do so. The GNU Lesser
Packit 6c4009
   General Public License gives permission to release a modified
Packit 6c4009
   version without this exception; this exception also makes it
Packit 6c4009
   possible to release a modified version which carries forward this
Packit 6c4009
   exception.
Packit 6c4009
Packit 6c4009
   The GNU C Library is distributed in the hope that it will be useful,
Packit 6c4009
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 6c4009
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit 6c4009
   Lesser General Public License for more details.
Packit 6c4009
Packit 6c4009
   You should have received a copy of the GNU Lesser General Public
Packit 6c4009
   License along with the GNU C Library.  If not, see
Packit 6c4009
   <http://www.gnu.org/licenses/>.  */
Packit 6c4009
Packit 6c4009
#include <sysdep.h>
Packit 6c4009
#include <m68k-vdso.h>
Packit 6c4009
Packit 6c4009
	.text
Packit 6c4009
Packit 6c4009
	.hidden __vdso_read_tp_stub
Packit 6c4009
ENTRY (__vdso_read_tp_stub)
Packit 6c4009
	move.l	#__NR_get_thread_area, %d0
Packit 6c4009
	trap	#0
Packit 6c4009
	move.l	%d0, %a0
Packit 6c4009
	rts
Packit 6c4009
END (__vdso_read_tp_stub)
Packit 6c4009
Packit 6c4009
# ifdef SHARED
Packit 6c4009
/* GCC will emit calls to this routine.  Linux has an
Packit 6c4009
   equivalent helper function (which clobbers fewer registers than
Packit 6c4009
   a normal function call) in a vdso; tail call to the
Packit 6c4009
   helper.  */
Packit 6c4009
# if IS_IN (rtld)
Packit 6c4009
/* rtld gets a hidden copy of __m68k_read_tp.  */
Packit 6c4009
	.hidden __m68k_read_tp
Packit 6c4009
# endif
Packit 6c4009
ENTRY (__m68k_read_tp)
Packit 6c4009
	LOAD_GOT (%a0)
Packit 6c4009
	move.l	M68K_VDSO_SYMBOL (__vdso_read_tp)@GOT(%a0), %a0
Packit 6c4009
	move.l	(%a0), %a0
Packit 6c4009
	jmp	(%a0)
Packit 6c4009
END (__m68k_read_tp)
Packit 6c4009
Packit 6c4009
/* The following two stubs are for macros in atomic.h, they can't
Packit 6c4009
   clobber anything.  */
Packit 6c4009
Packit 6c4009
	.hidden __vdso_atomic_cmpxchg_32_stub
Packit 6c4009
ENTRY (__vdso_atomic_cmpxchg_32_stub)
Packit 6c4009
	move.l	%d2, -(%sp)
Packit 6c4009
	cfi_adjust_cfa_offset (4)
Packit 6c4009
	cfi_rel_offset (%d2, 0)
Packit 6c4009
	move.l	%d0, %d2
Packit 6c4009
	move.l	#SYS_ify (atomic_cmpxchg_32), %d0
Packit 6c4009
	trap	#0
Packit 6c4009
	move.l	(%sp)+, %d2
Packit 6c4009
	cfi_adjust_cfa_offset (-4)
Packit 6c4009
	cfi_restore (%d2)
Packit 6c4009
	rts
Packit 6c4009
END (__vdso_atomic_cmpxchg_32_stub)
Packit 6c4009
Packit 6c4009
	.hidden __vdso_atomic_barrier_stub
Packit 6c4009
ENTRY (__vdso_atomic_barrier_stub)
Packit 6c4009
	move.l	%d0, -(%sp)
Packit 6c4009
	cfi_adjust_cfa_offset (4)
Packit 6c4009
	move.l	#SYS_ify (atomic_barrier), %d0
Packit 6c4009
	trap	#0
Packit 6c4009
	move.l	(%sp)+, %d0
Packit 6c4009
	cfi_adjust_cfa_offset (-4)
Packit 6c4009
	rts
Packit 6c4009
END (__vdso_atomic_barrier_stub)
Packit 6c4009
# else /* !SHARED */
Packit 6c4009
/* If the vDSO is not available, use a syscall to get TP.  */
Packit 6c4009
	strong_alias (__vdso_read_tp_stub, __m68k_read_tp)
Packit 6c4009
# endif /* SHARED */