Commit Graph

3110 Commits

Author SHA1 Message Date
bjorn3
441e2e67fa Rustup to rustc 1.60.0-nightly (88fb06a1f 2022-02-05) 2022-02-06 14:50:12 +01:00
bjorn3
bccf0a1f8d Merge codegen of a couple more simd intrinsics 2022-01-30 19:44:15 +01:00
bjorn3
5a3cfb24d8 Merge codegen of several simd intrinsics
This reduces code duplication
2022-01-30 19:37:01 +01:00
bjorn3
c1d699d37b Remove the remaining simd intrinsic macros 2022-01-30 19:31:18 +01:00
bjorn3
1ae27ea6aa Remove simd_cmp macro
This reduces duplication in the codegened source file
2022-01-30 19:19:54 +01:00
bjorn3
037aafbbaf Fix simd type validation 2022-01-30 18:35:08 +01:00
bjorn3
bb1b5cdde2 Remove validate_atomic_type
By expanding it in place. Also extract a common
report_atomic_type_validation_error function to reduce code duplication.
2022-01-30 18:23:01 +01:00
bjorn3
5efd7782b3 Don't generate unnecessary let $arg=$arg for intrinsics 2022-01-30 18:00:36 +01:00
bjorn3
246998f5ec Remove some unused lint allows 2022-01-30 17:43:09 +01:00
bjorn3
1b8ea0705e Add const_allocate and const_deallocate intrinsics 2022-01-30 17:35:33 +01:00
bjorn3
3ff158e3ed Update dependencies 2022-01-30 16:57:30 +01:00
bjorn3
96dc846a7d Rustup to rustc 1.60.0-nightly (a00e130da 2022-01-29) 2022-01-30 16:52:18 +01:00
bjorn3
2d32e51d86 Sync from rust a00e130dae 2022-01-30 13:25:57 +01:00
pierwill
2c26139bbc Use an indexmap to avoid sorting LocalDefIds
Update `indexmap` to 1.8.0.

Bless test
2022-01-22 22:34:16 -06:00
bjorn3
cc24cea101 Rustfmt 2022-01-19 16:38:58 +01:00
bjorn3
c6e607a947 Implement unchecked_mul intrinsic 2022-01-19 15:45:04 +01:00
bjorn3
7a8227ecf9 Rustup to rustc 1.60.0-nightly (9ad5d82f8 2022-01-18) 2022-01-19 15:36:14 +01:00
bjorn3
400f122709 Sync from rust 2f004d2d40 2022-01-19 15:26:05 +01:00
lcnr
513d72d007 remove is_noop 2022-01-19 13:58:29 +01:00
bjorn3
78b65718bc Split compile_fn out of codegen_fn 2022-01-18 19:07:26 +01:00
bjorn3
5f6c59e63f Pass only the Function to write_clif_file 2022-01-18 18:58:37 +01:00
bjorn3
f3b2d37e77 Record object file artifact size in self profile data 2022-01-18 15:24:11 +01:00
bjorn3
b91ecc78bf Update rustc test ignore list 2022-01-18 13:59:40 +01:00
bjorn3
0472f6c91c Use 2021 edition for libcore tests 2022-01-18 13:41:01 +01:00
bjorn3
b85cbddf75 Rustup to rustc 1.60.0-nightly (ee5d8d37b 2022-01-17) 2022-01-18 13:02:02 +01:00
bjorn3
489bff5543 Sync from rust 7531d2fdd4 2022-01-18 12:49:50 +01:00
bjorn3
e59b024e02 Pass target_features set instead of has_feature closure
This avoids unnecessary monomorphizations in codegen backends
2022-01-17 18:06:30 +01:00
bjorn3
48abe3c6fa Use Symbol for target features in asm handling
This saves a couple of Symbol::intern calls
2022-01-17 18:06:27 +01:00
bors
0b58e52786 Auto merge of #92816 - tmiasko:rm-llvm-asm, r=Amanieu
Remove deprecated LLVM-style inline assembly

The `llvm_asm!` was deprecated back in #87590 1.56.0, with intention to remove
it once `asm!` was stabilized, which already happened in #91728 1.59.0. Now it
is time to remove `llvm_asm!` to avoid continued maintenance cost.

