Slava Pestov
|
11511167e2
|
cpu.x86.x87: compares were clobbering ST0
|
2010-05-18 19:18:53 -04:00 |
Slava Pestov
|
1834241e5a
|
alien.libraries, stack-checker.alien: check user inputs more carefully to ensure that invalid ABI descriptors don't slip through and break random stuff (reported by prunedtree)
|
2010-05-18 18:46:31 -04:00 |
Slava Pestov
|
ea726f5680
|
Move remaining sequence operations from generalizations to sequences.generalizations where they belong
|
2010-05-18 18:36:47 -04:00 |
Slava Pestov
|
2dde83767c
|
cpu.x86.assembler: fix typo
|
2010-05-18 17:59:34 -04:00 |
Slava Pestov
|
0aa6ae0feb
|
cpu.x86.x87: use FISTPD to convert floats to integers, instead of the SSE3 instruction FISTTPD
|
2010-05-18 17:10:58 -04:00 |
Slava Pestov
|
f5a951801e
|
cpu.x86.assembler: AH CH DH BH register operands now work properly
|
2010-05-18 17:10:32 -04:00 |
Slava Pestov
|
be733cd797
|
compiler.cfg.value-numbering: constant folding for ##shuffle-vector
|
2010-05-18 04:22:21 -04:00 |
Slava Pestov
|
53a51957df
|
compiler.cfg.value-numbering: add constant folding for ##gather-vector instructions, and fix ##scalar>vector constant folding for integers
|
2010-05-18 03:56:07 -04:00 |
Slava Pestov
|
3104ad779a
|
cpu.x86.64: call check-sse to ensure that cpu.x86.sse is loaded
|
2010-05-17 11:43:42 -04:00 |
Slava Pestov
|
6eaf2d7534
|
cpu.x86: add x87 codegen for Model T enthusiasts
|
2010-05-17 11:35:47 -04:00 |
Slava Pestov
|
41d929a201
|
compiler.cfg.ssa.interference: implement linear-time interference test
|
2010-05-17 05:50:13 -04:00 |
Slava Pestov
|
6b7260a4a7
|
compiler.cfg.ssa.interference.live-ranges: compute correct live ranges for ##phi instructions
|
2010-05-17 05:50:13 -04:00 |
Slava Pestov
|
0955f2c7eb
|
compiler.cfg.linear-scan: fix typo
|
2010-05-17 05:50:13 -04:00 |
Joe Groff
|
93abc7d169
|
cpu.x86.assembler: a choice selection of x87 instructions
|
2010-05-17 02:02:40 -07:00 |
Slava Pestov
|
db5b33977b
|
cpu.x86.32: clean up %unary/binary-float-function
|
2010-05-17 04:03:13 -04:00 |
Slava Pestov
|
7ff309d50e
|
cpu.x86: get rid of this extra-stack-space nonsense
|
2010-05-17 02:14:44 -04:00 |
Slava Pestov
|
3f8e13bf66
|
compiler.cfg: refactor stack frame code and fix frame pointer usage in callbacks
|
2010-05-16 21:04:40 -04:00 |
Slava Pestov
|
a7b5957f6d
|
compiler: hack to make XCreateIC() work on x86-64
|
2010-05-16 04:49:53 -04:00 |
Slava Pestov
|
8ebecac4d2
|
Merge branch 'master' of git://factorcode.org/git/factor
|
2010-05-16 04:10:03 -04:00 |
Slava Pestov
|
e6abc0be15
|
Fixes for FFI changes
|
2010-05-16 04:09:47 -04:00 |
Joe Groff
|
67ea40ade3
|
compiler.cfg.intrinsics.simd: use ^^select-vector for simd constant nth when available
|
2010-05-16 00:50:20 -07:00 |
Joe Groff
|
645164188d
|
compiler.cfg.instructions: ##select-vector instruction mapping to SSE4 PEXTR*
|
2010-05-16 00:50:19 -07:00 |
Slava Pestov
|
5b48cd2a63
|
FFI rewrite part 5: return value boxing and callback parameter boxing now uses vregs; simplify return value unboxing
|
2010-05-16 03:43:23 -04:00 |
Joe Groff
|
0c27f30475
|
compiler.cfg.intrinsics.simd: use new ##gather-int-vector insns to construct int vectors when available
|
2010-05-15 23:59:27 -07:00 |
Joe Groff
|
8c878ada17
|
compiler.cfg.instructions: ##gather-int-vector-2/4 instructions that map to SSE4 PINSR/PEXTR
|
2010-05-15 23:48:22 -07:00 |
Joe Groff
|
7c0cd6dc37
|
cpu.x86: fix bootstrap load error
|
2010-05-15 15:28:22 -07:00 |
Joe Groff
|
3de020c18a
|
cpu.x86: don't enable bit-count intrinsic by default
|
2010-05-15 14:52:00 -07:00 |
Joe Groff
|
3956dd1516
|
cpu.x86.features: ( int alien-assembly ) c-bool> ==> ( bool alien-assembly )
|
2010-05-15 14:33:19 -07:00 |
Joe Groff
|
009408dd11
|
cpu.x86: enable bit-count intrinsic if POPCNT available
|
2010-05-15 14:00:12 -07:00 |
Joe Groff
|
5d35917061
|
compiler.cfg.intrinsics: intrinsic for fixnum-bit-count
|
2010-05-15 13:59:47 -07:00 |
Joe Groff
|
7fec53b509
|
compiler.cfg.instructions: ##bit-count insn
|
2010-05-15 13:57:35 -07:00 |
Joe Groff
|
7c6c4ef8ae
|
math.bitwise: factor M\ fixnum (bit-count) to a separate word so it can be made intrinsic
|
2010-05-15 13:27:26 -07:00 |
Joe Groff
|
c00272d80a
|
cpu.x86.features: add popcnt? test
|
2010-05-15 13:26:14 -07:00 |
Joe Groff
|
d5b7ec3348
|
cpu.x86.assembler: SETcc instructions
|
2010-05-15 13:14:27 -07:00 |
Joe Groff
|
986ed057d8
|
cpu.x86.assembler: BT family instructions
|
2010-05-15 13:08:22 -07:00 |
Joe Groff
|
010b5069bd
|
opengl.textures: borrow get-texture-float and get-texture-int helper words from gpu.textures
|
2010-05-15 12:09:50 -07:00 |
Slava Pestov
|
5c0c87fcaa
|
compiler.cfg.value-numbering.comparisons: ##test-imm rewrite rule must check that the immediate fits
|
2010-05-15 03:19:24 -04:00 |
Slava Pestov
|
ad7636045f
|
compiler: fix bad unit test
|
2010-05-14 18:37:11 -04:00 |
Slava Pestov
|
62eadda2aa
|
cpu.x86.bootstrap: use TEST instruction
|
2010-05-14 18:37:10 -04:00 |
Slava Pestov
|
5ecd2b61c7
|
compiler.cfg: more silly optimizations
|
2010-05-14 18:37:09 -04:00 |
Slava Pestov
|
1a61c50896
|
compiler.cfg.instructions: change vreg-insn from a mixin into a superclass
|
2010-05-14 18:37:09 -04:00 |
Slava Pestov
|
6d30bb8bf4
|
compiler.cfg.linear-scan: pointless optimizations
|
2010-05-14 18:37:08 -04:00 |
Slava Pestov
|
291543c300
|
compiler.cfg.ssa.live-ranges: clean up
|
2010-05-14 18:37:08 -04:00 |
Slava Pestov
|
2a137bed0e
|
bootstrap.compiler.timing: small update
|
2010-05-14 18:37:07 -04:00 |
Slava Pestov
|
d1e422c981
|
compiler.cfg.alias-analysis: simplify and speed up
|
2010-05-14 18:37:07 -04:00 |
Slava Pestov
|
5a67711bfd
|
compiler.cfg: use x86 TEST instruction to optimize 'bitand 0 ='
|
2010-05-14 18:37:06 -04:00 |
Joe Groff
|
22625469bc
|
sequences.cords: specialize vshuffle-elements to use vshuffle2-elements on cord components
|
2010-05-14 13:29:37 -07:00 |
Joe Groff
|
8f1751cd54
|
math.vectors.simd.intrinsics: fix scalar fallback for (simd-vshuffle2-elements)
|
2010-05-14 02:47:39 -07:00 |
Joe Groff
|
2744816209
|
math.vectors, math.vectors.simd: add user-facing vshuffle2 word
|
2010-05-14 02:47:05 -07:00 |
Joe Groff
|
465a1673eb
|
compiler.cfg.intrinsics.simd: mod shuffle indices for shuffle-2-vectors-imm intrinsic so they wrap like a real instruction would
|
2010-05-14 01:20:05 -07:00 |
Joe Groff
|
9f9e145819
|
math.vectors.simd.intrinsics: (simd-vshuffle2-elements) intrinsic that creates a vector by selecting elements from two input vectors. use ##shuffle-vector-halves-imm to implement for double-2s with SSE
|
2010-05-14 01:16:29 -07:00 |
Joe Groff
|
3766abd65e
|
compiler.cfg.instructions: ##shuffle-vector-halves-imm insn to map to SSE's two-input SHUFPS/SHUFPD
|
2010-05-14 00:20:21 -07:00 |
Slava Pestov
|
fe30355ec7
|
math.vectors.simd.cords: implement new-sequence and like methods on cords to make cross product work
|
2010-05-13 21:55:19 -04:00 |
Slava Pestov
|
4a98278720
|
cpu.x86.32: check for SSE2 on bootstrap since Factor now requires it
|
2010-05-13 18:25:46 -04:00 |
Anton Gorenko
|
83819c9902
|
Merge branch 'master' of git://factorcode.org/git/factor
|
2010-05-13 17:58:01 +06:00 |
Slava Pestov
|
bb87d124c1
|
compiler: small fixes and cleanups
|
2010-05-13 02:48:20 -04:00 |
Joe Groff
|
8b9f33e040
|
x11: convert XSupportsLocale return value to factor bool before testing (bug reported by ceninan)
|
2010-05-12 18:07:33 -07:00 |
Slava Pestov
|
db2db6a1a6
|
compiler.cfg.builder.alien: fix for x86-32
|
2010-05-12 18:07:11 -04:00 |
Slava Pestov
|
42b0d456cd
|
Refactor x86-32 stack cleanup logic
|
2010-05-12 02:09:11 -04:00 |
Slava Pestov
|
f89b85db7b
|
Temporary fixes for x86-32 until FFI boxing is rewritten
|
2010-05-12 01:41:49 -04:00 |
Slava Pestov
|
0cde5c8fb5
|
Eliminate compiler.alien
|
2010-05-11 23:24:47 -04:00 |
Slava Pestov
|
1c76c87c5c
|
cpu.x86.64: fix typo
|
2010-05-11 22:29:46 -04:00 |
Slava Pestov
|
ee0640f176
|
Move flatten-c-type to death row so that it can be executed in part 5
|
2010-05-11 22:26:31 -04:00 |
Slava Pestov
|
eb802208d1
|
FFI rewrite part 4: parameter and return value unboxing redesign
|
2010-05-11 19:11:44 -04:00 |
Anton Gorenko
|
e97f10ff6b
|
add generation of records as STRUCT: with slots when the record is listed in IMPLEMENT-STRUCTS:, add generation of enumerations as ENUM:
|
2010-05-11 23:31:35 +06:00 |
Slava Pestov
|
423f9c607a
|
cpu.ppc: fixes
|
2010-05-10 17:50:10 -05:00 |
Anton Gorenko
|
b2b5365ebd
|
Merge branch 'master' of git://factorcode.org/git/factor
|
2010-05-10 23:42:41 +06:00 |
Slava Pestov
|
9321f9378a
|
cpu.ppc: update for recent changes -- untested
|
2010-05-10 02:21:23 -04:00 |
Slava Pestov
|
45689dbfe6
|
compiler: simplify ##unbox-small/large-struct by emitting an ##unbox-any-c-ptr first
|
2010-05-10 01:38:34 -04:00 |
Slava Pestov
|
4478c3a51a
|
FFI rewrite part 3: eliminate ##push-context-stack and ##pop-context-stack
|
2010-05-10 00:46:29 -04:00 |
Slava Pestov
|
acfbea3865
|
compiler.codegen.fixup: remove unused variable
|
2010-05-10 00:45:48 -04:00 |
Slava Pestov
|
7450dcf9ff
|
cpu.x86.32: fix load error
|
2010-05-09 23:36:57 -04:00 |
Slava Pestov
|
7316d41226
|
FFI rewrite part 2: use ##peek and ##replace instructions to access stack
|
2010-05-09 23:26:43 -04:00 |
Slava Pestov
|
2912f21acc
|
cpu.x86.64.unix: fix load error
|
2010-05-09 22:15:14 -04:00 |
Slava Pestov
|
839e26de3a
|
cpu.x86.32: fix load error
|
2010-05-09 21:55:21 -04:00 |
Slava Pestov
|
c211c3e84e
|
FFI rewrite part 1: split up ##alien-invoke and friends into smaller instructions
|
2010-05-09 21:36:52 -04:00 |
Anton Gorenko
|
56280003c5
|
pango is gir-based now (very draft version)
|
2010-05-09 23:25:47 +06:00 |
Anton Gorenko
|
da25daeb51
|
first commit (move from factor-gir); basis/pango is gir-based now (very draft version); add gstreamer and gtkglext modules and samples
|
2010-05-09 23:21:12 +06:00 |
Slava Pestov
|
fa99cc8f0e
|
ui.backend.windows: faster wheel mouse scroll rate
|
2010-05-07 18:26:16 -04:00 |
Slava Pestov
|
f988dad79c
|
compiler.cfg: add ##load-float instruction for single precision floating point constants
|
2010-05-07 18:26:00 -04:00 |
Slava Pestov
|
982e704626
|
compiler.cfg.linear-scan: clean up clobber-insn handling
|
2010-05-07 18:22:35 -04:00 |
Slava Pestov
|
d215d691b5
|
Load debugger.{unix,windows} later on in bootstrap, because lopading it before the optimizing compiler incurs a long delay on Windows as all the WinAPI bindings get loaded and parsed
|
2010-05-06 17:41:00 -04:00 |
Slava Pestov
|
627295f094
|
Language change: tuple slot setter words with stack effect ( value object -- ) are now named FOO<< instead of (>>FOO)
|
2010-05-06 17:21:02 -04:00 |
Joe Groff
|
98db8b5e78
|
windows.directx.dinput: redo constant generation yet again to get compile time under control
|
2010-05-05 23:26:54 -07:00 |
Slava Pestov
|
020c011d00
|
cpu.ppc: add missing cases to ##load/store-memory instructions
|
2010-05-05 13:37:25 -04:00 |
Slava Pestov
|
32ab6ca8d8
|
compiler.cfg.intrinsics: may as well use cell-size stores instead of 32-bit stores when initializing byte arrays
|
2010-05-05 13:23:00 -04:00 |
Slava Pestov
|
07092df20b
|
compiler.cfg.intrinsics.allot: fix <byte-array> intrinsic for real. Don't ever check in code without testing it
|
2010-05-05 13:17:20 -04:00 |
Slava Pestov
|
aaa706dd29
|
cpu.x86.32: fix load error
|
2010-05-05 02:54:48 -04:00 |
Slava Pestov
|
0dab9c7f9d
|
compiler.cfg.intrinsics.allot: <byte-array> intrinsic was writing past the end of the array and this was causing problems for scheduling
|
2010-05-05 02:17:57 -04:00 |
Slava Pestov
|
e763c74096
|
More FFI cleanups
|
2010-05-05 01:13:45 -04:00 |
Slava Pestov
|
029719f757
|
functors: fix unit test
|
2010-05-05 00:44:21 -04:00 |
Slava Pestov
|
de8e0ccd5c
|
alien.c-types: cleanup
|
2010-05-04 19:33:55 -04:00 |
Slava Pestov
|
5fbc42e184
|
bootstrap.compiler.timing: update
|
2010-05-04 19:33:54 -04:00 |
Slava Pestov
|
f693e64798
|
vm: fix field order in zone struct
|
2010-05-04 17:57:53 -04:00 |
Daniel Ehrenberg
|
24ad579631
|
Merge branch 'master' of git://factorcode.org/git/factor
|
2010-05-04 09:52:34 -05:00 |
Daniel Ehrenberg
|
4f66732c36
|
Fixing scheduling for compiler changes
|
2010-05-04 09:48:16 -05:00 |
Slava Pestov
|
f3ea9288df
|
cpu.ppc: updating optimizing compiler backend for recent changes
|
2010-05-04 05:51:54 -05:00 |
Slava Pestov
|
92a4b5ec7b
|
cpu.ppc.assembler: new opcodes: LFDUX LFDX LFSUX LFSX STFDUX STFDX STFSUX STFSX
|
2010-05-04 05:47:21 -05:00 |
Slava Pestov
|
035a2e9b63
|
compiler: more tests
|
2010-05-04 05:46:45 -05:00 |
Slava Pestov
|
572d7f77f8
|
compiler.cfg.value-numbering: don't use complex addressing modes unless architecture supports it
|
2010-05-04 05:46:21 -05:00 |