223 lines
		
	
	
		
			8.5 KiB
		
	
	
	
		
			Factor
		
	
	
			
		
		
	
	
			223 lines
		
	
	
		
			8.5 KiB
		
	
	
	
		
			Factor
		
	
	
| USING: assocs alien classes compiler.cfg.instructions compiler.cfg.stack-frame
 | |
| cpu.x86.assembler cpu.x86.assembler.operands help.markup help.syntax kernel
 | |
| layouts literals math multiline system words ;
 | |
| QUALIFIED: vm
 | |
| IN: cpu.architecture
 | |
| 
 | |
| <<
 | |
| STRING: ex-%box-alien
 | |
| USING: compiler.codegen compiler.codegen.relocation cpu.architecture make ;
 | |
| init-fixup init-relocation [ RAX RBX RCX %box-alien ] B{ } make disassemble
 | |
| 000000e9fcc720a0: 48b80100000000000000  mov rax, 0x1
 | |
| 000000e9fcc720aa: 4885db                test rbx, rbx
 | |
| 000000e9fcc720ad: 0f8400000000          jz dword 0xe9fcc720b3
 | |
| 000000e9fcc720b3: 498d4d10              lea rcx, [r13+0x10]
 | |
| 000000e9fcc720b7: 488b01                mov rax, [rcx]
 | |
| 000000e9fcc720ba: 48c70018000000        mov qword [rax], 0x18
 | |
| 000000e9fcc720c1: 4883c806              or rax, 0x6
 | |
| 000000e9fcc720c5: 48830130              add qword [rcx], 0x30
 | |
| 000000e9fcc720c9: 48c7400201000000      mov qword [rax+0x2], 0x1
 | |
| 000000e9fcc720d1: 48c7400a01000000      mov qword [rax+0xa], 0x1
 | |
| 000000e9fcc720d9: 48895812              mov [rax+0x12], rbx
 | |
| 000000e9fcc720dd: 4889581a              mov [rax+0x1a], rbx
 | |
| ;
 | |
| 
 | |
| STRING: ex-%allot
 | |
| USING: cpu.architecture make ;
 | |
| [ RAX 40 tuple RCX %allot ] B{ } make disassemble
 | |
| 0000000002270cc0: 498d4d10        lea rcx, [r13+0x10]
 | |
| 0000000002270cc4: 488b01          mov rax, [rcx]
 | |
| 0000000002270cc7: 48c7001c000000  mov qword [rax], 0x1c
 | |
| 0000000002270cce: 4883c807        or rax, 0x7
 | |
| 0000000002270cd2: 48830130        add qword [rcx], 0x30
 | |
| ;
 | |
| 
 | |
| STRING: ex-%context
 | |
| USING: cpu.architecture make ;
 | |
| [ EAX %context ] B{ } make disassemble
 | |
| 00000000010f5ed0: 418b4500  mov eax, [r13]
 | |
| ;
 | |
| 
 | |
| STRING: ex-%safepoint
 | |
| USING: cpu.architecture make ;
 | |
| init-relocation [ %safepoint ] B{ } make disassemble
 | |
| 00000000010b05a0: 890500000000  mov [rip], eax
 | |
| ;
 | |
| 
 | |
| STRING: ex-%save-context
 | |
| USING: cpu.architecture make ;
 | |
| [ RAX RBX %save-context ] B{ } make disassemble
 | |
| 0000000000e63ab0: 498b4500    mov rax, [r13]
 | |
| 0000000000e63ab4: 488d5c24f8  lea rbx, [rsp-0x8]
 | |
| 0000000000e63ab9: 488918      mov [rax], rbx
 | |
| 0000000000e63abc: 4c897010    mov [rax+0x10], r14
 | |
| 0000000000e63ac0: 4c897818    mov [rax+0x18], r15
 | |
| ;
 | |
| 
 | |
| STRING: ex-%copy
 | |
| USING: cpu.architecture make ;
 | |
| RAX RBX int-rep [ %copy ] B{ } make disassemble
 | |
| 000000000108a970: 4889d8  mov rax, rbx
 | |
| ;
 | |
| >>
 | |
| 
 | |
| HELP: signed-rep
 | |
