make_s390x_sysv_elf_gas.S 3.95 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104
/*******************************************************
*                                                     *
*  -------------------------------------------------  *
*  |  0  |  1  |  2  |  3  |  4  |  5  |  6  |  7  |  *
*  -------------------------------------------------  *
*  |     0     |     8     |    16     |     24    |  *
*  -------------------------------------------------  *
*  |    R6     |    R7     |    R8     |    R9     |  *
*  -------------------------------------------------  *
*  -------------------------------------------------  *
*  |  8  |  9  |  10 |  11 |  12 |  13 |  14 |  15 |  *
*  -------------------------------------------------  *
*  |     32    |    40     |     48    |     56    |  *
*  -------------------------------------------------  *
*  |    R10    |    R11    |     R12   |     R13   |  *
*  -------------------------------------------------  *
*  -------------------------------------------------  *
*  |  16 |  17 |  18 |  19 |  20 |  21 |  22 |  23 |  *
*  -------------------------------------------------  *
*  |     64    |    72     |     80    |     88    |  *
*  -------------------------------------------------  *
*  |   R14/LR  |    R15    |     F1    |     F3    |  *
*  -------------------------------------------------  *
*  -------------------------------------------------  *
*  |  24 |  25 |  26 |  27 |  28 | 29  |           |  *
*  -------------------------------------------------  *
*  |     96    |    104    |    112    |    120    |  *
*  -------------------------------------------------  *
*  |    F5     |    F7     |     PC    |           |  *
*  -------------------------------------------------  *
* *****************************************************/

.file  "make_s390x_sysv_elf_gas.S"
.text
.align  4 # According to the sample code in the ELF ABI docs
.global make_fcontext
.type 	 make_fcontext, @function

#define GR_OFFSET	0
#define LR_OFFSET	64
#define SP_OFFSET	72
#define FP_OFFSET	80
#define PC_OFFSET	112
#define L_CTX		120
#define L_STACKFRAME	120

make_fcontext:

		# make_fcontext takes in 3 arguments
		# arg1 --> The address where the context needs to be made
		# arg2 --> The size of the context
		# arg3 --> The address of the context function

		# According to the ELF ABI, the register R2 holds the first arg.
		# R2 also acts as the register which holds return value
		# Register R3 holds the second, R4 the third so on.

		# Shift the address in R2 to a lower 8 byte boundary

		# This is done because according to the ELF ABI Doc, the stack needs
		# to be 8 byte aligned.
		# In order to do so, we need to make sure that the address is divisible
		# by 8. We can check this, by checking if the the last 3 bits of the
		# address is zero or not. If not AND it with `-8`. 

		# Here we AND the lower 16 bits of the memory address present in the 
		# R2 with the bits 1111 1111 1111 1000 
		nill    %r2,0xfff0

		# Reserve space for context-data on context-stack.
		# This is done by shifting the SP/address by 112 bytes.
		aghi	%r2,-L_CTX

		# third arg of make_fcontext() == address of the context-function
		# Store the address as a PC to jump in, whenever we call the 
		# make_fcontext.
		stg 	%r4,PC_OFFSET(%r2)

		# Save the address of finish as return-address for context-function
		# This will be entered after context-function return
		# The address of finish will be saved in Link register, this register
		# specifies where we need to jump after the function executes
		# completely.
		larl 	%r1,finish
		stg  	%r1,LR_OFFSET(%r2)

		# Return pointer to context data
		# R14 acts as the link register
		# R2 holds the address of the context stack. When we return from the
		# make_fcontext, R2 is passed back.
		br 	%r14 

	finish:

		# In finish tasks, you load the exit code and exit the make_fcontext
		# This is called when the context-function is entirely executed

		lghi 	%r2,0
		brasl 	%r14,_exit@PLT

.size   make_fcontext,.-make_fcontext
# Mark that we don't need executable stack.
.section .note.GNU-stack,"",%progbits