Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Rollup of 6 pull requests #41242

Closed
wants to merge 29 commits into from
Closed

Rollup of 6 pull requests #41242

wants to merge 29 commits into from

Conversation

pirate and others added 29 commits March 23, 2017 13:29
Travis failures indicated the OuterVisitor#visit_item method caused a
panic. The Visitor's inner visitor actually relies on the visitor
visiting every item's NodeId. I forgot to perform that call in the
ItemGlobalAsm match arm, leading to build breakage. The fix is
simple: call visit_id(...) for ItemGlobalAsm
Windows builder croaked. This change tries to fix that by actually
calling the global_asm-defined function so the symbol doesn't get
optimized away. I don't know if that's what's happening though...
* Use the right version when building combined installer
* Update dependencies of rls as it depends on rustc and plugins
* Fix build-manifest and the versions it uses for the rls
Add the RLS as a submodule and build a package out of it

r? @brson (and cc @alexcrichton) Please review closely, I am not at all convinced I've done the right things here. I did run `x.py dist` and it makes an rls package which looks right to my eyes, but I haven't tested on non-linux platforms nor am I really sure what it should look like.

This does not attempt to run tests for the RLS yet.
Implement global_asm!() (RFC 1548)

This is a first attempt. ~~One (potential) problem I haven't solved is how to handle multiple usages of `global_asm!` in a module/crate. It looks like `LLVMSetModuleInlineAsm` overwrites module asm, and `LLVMAppendModuleInlineAsm` is not provided in LLVM C headers 😦~~

I can provide more detail as needed, but honestly, there's not a lot going on here.

r? @eddyb

CC @Amanieu @jackpot51

Tracking issue: rust-lang#35119
Add contribution instructions to stdlib docs

Generally programming language docs have instructions on how to contribute changes.

I couldn't find any in the rust docs, so I figured I'd add an instructions section, let me know if this belongs somewhere else!
Derive Hash for ThreadId + better example