| { $values { "rep" representation } { "rep'" representation } }
 | |
| { $description "Maps any representation to its signed counterpart, if it has one." } ;
 | |
| 
 | |
| HELP: rep-size
 | |
| { $values { "rep" representation } { "n" integer } }
 | |
| { $description "Size in bytes of a representation." } ;
 | |
| 
 | |
| HELP: immediate-arithmetic?
 | |
| { $values { "n" number } { "?" boolean } }
 | |
| { $description
 | |
|   "Can this value be an immediate operand for " { $link %add-imm } ", "
 | |
|   { $link %sub-imm } ", or " { $link %mul-imm } "?"
 | |
| } ;
 | |
| 
 | |
| HELP: machine-registers
 | |
| { $values { "assoc" assoc } }
 | |
| { $description "Mapping from register class to machine registers. Only registers not reserved by the Factor VM are included." } ;
 | |
| 
 | |
| HELP: vm-stack-space
 | |
| { $values { "n" number } }
 | |
| { $description "Parameter space to reserve in anything making VM calls." } ;
 | |
| 
 | |
| HELP: complex-addressing?
 | |
| { $values { "?" boolean } }
 | |
| { $description "Specifies if " { $link %slot } ", " { $link %set-slot } " and " { $link %write-barrier } " accept the 'scale' and 'tag' parameters, and if %load-memory and %store-memory work." } ;
 | |
| 
 | |
| HELP: param-regs
 | |
| { $values { "abi" "a calling convention symbol" } { "regs" assoc } }
 | |
| { $description "Retrieves the order in which machine registers are used for parameters for the given calling convention." } ;
 | |
| 
 | |
| HELP: %load-immediate
 | |
| { $values { "reg" "a register symbol" } { "val" "a value" } }
 | |
| { $description "Emits code for loading an immediate value into a register. On " { $link x86 } ", if val is 0, then an " { $link XOR } " instruction is emitted instead of " { $link MOV } "." } ;
 | |
| 
 | |
| HELP: %call
 | |
| { $values { "word" word } }
 | |
| { $description "Emits code for calling a Factor word." } ;
 | |
| 
 | |
| HELP: %box
 | |
| { $values
 | |
|   { "dst" "destination register" }
 | |
|   { "src" "source register" }
 | |
|   { "func" "function?" }
 | |
|   { "rep" "representation class" }
 | |
|   { "gc-map" gc-map }
 | |
| }
 | |
| { $description "Call a function to convert a value into a tagged pointer, possibly allocating a bignum, float, or alien instance, which is then pushed on the data stack." } ;
 | |
| 
 | |
| HELP: %box-alien
 | |
| { $values { "dst" "destination register" } { "src" "source register" } { "temp" "temporary register" } }
 | |
| { $description "Emits machine code for boxing an alien value. If the alien is not a NULL pointer, then five " { $link cells } " will be allocated in the nursery space to wrap the object. See vm/layouts.hpp for details." }
 | |
| { $examples { $unchecked-example $[ ex-%box-alien ] } }
 | |
