Skip to content

Commit fe07ece

Browse files
committed
Auto merge of #74724 - Manishearth:rollup-plbt8fe, r=Manishearth
Rollup of 8 pull requests Successful merges: - #72954 (revise RwLock for HermitCore) - #74367 (Rearrange the pipeline of `pow` to gain efficiency) - #74491 (Optimize away BitAnd and BitOr when possible) - #74639 (Downgrade glibc to 2.11.1 for ppc, ppc64 and s390x) - #74661 (Refactor `region_name`: add `RegionNameHighlight`) - #74692 (delay_span_bug instead of silent ignore) - #74698 (fixed error reporting for mismatched traits) - #74715 (Add a system for creating diffs across multiple mir optimizations.) Failed merges: r? @ghost
2 parents cfb6114 + 5d1d94e commit fe07ece

37 files changed

+963
-722
lines changed

Cargo.lock

+2-2
Original file line numberDiff line numberDiff line change
@@ -1242,9 +1242,9 @@ dependencies = [
12421242

12431243
[[package]]
12441244
name = "hermit-abi"
1245-
version = "0.1.14"
1245+
version = "0.1.15"
12461246
source = "registry+https://github.com/rust-lang/crates.io-index"
1247-
checksum = "b9586eedd4ce6b3c498bc3b4dd92fc9f11166aa908a914071953768066c67909"
1247+
checksum = "3deed196b6e7f9e44a2ae8d94225d80302d81208b1bb673fd21fe634645c85a9"
12481248
dependencies = [
12491249
"compiler_builtins",
12501250
"libc",

src/ci/docker/README.md

+3-3
Original file line numberDiff line numberDiff line change
@@ -238,7 +238,7 @@ For targets: `powerpc-unknown-linux-gnu`
238238
- Target options > Emit assembly for CPU = powerpc -- pure 32-bit PowerPC
239239
- Operating System > Target OS = linux
240240
- Operating System > Linux kernel version = 2.6.32.68 -- ~RHEL6 kernel
241-
- C-library > glibc version = 2.12.2 -- ~RHEL6 glibc
241+
- C-library > glibc version = 2.11.1 -- ~SLE11-SP4 glibc
242242
- C compiler > gcc version = 5.2.0
243243
- C compiler > C++ = ENABLE -- to cross compile LLVM
244244
@@ -255,7 +255,7 @@ For targets: `powerpc64-unknown-linux-gnu`
255255
- Target options > Tune for CPU = power6 -- (+)
256256
- Operating System > Target OS = linux
257257
- Operating System > Linux kernel version = 2.6.32.68 -- ~RHEL6 kernel
258-
- C-library > glibc version = 2.12.2 -- ~RHEL6 glibc
258+
- C-library > glibc version = 2.11.1 -- ~SLE11-SP4 glibc
259259
- C compiler > gcc version = 5.2.0
260260
- C compiler > C++ = ENABLE -- to cross compile LLVM
261261
@@ -272,7 +272,7 @@ For targets: `s390x-unknown-linux-gnu`
272272
- Target options > Bitness = 64-bit
273273
- Operating System > Target OS = linux
274274
- Operating System > Linux kernel version = 2.6.32.68 -- ~RHEL6 kernel
275-
- C-library > glibc version = 2.12.2 -- ~RHEL6 glibc
275+
- C-library > glibc version = 2.11.1 -- ~SLE11-SP4 glibc
276276
- C compiler > gcc version = 5.2.0
277277
- C compiler > gcc extra config = --with-arch=z10 -- LLVM's minimum support
278278
- C compiler > C++ = ENABLE -- to cross compile LLVM

src/ci/docker/host-x86_64/dist-powerpc-linux/powerpc-linux-gnu.config

+3-3
Original file line numberDiff line numberDiff line change
@@ -290,7 +290,7 @@ CT_BINUTILS_EXTRA_CONFIG_ARRAY=""
290290
# C-library
291291
#
292292
CT_LIBC="glibc"
293-
CT_LIBC_VERSION="2.12.2"
293+
CT_LIBC_VERSION="2.11.1"
294294
CT_LIBC_glibc=y
295295
# CT_LIBC_musl is not set
296296
# CT_LIBC_uClibc is not set
@@ -309,9 +309,9 @@ CT_THREADS="nptl"
309309
# CT_LIBC_GLIBC_V_2_14_1 is not set
310310
# CT_LIBC_GLIBC_V_2_14 is not set
311311
# CT_LIBC_GLIBC_V_2_13 is not set
312-
CT_LIBC_GLIBC_V_2_12_2=y
312+
# CT_LIBC_GLIBC_V_2_12_2 is not set
313313
# CT_LIBC_GLIBC_V_2_12_1 is not set
314-
# CT_LIBC_GLIBC_V_2_11_1 is not set
314+
CT_LIBC_GLIBC_V_2_11_1=y
315315
# CT_LIBC_GLIBC_V_2_11 is not set
316316
# CT_LIBC_GLIBC_V_2_10_1 is not set
317317
# CT_LIBC_GLIBC_V_2_9 is not set

src/ci/docker/host-x86_64/dist-powerpc64-linux/powerpc64-linux-gnu.config

+3-3
Original file line numberDiff line numberDiff line change
@@ -290,7 +290,7 @@ CT_BINUTILS_EXTRA_CONFIG_ARRAY=""
290290
# C-library
291291
#
292292
CT_LIBC="glibc"
293-
CT_LIBC_VERSION="2.12.2"
293+
CT_LIBC_VERSION="2.11.1"
294294
CT_LIBC_glibc=y
295295
# CT_LIBC_musl is not set
296296
# CT_LIBC_uClibc is not set
@@ -309,9 +309,9 @@ CT_THREADS="nptl"
309309
# CT_LIBC_GLIBC_V_2_14_1 is not set
310310
# CT_LIBC_GLIBC_V_2_14 is not set
311311
# CT_LIBC_GLIBC_V_2_13 is not set
312-
CT_LIBC_GLIBC_V_2_12_2=y
312+
# CT_LIBC_GLIBC_V_2_12_2 is not set
313313
# CT_LIBC_GLIBC_V_2_12_1 is not set
314-
# CT_LIBC_GLIBC_V_2_11_1 is not set
314+
CT_LIBC_GLIBC_V_2_11_1=y
315315
# CT_LIBC_GLIBC_V_2_11 is not set
316316
# CT_LIBC_GLIBC_V_2_10_1 is not set
317317
# CT_LIBC_GLIBC_V_2_9 is not set

src/ci/docker/host-x86_64/dist-s390x-linux/s390x-linux-gnu.config

+3-3
Original file line numberDiff line numberDiff line change
@@ -270,7 +270,7 @@ CT_BINUTILS_EXTRA_CONFIG_ARRAY=""
270270
# C-library
271271
#
272272
CT_LIBC="glibc"
273-
CT_LIBC_VERSION="2.12.2"
273+
CT_LIBC_VERSION="2.11.1"
274274
CT_LIBC_glibc=y
275275
# CT_LIBC_musl is not set
276276
# CT_LIBC_uClibc is not set
@@ -289,9 +289,9 @@ CT_THREADS="nptl"
289289
# CT_LIBC_GLIBC_V_2_14_1 is not set
290290
# CT_LIBC_GLIBC_V_2_14 is not set
291291
# CT_LIBC_GLIBC_V_2_13 is not set
292-
CT_LIBC_GLIBC_V_2_12_2=y
292+
# CT_LIBC_GLIBC_V_2_12_2 is not set
293293
# CT_LIBC_GLIBC_V_2_12_1 is not set
294-
# CT_LIBC_GLIBC_V_2_11_1 is not set
294+
CT_LIBC_GLIBC_V_2_11_1=y
295295
# CT_LIBC_GLIBC_V_2_11 is not set
296296
# CT_LIBC_GLIBC_V_2_10_1 is not set
297297
# CT_LIBC_GLIBC_V_2_9 is not set

src/libcore/num/mod.rs

+44-43
Original file line numberDiff line numberDiff line change
@@ -1095,6 +1095,9 @@ $EndFeature, "
10951095
without modifying the original"]
10961096
#[inline]
10971097
pub const fn checked_pow(self, mut exp: u32) -> Option<Self> {
1098+
if exp == 0 {
1099+
return Some(1);
1100+
}
10981101
let mut base = self;
10991102
let mut acc: Self = 1;
11001103

@@ -1105,15 +1108,11 @@ $EndFeature, "
11051108
exp /= 2;
11061109
base = try_opt!(base.checked_mul(base));
11071110
}
1108-
1111+
// since exp!=0, finally the exp must be 1.
11091112
// Deal with the final bit of the exponent separately, since
11101113
// squaring the base afterwards is not necessary and may cause a
11111114
// needless overflow.
1112-
if exp == 1 {
1113-
acc = try_opt!(acc.checked_mul(base));
1114-
}
1115-
1116-
Some(acc)
1115+
Some(try_opt!(acc.checked_mul(base)))
11171116
}
11181117
}
11191118