Derive `Hash` for `ThreadId` (see comments in rust-lang#21507). Useful for making maps based on thread, e.g. `HashMap<ThreadId, ?>`. Also update example code for thread IDs to be more useful.
Fix pairs of doubles using an illegal <8 x i8> vector.

Accidentally introduced in rust-lang#40658 and discovered in some Objective-C bindings (returning `NSPoint`).
Turns out LLVM will widen element types of illegal vectors instead of increasing element count, i.e. it will zero-extend `<8 x i8>` to `<8 x i16>`, interleaving the bytes, instead of using the first 8 of `<16 x i8>`.
@rust-highfive
Copy link
Collaborator

Thanks for the pull request, and welcome! The Rust team is excited to review your changes, and you should hear from @pnkfelix (or someone else) soon.

If any changes to this PR are deemed necessary, please add them as extra commits. This ensures that the reviewer can see what has changed since they last reviewed the code. Due to the way GitHub handles out-of-date commits, this should also make it reasonably obvious what issues have or haven't been addressed. Large or tricky changes may require several passes of review and changes.

Please see the contribution instructions for more information.

@frewsxcv
Copy link
Member Author

@bors r+ p=10

@bors
Copy link
Contributor

bors commented Apr 12, 2017

📌 Commit 8b4fdcb has been approved by frewsxcv

@bors
Copy link
Contributor

bors commented Apr 12, 2017

⌛ Testing commit 8b4fdcb with merge f15a6be...

@bors
Copy link
Contributor

bors commented Apr 12, 2017

💔 Test failed - status-travis

@TimNN
Copy link
Contributor

TimNN commented Apr 12, 2017

Looks like #40702:

[01:07:42] failures:
[01:07:42] 
[01:07:42] ---- [run-pass] run-pass/simple_global_asm.rs stdout ----
[01:07:42] 	
[01:07:42] error: compilation failed!
[01:07:42] status: exit code: 101
[01:07:42] command: /checkout/obj/build/x86_64-unknown-linux-gnu/stage2/bin/rustc /checkout/src/test/run-pass/simple_global_asm.rs -L /checkout/obj/build/x86_64-unknown-linux-gnu/test/run-pass --target=arm-unknown-linux-gnueabihf --error-format json -L /checkout/obj/build/x86_64-unknown-linux-gnu/test/run-pass/simple_global_asm.stage2-arm-unknown-linux-gnueabihf.run-pass.libaux -C prefer-dynamic -o /checkout/obj/build/x86_64-unknown-linux-gnu/test/run-pass/simple_global_asm.stage2-arm-unknown-linux-gnueabihf -Clinker=arm-linux-gnueabihf-gcc -Crpath -O -Lnative=/checkout/obj/build/arm-unknown-linux-gnueabihf/native/rust-test-helpers
[01:07:42] thread 'main' panicked at 'Some tests failed', /checkout/src/tools/compiletest/src/main.rs:329
[01:07:42] stdout:
[01:07:42] ------------------------------------------
[01:07:42] 
[01:07:42] ------------------------------------------
[01:07:42] stderr:
[01:07:42] ------------------------------------------
[01:07:42] {"message":"linking with `arm-linux-gnueabihf-gcc` failed: exit code: 1","code":null,"level":"error","spans":[],"children":[{"message":"\"arm-linux-gnueabihf-gcc\" \"-Wl,--as-needed\" \"-Wl,-z,noexecstack\" \"-L\" \"/checkout/obj/build/x86_64-unknown-linux-gnu/stage2/lib/rustlib/arm-unknown-linux-gnueabihf/lib\" \"/checkout/obj/build/x86_64-unknown-linux-gnu/test/run-pass/simple_global_asm.0.o\" \"-o\" \"/checkout/obj/build/x86_64-unknown-linux-gnu/test/run-pass/simple_global_asm.stage2-arm-unknown-linux-gnueabihf\" \"-Wl,--gc-sections\" \"-pie\" \"-Wl,-O1\" \"-nodefaultlibs\" \"-L\" \"/checkout/obj/build/x86_64-unknown-linux-gnu/test/run-pass\" \"-L\" \"/checkout/obj/build/x86_64-unknown-linux-gnu/test/run-pass/simple_global_asm.stage2-arm-unknown-linux-gnueabihf.run-pass.libaux\" \"-L\" \"/checkout/obj/build/arm-unknown-linux-gnueabihf/native/rust-test-helpers\" \"-L\" \"/checkout/obj/build/x86_64-unknown-linux-gnu/stage2/lib/rustlib/arm-unknown-linux-gnueabihf/lib\" \"-L\" \"/checkout/obj/build/x86_64-unknown-linux-gnu/stage2/lib/rustlib/arm-unknown-linux-gnueabihf/lib\" \"-l\" \"std-f4594d3e53dcb114\" \"-Wl,-Bstatic\" \"/checkout/obj/build/x86_64-unknown-linux-gnu/stage2/lib/rustlib/arm-unknown-linux-gnueabihf/lib/libcompiler_builtins-987729be881d4d32.rlib\" \"-Wl,-Bdynamic\" \"-l\" \"dl\" \"-l\" \"rt\" \"-l\" \"pthread\" \"-l\" \"gcc_s\" \"-l\" \"pthread\" \"-l\" \"c\" \"-l\" \"m\" \"-l\" \"rt\" \"-l\" \"util\" \"-Wl,-rpath,$ORIGIN/../../stage2/lib/rustlib/arm-unknown-linux-gnueabihf/lib\" \"-Wl,-rpath,/usr/local/lib/rustlib/arm-unknown-linux-gnueabihf/lib\" \"-Wl,--enable-new-dtags\"","code":null,"level":"note","spans":[],"children":[],"rendered":null},{"message":"/checkout/obj/build/x86_64-unknown-linux-gnu/test/run-pass/simple_global_asm.0.o: In function `simple_global_asm::main::h8f5a5f4abd38360a':\nsimple_global_asm.cgu-0.rs:(.text._ZN17simple_global_asm4main17h8f5a5f4abd38360aE+0x0): undefined reference to `foo'\ncollect2: error: ld returned 1 exit status\n","code":null,"level":"note","spans":[],"children":[],"rendered":null}],"rendered":null}
[01:07:42] {"message":"aborting due to previous error","code":null,"level":"error","spans":[],"children":[],"rendered":null}
[01:07:42] 
[01:07:42] ------------------------------------------
[01:07:42] 
[01:07:42] thread '[run-pass] run-pass/simple_global_asm.rs' panicked at 'explicit panic', /checkout/src/tools/compiletest/src/runtest.rs:2621
[01:07:42] note: Run with `RUST_BACKTRACE=1` for a backtrace.
[01:07:42] 
[01:07:42] 
[01:07:42] failures:
[01:07:42]     [run-pass] run-pass/simple_global_asm.rs
[01:07:42] 
[01:07:42] test result: FAILED. 2647 passed; 1 failed; 8 ignored; 0 measured

@frewsxcv frewsxcv closed this Apr 12, 2017
@frewsxcv frewsxcv deleted the rollup branch April 12, 2017 14:54
@Centril Centril added the rollup A PR which is a rollup label Oct 24, 2019
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
rollup A PR which is a rollup
Projects
None yet
Development

Successfully merging this pull request may close these issues.