| { $see-also ##box-alien %allot } ;
 | |
| 
 | |
| HELP: %context
 | |
| { $values { "dst" "a register symbol" } }
 | |
| { $description "Emits machine code for putting a pointer to the context field of the " { $link vm } " in a register." }
 | |
| { $examples { $unchecked-example $[ ex-%context ] } } ;
 | |
| 
 | |
| HELP: %copy
 | |
| { $values { "dst" "destination" } { "src" "source" } { "rep" representation } }
 | |
| { $description "Emits code copying a value from a register, arbitrary memory location or " { $link spill-slot } " to a destination." }
 | |
| { $examples { $unchecked-example $[ ex-%copy ] } } ;
 | |
| 
 | |
| HELP: %safepoint
 | |
| { $description "Emits a safe point to the current code sequence being generated." }
 | |
| { $examples { $unchecked-example $[ ex-%safepoint ] } } ;
 | |
| 
 | |
| HELP: %save-context
 | |
| { $values { "temp1" "a register symbol" } { "temp2" "a register symbol" } }
 | |
| { $description "Emits machine code for saving pointers to the callstack, datastack and retainstack in the current context field struct." }
 | |
| { $examples { $unchecked-example $[ ex-%save-context ] } } ;
 | |
| 
 | |
| 
 | |
| HELP: %allot
 | |
| { $values
 | |
|   { "dst" "destination register symbol" }
 | |
|   { "size" "number of bytes to allocate" }
 | |
|   { "class" "one of the built-in classes listed in " { $link type-numbers } }
 | |
|   { "temp" "temporary register symbol" }
 | |
| }
 | |
| { $description "Emits machine code for allocating memory." }
 | |
| { $examples
 | |
|   "In this example 40 bytes is allocated and a tagged pointer to the memory is put in " { $link RAX } ":"
 | |
|   { $unchecked-example $[ ex-%allot ] }
 | |
| } ;
 | |
| 
 | |
| HELP: %local-allot
 | |
| { $values
 | |
|   { "dst" "destination register symbol" }
 | |
|   { "size" "number of bytes to allocate" }
 | |
|   { "align" "alignment" }
 | |
|   { "offset" "where to allocate the data, relative to the stack register" }
 | |
| }
 | |
| { $description "Emits machine code for stack \"allocating\" a chunk of memory. No memory is really allocated and instead a pointer to it is just put in the destination register." } ;
 | |
| 
 | |
| HELP: test-instruction?
 | |
| { $values { "?" "a boolean" } }
 | |
| { $description "Does the current architecture have a test instruction? Used on x86 to rewrite some " { $link CMP } " instructions to less expensive " { $link TEST } "s." } ;
 | |
| 
 | |
| HELP: fused-unboxing?
 | |
| { $values { "?" boolean } }
 | |
| { $description "Whether this architecture support " { $link %load-float } ", " { $link %load-double } ", and " { $link %load-vector } "." } ;
 | |
| 
 | |
| HELP: return-regs
 | |
| { $values { "regs" assoc } }
 | |
| { $description "What registers that will be used for function return values of which class." } ;
 | |
| 
 | |
| HELP: return-struct-in-registers?
 | |
| { $values { "c-type" class } { "?" "a boolean" } }
 | |
| { $description "Whether the size of the struct is so small that it will be returned in registers or not." } ;
 | |
| 
 | |
| HELP: stack-cleanup
 | |
| { $values
 | |
|   { "stack-size" integer }
 | |
|   { "return" "a c type" }
 | |
|   { "abi" abi }
 | |
|   { "n" integer }
 | |
| }
 | |
| { $description "Calculates how many bytes of stack space the caller of the procedure being constructed need to cleanup. For modern abi's the value is almost always 0." }
 | |
| { $examples
 | |
|   { $unchecked-example
 | |
|     "USING: cpu.architecture prettyprint ;"
 | |
|     "20 void stdcall stack-cleanup ."
 | |
|     "20"
 | |
|   }
 | |
| } ;
 | |
| 
 | |
| HELP: gc-root-offset
 | |
| { $values { "spill-slot" spill-slot } { "n" integer } }
 | |
| { $description "Offset in the " { $link stack-frame } " for the word being constructed where the spill slot is located, in " { $link cell } " units." }
 | |
| { $see-also vm:gc-info } ;
 | |
| 
 | |
| ARTICLE: "cpu.architecture" "CPU architecture description model"
 | |
| "The " { $vocab-link "cpu.architecture" } " vocab contains generic words and hooks that serves as an api for the compiler towards the cpu architecture."
 | |
| $nl
 | |
| "Register categories:"
 | |
| { $subsections machine-registers param-regs return-regs }
 | |
| "Architecture support checks:"
 | |
| { $subsections
 | |
|   complex-addressing?
 | |
|   float-on-stack?
 | |
|   float-right-align-on-stack?
 | |
|   fused-unboxing?
 | |
|   test-instruction?
 | |
| }
 | |
| "Control flow code emitters:"
 | |
| { $subsections %call %jump %jump-label %return }
 | |
| "Representation metadata:"
 | |
| { $subsections
 | |
|   narrow-vector-rep
 | |
|   rep-component-type
 | |
|   rep-length
 | |
|   rep-size
 | |
|   scalar-rep-of
 | |
|   signed-rep
 | |
|   widen-vector-rep
 | |
| } ;
 |