factor/basis/cpu/architecture/architecture-docs.factor

337 lines
12 KiB
Factor

USING: assocs alien classes compiler.cfg.instructions compiler.cfg.registers
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-%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-%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-%context
USING: cpu.architecture make ;
[ EAX %context ] B{ } make disassemble
00000000010f5ed0: 418b4500 mov eax, [r13]
;
STRING: ex-%copy
USING: cpu.architecture make ;
RAX RBX int-rep [ %copy ] B{ } make disassemble
000000000108a970: 4889d8 mov rax, rbx
;
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-%write-barrier
USING: cpu.architecture make tools.disassembler ;
init-relocation [ RAX RBX 3 -14 RCX RDX %write-barrier ] B{ } make disassemble
000000000143f960: 488d4cd80e lea rcx, [rax+rbx*8+0xe]
000000000143f965: 48c1e908 shr rcx, 0x8
000000000143f969: 48ba0000000000000000 mov rdx, 0x0
000000000143f973: 48c60411c0 mov byte [rcx+rdx], 0xc0
000000000143f978: 48c1e90a shr rcx, 0xa
000000000143f97c: 48ba0000000000000000 mov rdx, 0x0
000000000143f986: 48c60411c0 mov byte [rcx+rdx], 0xc0
;
>>
HELP: double-2-rep
{ $var-description "Representation for a pair of doubles." } ;
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: %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: %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: %call
{ $values { "word" word } }
{ $description "Emits code for calling a Factor word." } ;
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: %horizontal-add-vector
{ $values
{ "dst" "destination register symbol" }
{ "src1" "first source register" }
{ "src2" "second source register" }
{ "rep" "representation" }
}
{ $description "Emits machine code for performing a horizontal add, meaning that adjacent elements in the same operand are added together. So if the two vectors are (a0, a1, a2, a3) and (b0, b1, b2, b3) then the result is (a0 + a1, a2 + a3, b0 + b1, b2 + b3)." }
{ $examples
{ $unchecked-example
"USING: cpu.architecture make tools.disassembler ;"
"[ XMM0 XMM1 XMM2 float-4-rep %horizontal-add-vector ] B{ } make disassemble"
"0000000002660870: 0f28c1 movaps xmm0, xmm1"
"0000000002660873: f20f7cc2 haddps xmm0, xmm2"
}
} ;
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 } " because the former is shorter." }
{ $see-also ##load-tagged } ;
HELP: %load-memory-imm
{ $values
{ "dst" "destination register" }
{ "base" "base gpr for memory address" }
{ "offset" "memory offset" }
{ "rep" "representation" }
{ "c-type" "no idea" }
}
{ $description "Emits code for loading a value from memory into a SIMD register." }
{ $examples
{ $unchecked-example
"USING: cpu.architecture make tools.disassembler ;"
"[ XMM0 RCX 7 float-4-rep f %load-memory-imm ] B{ } make disassemble"
"0000000002633800: 480f284107 movaps xmm0, [rcx+0x7]"
}
} ;
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: %replace-imm
{ $values
{ "src" integer }
{ "loc" loc }
}
{ $description "Emits machine code for putting an integer on the stack." }
{ $examples
{ $unchecked-example
"USING: cpu.architecture make ;"
"[ 777 D 0 %replace-imm ] B{ } make disassemble"
"0000000000aad8c0: 49c70690300000 mov qword [r14], 0x3090"
}
} ;
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: %store-memory-imm
{ $values
{ "value" "source register" }
{ "base" "base register for memory" }
{ "offset" "memory offset" }
{ "rep" "representation" }
{ "c-type" "a c type or " { $link f } }
}
{ $description "Emits machine code for " { $link ##store-memory-imm } " instructions." }
{ $examples
{ $unchecked-example
"USING: cpu.architecture prettyprint ;"
"[ XMM0 RBX 5 double-rep f %store-memory-imm ] B{ } make disassemble"
"0000000002800ae0: f2480f114305 movsd [rbx+0x5], xmm0"
}
} ;
HELP: %vector>scalar
{ $values
{ "dst" "destination register" }
{ "src" "source register" }
{ "rep" representation }
}
{ $description "Converts the contents of a SIMD register to a scalar. On x86 this instruction is a noop." } ;
HELP: %write-barrier
{ $values
{ "src" "a register symbol" }
{ "slot" "a register symbol" }
{ "scale" integer }
{ "tag" integer }
{ "temp1" "a register symbol" }
{ "temp2" "a register symbol" }
}
{ $description "Generates code for the " { $link ##write-barrier } " instruction." }
{ $examples { $unchecked-example $[ ex-%write-barrier ] } } ;
HELP: test-instruction?
{ $values { "?" 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 } { "?" 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. The value is given 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
"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 }
"Moving values around:"
{ $subsections %replace %replace-imm }
"Register categories:"
{ $subsections machine-registers param-regs return-regs }
"Representation metadata:"
{ $subsections
narrow-vector-rep
rep-component-type
rep-length
rep-size
scalar-rep-of
signed-rep
widen-vector-rep
}
"Slot access:"
{ $subsections
%set-slot
%set-slot-imm
%slot
%slot-imm
%write-barrier
}
"Spilling:"
{ $subsections gc-root-offset } ;
ABOUT: "cpu.architecture"