Andrew Brown
e45ef24d3b
Convert SIMD load and store to their respective CLIF instructions
2019-09-27 12:48:30 -07:00
Joshua Nelson
a1f6457e8a
Allow building without std ( #1069 )
...
Closes https://github.com/CraneStation/cranelift/issues/1067
2019-09-26 18:00:03 +02:00
Nicolas B. Pierron
40f6d3b753
Set speed-and-size optimization level for legalize-br-table-bb.clif test case.
2019-09-26 12:05:53 +02:00
Sean Stangl
3d5346a90b
Name opcodes statically in isa/x86. Closes #1051 ( #1079 )
2019-09-25 19:59:49 -06:00
Nick Fitzgerald
8c3072c774
Combine VisibleTranslationState and TranslationState ( #1076 )
...
`VisibleTranslationState` was a wrapper around a `TranslationState` that was
meant to public API consumers outside of this crate. However, the internal
`TranslationState` and all its methods were still publicly exposed! This commit
simplifies and remedies the situation by combining them into a single
`TranslationState` type. Most of its methods are only `pub(crate)` now, not
visible to the entire world. The only methods that are `pub` are the ones that
`VisibleTranslationState` exposed.
2019-09-25 13:07:54 -06:00
Benjamin Bouvier
46ab1b4103
Liverange: use a macro to make Order comparisons simpler to read;
2019-09-25 11:43:29 +02:00
Benjamin Bouvier
5beb10e77a
Regalloc: remove the transient LiveRangeContext data structure;
2019-09-25 11:43:29 +02:00
Benjamin Bouvier
b9b1c842e9
Use LiveRange::reaches_use instead of reimplementing it in liveness checks;
2019-09-25 11:43:29 +02:00
Benjamin Bouvier
59f5f12c60
[codegen] Rename GenLiveRange to GenericLiveRange;
...
(to avoid confuson with Gen interpreted as Generator)
2019-09-25 11:43:29 +02:00
Benjamin Bouvier
b036ab77dc
Update comment about the live range implementation details;
2019-09-25 11:43:29 +02:00
Ujjwal Sharma
43a891dfa2
[codegen] add intcc conditions for reading overflow flag
...
Add conditions to IntCC for checking the overflow flag (Overflow,
NotOverflow).
2019-09-25 11:42:58 +02:00
Dan Gohman
dfdd504edc
Bump version to 0.44.0
2019-09-24 16:28:17 -07:00
Ujjwal Sharma
6e131e5347
[codegen] add intcc conditions for reading carry flag
...
Add conditions to IntCC for checking the carry flag (Carry, NotCarry).
Fixes: https://github.com/CraneStation/cranelift/issues/980
2019-09-24 15:12:09 -07:00
Artur Jamro
1431ab5201
Derive serde traits for TrapCode
2019-09-24 10:50:52 -07:00
Andrew Brown
636ef98024
Use existing is_equal predicate with the newly-shared condition codes
...
This removes the `HasConditionCode(&'static str)` predicate and the associated issues with that.
2019-09-24 09:33:07 -07:00
Andrew Brown
c648fa3d06
Move condcodes.rs to a new crate, cranelift-codegen-shared
...
This move allows the `IntCC`/`FloatCC` enums to be used in both meta (for predicate matching) and in codegen. To avoid breaking any code dependent on the previous location of condcodes.rs (`cranelift-codegen/src/condcodes.rs`), the module is re-exported under `cranelift_codegen::ir`.
2019-09-24 09:33:07 -07:00
Andrew Brown
a3db30d97e
Add x86 encoding for SIMD icmp eq
...
Also adds a predicate for matching the `eq` IntCC code (TODO this should be replaced by something more general)
2019-09-24 09:33:07 -07:00
Andrew Brown
702155b19b
Optimize vconst for x86 when immediate contains all zeroes or ones
...
Instead of using MOVUPS to expensively load bits from memory, this change uses a predicate to optimize vconst without a memory access:
- when the 128-bit immediate is all zeroes in all bits, use PXOR to zero out an XMM register
- when the 128-bit immediate is all ones in all bits, use PCMPEQB to set an XMM register to all ones
This leaves the constant data in the constant pool, which may increase code size (TODO)
2019-09-24 09:33:07 -07:00
Nicolas B. Pierron
694de912a5
Update brnz.i128 legalization to use non-extended basic blocks.
2019-09-24 15:55:58 +02:00
Nicolas B. Pierron
26cfbafb32
Add ebb macro to insert a new blocks in legalization output.
2019-09-24 15:55:58 +02:00
Nicolas B. Pierron
0c1f17d6dd
Add empty_vararg literal to generate jump instruction.
2019-09-24 15:55:58 +02:00
Nicolas B. Pierron
614fb7b526
Factor out the var_index function.
2019-09-24 15:55:58 +02:00
Pat Hickey
4052bc04ee
cranelift-wasm: upgrade to wasmparser 0.39.1 ( #1068 )
...
Uses new SectionContent api, which is simpler than matching on
SectionCode and then getting the right reader, & avoids possible panics
2019-09-23 16:47:13 -07:00
Erin Power
947fce194e
Replaced instances of SparseSet with EntitySet
2019-09-23 17:20:25 +02:00
Benjamin Bouvier
f0244516c5
[meta] Make more things pub(crate) instead of pub;
...
This could help the compiler find unused fields/methods. It didn't find any
during this migration.
2019-09-23 14:42:20 +02:00
Benjamin Bouvier
c2587c9d61
[meta] Remove Literal's kind field;
2019-09-23 14:42:20 +02:00
Benjamin Bouvier
3ab8eed7d3
Remove unused core::mem import;
2019-09-23 14:41:07 +02:00
Anthony Ramine
eeb3159fe9
Make wasm_unsupported be composeable
2019-09-23 10:36:03 +02:00
Anthony Ramine
26accbadf8
Use f32::to_bits and f64::to_bits
2019-09-23 10:36:03 +02:00
Anthony Ramine
178241625c
Use slice::from_ref and slice::from_mut
2019-09-23 10:36:03 +02:00
Dan Gohman
411545ed9a
Bump version to 0.43.1
2019-09-20 14:11:15 -07:00
Andrew Brown
2330ca7e2c
Fix incorrect regmove and fill encodings for SIMD types
...
- `fill` attempted to use a GPR recipe, `fillSib32`, instead of its FPR equivalent, `ffillSib32` (code compiled without error but incorrect instructions were allowed, e.g. `v1 = regmove v0, %rdi -> %xmm0`
- `regmove` could be encoded with a GPR recipe, `rmov`, which hid the above incorrectness; now only FPR-to-FPR regmoves are allowed using the `frmov` recipe
2019-09-20 14:02:03 -07:00
Nick Fitzgerald
9b8e7b511e
tidy: Remove extra semicolons
...
These were causing compilation warnings.
2019-09-19 16:25:49 -07:00
Dan Gohman
5c5eabb8d0
Bump version to 0.43.0
2019-09-19 12:23:51 -07:00
Andrew Brown
fe25abeb0d
Add x86 encodings for vector copy, copy_nop, fill_nop
2019-09-19 12:04:14 -07:00
Andrew Brown
766cf8ddfd
Add x86 implemention for SIMD iadd
2019-09-19 12:04:14 -07:00
Andrew Brown
cd426cb7bc
Rename Uimm128 to V128Imm
2019-09-19 12:04:14 -07:00
Andrew Brown
6cbc6e8bfb
Handle use of SIMD vector globals and locals
2019-09-19 12:04:14 -07:00
Andrew Brown
7e6913e362
Add x86 encodings for vector store, load, fill, spill, and regmove
2019-09-19 12:04:14 -07:00
Andrew Brown
ddd1680e76
Add V128 -> I8X16 type conversions
2019-09-19 12:04:14 -07:00
Andrew Brown
13ac951004
Allow global initialization of SIMD vectors
2019-09-19 12:04:14 -07:00
Wander Lairson Costa
1e74d01111
Check for types::INVALID in the function signature, resolves #493 ( #1046 )
2019-09-19 11:26:17 -07:00
Andrew Brown
20c67f243e
Add boolean shuffle test
2019-09-19 10:53:40 -07:00
Andrew Brown
e72434e58f
Add boolean encodings for x86
...
Includes and, or, xor, not, and regmove; TODO re-factor PerCpuModeEncodings to avoid code duplication
2019-09-19 10:53:40 -07:00
Andrew Brown
af1499ce99
Add x86 implementation of shuffle
2019-09-19 10:53:40 -07:00
julian-seward1
9e088e4164
Reorganise optimisation level settings, and make the insn shrink pass optional ( #1044 )
...
This patch:
* removes the "default" opt level, on the basis that it has no definition and
is referred to nowhere in the compiler.
* renames the "fastest" level to "none". The resulting set of transformations
is unchanged.
* renames the "best" level to "speed_and_size". The resulting set of
transformations is unchanged.
* adds a new level, "speed". This is the same as "speed_and_size" except that
it omits transformations aimed only at reducing code size. Currently it
omits only the insn shrinking pass.
2019-09-19 18:51:25 +02:00
Joshua Nelson
59139c6c46
Add more documentation for entities, fixes #1038 ( #1041 )
...
Also fixes broken links to point to docs.rs; see
https://github.com/CraneStation/cranelift/pull/1041#issuecomment-532356880 ,
there doesn't currently seem to be a way to link to a type in a
dependent crate.
2019-09-18 16:48:57 -07:00
Joshua Nelson
e252e0f5b7
fix broken link in cranelift-object
2019-09-18 08:33:17 -07:00
Erin Power
3c6795decf
Fixed broken pipe race condition in ensure_installed
2019-09-18 11:11:30 +02:00
AnthonyMikh
c0274eca24
Simplify and rename Stackmap::from_vec ( #1032 )
...
Co-Authored-By: bjorn3 <bjorn3@users.noreply.github.com >
2019-09-18 10:11:32 +02:00