@@ -1622,6 +1621,9 @@ $EndFeature, "
16221621
without modifying the original"]
16231622
#[inline]
16241623
pub const fn wrapping_pow(self, mut exp: u32) -> Self {
1624+
if exp == 0 {
1625+
return 1;
1626+
}
16251627
let mut base = self;
16261628
let mut acc: Self = 1;
16271629

@@ -1633,14 +1635,11 @@ $EndFeature, "
16331635
base = base.wrapping_mul(base);
16341636
}
16351637

1638+
// since exp!=0, finally the exp must be 1.
16361639
// Deal with the final bit of the exponent separately, since
16371640
// squaring the base afterwards is not necessary and may cause a
16381641
// needless overflow.
1639-
if exp == 1 {
1640-
acc = acc.wrapping_mul(base);
1641-
}
1642-
1643-
acc
1642+
acc.wrapping_mul(base)
16441643
}
16451644
}
16461645

@@ -1989,6 +1988,9 @@ $EndFeature, "
19891988
without modifying the original"]
19901989
#[inline]
19911990
pub const fn overflowing_pow(self, mut exp: u32) -> (Self, bool) {
1991+
if exp == 0 {
1992+
return (1,false);
1993+
}
19921994
let mut base = self;
19931995
let mut acc: Self = 1;
19941996
let mut overflown = false;
@@ -2007,16 +2009,13 @@ $EndFeature, "
20072009
overflown |= r.1;
20082010
}
20092011

