Skip to content

Commit 977d3f6

Browse files
committed
use llvm_readobj in run-make test instead of nm
1 parent c1597f9 commit 977d3f6

File tree

3 files changed

+28
-63
lines changed

3 files changed

+28
-63
lines changed

Diff for: src/tools/run-make-support/src/llvm.rs

+23-5
Original file line numberDiff line numberDiff line change
@@ -2,8 +2,8 @@ use std::path::{Path, PathBuf};
22

33
use crate::{env_var, Command};
44

5-
/// Construct a new `llvm-readobj` invocation. This assumes that `llvm-readobj` is available
6-
/// at `$LLVM_BIN_DIR/llvm-readobj`.
5+
/// Construct a new `llvm-readobj` invocation with the `GNU` output style.
6+
/// This assumes that `llvm-readobj` is available at `$LLVM_BIN_DIR/llvm-readobj`.
77
#[track_caller]
88
pub fn llvm_readobj() -> LlvmReadobj {
99
LlvmReadobj::new()
@@ -70,13 +70,24 @@ pub fn llvm_bin_dir() -> PathBuf {
7070
}
7171

7272
impl LlvmReadobj {
73-
/// Construct a new `llvm-readobj` invocation. This assumes that `llvm-readobj` is available
74-
/// at `$LLVM_BIN_DIR/llvm-readobj`.
73+
/// Construct a new `llvm-readobj` invocation with the `GNU` output style.
74+
/// This assumes that `llvm-readobj` is available at `$LLVM_BIN_DIR/llvm-readobj`.
7575
#[track_caller]
7676
pub fn new() -> Self {
7777
let llvm_readobj = llvm_bin_dir().join("llvm-readobj");
7878
let cmd = Command::new(llvm_readobj);
79-
Self { cmd }
79+
let mut readobj = Self { cmd };
80+
readobj.elf_output_style("GNU");
81+
readobj
82+
}
83+
84+
/// Specify the format of the ELF information.
85+
///
86+
/// Valid options are `LLVM` (default), `GNU`, and `JSON`.
87+
pub fn elf_output_style(&mut self, style: &str) -> &mut Self {
88+
self.cmd.arg("--elf-output-style");
89+
self.cmd.arg(style);
90+
self
8091
}
8192

8293
/// Provide an input file.
@@ -90,6 +101,13 @@ impl LlvmReadobj {
90101
self.cmd.arg("--file-header");
91102
self
92103
}
104+
105+
/// Specify the section to display.
106+
pub fn section(&mut self, section: &str) -> &mut Self {
107+
self.cmd.arg("--string-dump");
108+
self.cmd.arg(section);
109+
self
110+
}
93111
}
94112

95113
impl LlvmProfdata {

Diff for: src/tools/run-make-support/src/nm/mod.rs

-50
This file was deleted.

Diff for: tests/run-make/bin-emit-no-symbols/rmake.rs

+5-8
Original file line numberDiff line numberDiff line change
@@ -5,15 +5,12 @@
55
// emitted inside the object files.
66
// See https://github.com/rust-lang/rust/issues/51671
77

8-
use run_make_support::{nm, rustc, tmp_dir};
8+
use run_make_support::{llvm_readobj, rustc};
99

1010
fn main() {
1111
rustc().emit("obj").input("app.rs").run();
12-
//FIXME(Oneirical): This should eventually be rmake_out_path
13-
let nm = nm(tmp_dir().join("app.o"));
14-
assert!(
15-
nm.contains("rust_begin_unwind")
16-
&& nm.contains("rust_eh_personality")
17-
&& nm.contains("__rg_oom")
18-
);
12+
let out = llvm_readobj().input("app.o").arg("--symbols").run();
13+
out.assert_stdout_contains("rust_begin_unwind");
14+
out.assert_stdout_contains("rust_eh_personality");
15+
out.assert_stdout_contains("__rg_oom");
1916
}

0 commit comments

Comments
 (0)