Closes #70173.
Closes #92794.
Closes #87612.
Closes #82065.

cc `@rust-lang/wg-inline-asm`

r? `@Amanieu`
2022-01-17 09:40:29 +00:00
Ellen
eef35308ef initial revert 2022-01-15 01:16:55 +00:00
Tomasz Miąsko
7ec4de3ab8 Remove deprecated LLVM-style inline assembly 2022-01-12 18:51:31 +01:00
Aaron Hill
409276cf55 Store a Symbol instead of an Ident in VariantDef/FieldDef
The field is also renamed from `ident` to `name. In most cases,
we don't actually need the `Span`. A new `ident` method is added
to `VariantDef` and `FieldDef`, which constructs the full `Ident`
using `tcx.def_ident_span()`. This method is used in the cases
where we actually need an `Ident`.

This makes incremental compilation properly track changes
to the `Span`, without all of the invalidations caused by storing
a `Span` directly via an `Ident`.
2022-01-11 10:16:22 -05:00
bjorn3
8f02c4e2ee Add y.bin to clean_all.sh 2022-01-10 12:26:23 +01:00
bjorn3
759c4ac08f Update to Cranelift 0.80.0 2022-01-10 12:26:03 +01:00
bjorn3
4dbd3196f9 Move most code from y.rs to build_system/mod.rs
y.rs can't be rustfmt'ed without making it no longer be a valid bash
script.
2022-01-09 19:30:07 +01:00
bjorn3
f328359787
Merge pull request #1216 from bjorn3/reduce_cg_clif_compile_times
Refactor the intrinsics module for slightly better build times
2022-01-09 19:25:10 +01:00
bjorn3
b7cda373d5 Pass Ty instead of TyAndLayout to the closure of various simd helpers
This reduces the total amount of llvm ir lines for simd related
functions from 9604 to 9467.
2022-01-09 19:07:15 +01:00
bjorn3
2633024850 Don't monomorphize the simd helpers for each closure
This halves the total amount of llvm ir lines for simd related functions
from 18227 to 9604.
2022-01-09 18:55:57 +01:00
bjorn3
b60eced405 Return Value instead of CValue from the simd_for_each_lane closure 2022-01-09 18:43:08 +01:00
bjorn3
57d25ef60e Use simplified version of bool_to_zero_or_max_uint in simd_cmp 2022-01-09 18:32:27 +01:00
bjorn3
d4d2b24d55 Slightly simplify some macros by removing an extra case for when signedness doesn't matter
This is slightly more verbose when invoking the macro.
2022-01-09 17:44:55 +01:00
bjorn3
78e2d4a275 Remove support for vector icmp for now
Real simd support will need an overhaul in the future anyway. For now it
only complicates the code.
2022-01-09 17:39:00 +01:00
bjorn3
8ace43e650 Move a couple of macros to intrinsics::simd 2022-01-09 17:34:55 +01:00
bjorn3
4e3a8d5fb9 Move validate_simd_type from intrinsics to intrinsics::simd 2022-01-09 17:30:01 +01:00
bjorn3
9295b086f6 Turn validate_simd_type into a function
This effectively outlines it, significantly reducing the size of
the codegen_simd_intrinsic_call llvm ir from 10419 lines to 6378 lines.
2022-01-09 17:29:16 +01:00
bjorn3
9e6d8c1b24 Remove the call_intrinsic_match macro 2022-01-09 17:22:23 +01:00
bjorn3
baad993dae Dedup codegen_operand calls in codegen_float_intrinsic_call
This reduces the amount of llvm ir lines for this function by a little
over half from 1662 to 781.
2022-01-09 17:19:11 +01:00
bjorn3
300974714c Dedup write_cvalue calls in codegen_float_intrinsic_call
Also directly use an array instead of going through a tuple. This
reduces the amount of llvm ir lines for this function by almost half
from 3086 to 1662.
2022-01-09 17:11:28 +01:00
bjorn3
a1a164083e Move call_intrinsic_match macro into codegen_float_intrinsic_call 2022-01-09 16:44:54 +01:00
bjorn3
046e094842 Only use a single bug!() invocation in call_intrinsic_match
This reduces code size
2022-01-09 15:40:40 +01:00