2012+
// since exp!=0, finally the exp must be 1.
20102013
// Deal with the final bit of the exponent separately, since
20112014
// squaring the base afterwards is not necessary and may cause a
20122015
// needless overflow.
2013-
if exp == 1 {
2014-
r = acc.overflowing_mul(base);
2015-
acc = r.0;
2016-
overflown |= r.1;
2017-
}
2018-
2019-
(acc, overflown)
2016+
r = acc.overflowing_mul(base);
2017+
r.1 |= overflown;
2018+
r
20202019
}
20212020
}
20222021

@@ -2040,6 +2039,9 @@ $EndFeature, "
20402039
#[inline]
20412040
#[rustc_inherit_overflow_checks]
20422041
pub const fn pow(self, mut exp: u32) -> Self {
2042+
if exp == 0 {
2043+
return 1;
2044+
}
20432045
let mut base = self;
20442046
let mut acc = 1;
20452047

@@ -2051,14 +2053,11 @@ $EndFeature, "
20512053
base = base * base;
20522054
}
20532055

2056+
// since exp!=0, finally the exp must be 1.
20542057
// Deal with the final bit of the exponent separately, since
20552058
// squaring the base afterwards is not necessary and may cause a
20562059
// needless overflow.
2057-
if exp == 1 {
2058-
acc = acc * base;
2059-
}
2060-
2061-
acc
2060+
acc * base
20622061
}
20632062
}
20642063

@@ -3295,6 +3294,9 @@ assert_eq!(", stringify!($SelfT), "::MAX.checked_pow(2), None);", $EndFeature, "
32953294
without modifying the original"]
32963295
#[inline]
32973296
pub const fn checked_pow(self, mut exp: u32) -> Option<Self> {
3297+
if exp == 0 {
3298+
return Some(1);
3299+
}
32983300
let mut base = self;
32993301
let mut acc: Self = 1;
33003302

@@ -3306,14 +3308,12 @@ assert_eq!(", stringify!($SelfT), "::MAX.checked_pow(2), None);", $EndFeature, "
33063308
base = try_opt!(base.checked_mul(base));
33073309
}
33083310

3311+
// since exp!=0, finally the exp must be 1.
33093312
// Deal with the final bit of the exponent separately, since
33103313
// squaring the base afterwards is not necessary and may cause a
33113314
// needless overflow.
3312-
if exp == 1 {
3313-
acc = try_opt!(acc.checked_mul(base));
3314-
}
33153315

3316-
Some(acc)
3316+
Some(try_opt!(acc.checked_mul(base)))
33173317
}
33183318
}
33193319

@@ -3704,6 +3704,9 @@ assert_eq!(3u8.wrapping_pow(6), 217);", $EndFeature, "
37043704
without modifying the original"]
37053705
#[inline]
37063706
pub const fn wrapping_pow(self, mut exp: u32) -> Self {
3707+
if exp == 0 {
3708+
return 1;
3709+
}
37073710
let mut base = self;
37083711
let mut acc: Self = 1;
37093712

@@ -3715,14 +3718,11 @@ assert_eq!(3u8.wrapping_pow(6), 217);", $EndFeature, "
37153718
base = base.wrapping_mul(base);
37163719
}
37173720

3721+
// since exp!=0, finally the exp must be 1.
37183722
// Deal with the final bit of the exponent separately, since
37193723
// squaring the base afterwards is not necessary and may cause a
37203724
// needless overflow.
3721-
if exp == 1 {
3722-
acc = acc.wrapping_mul(base);
3723-
}
3724-
3725-
acc
3725+
acc.wrapping_mul(base)
37263726
}
37273727
}
37283728

@@ -4029,6 +4029,9 @@ assert_eq!(3u8.overflowing_pow(6), (217, true));", $EndFeature, "
40294029
without modifying the original"]
40304030
#[inline]
40314031
pub const fn overflowing_pow(self, mut exp: u32) -> (Self, bool) {
4032+
if exp == 0{
4033+
return (1,false);
4034+
}
40324035
let mut base = self;
40334036
let mut acc: Self = 1;
40344037
let mut overflown = false;
@@ -4047,16 +4050,14 @@ assert_eq!(3u8.overflowing_pow(6), (217, true));", $EndFeature, "
40474050
overflown |= r.1;
40484051
}
40494052

4053+
// since exp!=0, finally the exp must be 1.
40504054
// Deal with the final bit of the exponent separately, since
40514055
// squaring the base afterwards is not necessary and may cause a
40524056
// needless overflow.
4053-
if exp == 1 {
4054-
r = acc.overflowing_mul(base);
4055-
acc = r.0;
4056-
overflown |= r.1;
4057-
}
4057+
r = acc.overflowing_mul(base);
4058+
r.1 |= overflown;
40584059

4059-
(acc, overflown)
4060+
r
40604061
}
40614062
}
40624063

@@ -4077,6 +4078,9 @@ Basic usage:
40774078
#[inline]
40784079
#[rustc_inherit_overflow_checks]
40794080
pub const fn pow(self, mut exp: u32) -> Self {
4081+
if exp == 0 {
4082+
return 1;
4083+
}
40804084
let mut base = self;
40814085
let mut acc = 1;
40824086

@@ -4088,14 +4092,11 @@ Basic usage:
40884092
base = base * base;
40894093
}
40904094

4095+
// since exp!=0, finally the exp must be 1.
40914096
// Deal with the final bit of the exponent separately, since
40924097
// squaring the base afterwards is not necessary and may cause a
40934098
// needless overflow.
4094-
if exp == 1 {
4095-
acc = acc * base;
4096-
}
4097-
4098-
acc
4099+
acc * base
40994100
}
41004101
}
41014102

src/libcore/tests/num/int_macros.rs

+32-1
Original file line numberDiff line numberDiff line change
@@ -255,12 +255,43 @@ macro_rules! int_module {
255255
#[test]
256256
fn test_pow() {
257257
let mut r = 2 as $T;
258-
259258
assert_eq!(r.pow(2), 4 as $T);
260259
assert_eq!(r.pow(0), 1 as $T);
260+
assert_eq!(r.wrapping_pow(2), 4 as $T);
261+
assert_eq!(r.wrapping_pow(0), 1 as $T);
262+
assert_eq!(r.checked_pow(2), Some(4 as $T));
263+
assert_eq!(r.checked_pow(0), Some(1 as $T));
264+
assert_eq!(r.overflowing_pow(2), (4 as $T, false));
265+
assert_eq!(r.overflowing_pow(0), (1 as $T, false));
266+
assert_eq!(r.saturating_pow(2), 4 as $T);
267+
assert_eq!(r.saturating_pow(0), 1 as $T);
268+
269+
r = MAX;
270+
// use `^` to represent .pow() with no overflow.
271+
// if itest::MAX == 2^j-1, then itest is a `j` bit int,
272+
// so that `itest::MAX*itest::MAX == 2^(2*j)-2^(j+1)+1`,
273+
// thussaturating_pow the overflowing result is exactly 1.
274+
assert_eq!(r.wrapping_pow(2), 1 as $T);
275+
assert_eq!(r.checked_pow(2), None);
276+
assert_eq!(r.overflowing_pow(2), (1 as $T, true));
277+
assert_eq!(r.saturating_pow(2), MAX);
278+
//test for negative exponent.
261279
r = -2 as $T;
262280
assert_eq!(r.pow(2), 4 as $T);
263281
assert_eq!(r.pow(3), -8 as $T);
282+
assert_eq!(r.pow(0), 1 as $T);
283+
assert_eq!(r.wrapping_pow(2), 4 as $T);
284+
assert_eq!(r.wrapping_pow(3), -8 as $T);
285+
assert_eq!(r.wrapping_pow(0), 1 as $T);
286+
assert_eq!(r.checked_pow(2), Some(4 as $T));
287+
assert_eq!(r.checked_pow(3), Some(-8 as $T));
288+
assert_eq!(r.checked_pow(0), Some(1 as $T));
289+
assert_eq!(r.overflowing_pow(2), (4 as $T, false));
290+
assert_eq!(r.overflowing_pow(3), (-8 as $T, false));
291+
assert_eq!(r.overflowing_pow(0), (1 as $T, false));
292+
assert_eq!(r.saturating_pow(2), 4 as $T);
293+
assert_eq!(r.saturating_pow(3), -8 as $T);
294+
assert_eq!(r.saturating_pow(0), 1 as $T);
264295
}
265296
}
266297
};

0 commit comments

Comments
 (0)