Skip to content

Commit caa89ed

Browse files
compiler(nfc): -Cforce-frame-pointers is a FramePointer
1 parent b9eb6fd commit caa89ed

File tree

4 files changed

+26
-14
lines changed

4 files changed

+26
-14
lines changed

compiler/rustc_codegen_llvm/src/attributes.rs

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -108,9 +108,10 @@ pub fn frame_pointer_type_attr<'ll>(cx: &CodegenCx<'ll, '_>) -> Option<&'ll Attr
108108
let opts = &cx.sess().opts;
109109
// "mcount" function relies on stack pointer.
110110
// See <https://sourceware.org/binutils/docs/gprof/Implementation.html>.
111-
if opts.unstable_opts.instrument_mcount || matches!(opts.cg.force_frame_pointers, Some(true)) {
112-
fp = FramePointer::Always;
111+
if opts.unstable_opts.instrument_mcount {
112+
fp.ratchet(FramePointer::Always);
113113
}
114+
fp.ratchet(opts.cg.force_frame_pointers);
114115
let attr_value = match fp {
115116
FramePointer::Always => "all",
116117
FramePointer::NonLeaf => "non-leaf",

compiler/rustc_interface/src/tests.rs

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -20,9 +20,9 @@ use rustc_span::source_map::{RealFileLoader, SourceMapInputs};
2020
use rustc_span::symbol::sym;
2121
use rustc_span::{FileName, SourceFileHashAlgorithm};
2222
use rustc_target::spec::{
23-
CodeModel, LinkerFlavorCli, MergeFunctions, OnBrokenPipe, PanicStrategy, RelocModel, WasmCAbi,
23+
CodeModel, FramePointer, LinkerFlavorCli, MergeFunctions, OnBrokenPipe, PanicStrategy,
24+
RelocModel, RelroLevel, SanitizerSet, SplitDebuginfo, StackProtector, TlsModel, WasmCAbi,
2425
};
25-
use rustc_target::spec::{RelroLevel, SanitizerSet, SplitDebuginfo, StackProtector, TlsModel};
2626
use std::collections::{BTreeMap, BTreeSet};
2727
use std::num::NonZero;
2828
use std::path::{Path, PathBuf};
@@ -605,7 +605,7 @@ fn test_codegen_options_tracking_hash() {
605605
tracked!(debug_assertions, Some(true));
606606
tracked!(debuginfo, DebugInfo::Limited);
607607
tracked!(embed_bitcode, false);
608-
tracked!(force_frame_pointers, Some(false));
608+
tracked!(force_frame_pointers, FramePointer::Always);
609609
tracked!(force_unwind_tables, Some(true));
610610
tracked!(inline_threshold, Some(0xf007ba11));
611611
tracked!(instrument_coverage, InstrumentCoverage::Yes);

compiler/rustc_session/src/config.rs

Lines changed: 3 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -2910,10 +2910,8 @@ pub(crate) mod dep_tracking {
29102910
use rustc_span::edition::Edition;
29112911
use rustc_span::RealFileName;
29122912
use rustc_target::spec::{
2913-
CodeModel, MergeFunctions, OnBrokenPipe, PanicStrategy, RelocModel, WasmCAbi,
2914-
};
2915-
use rustc_target::spec::{
2916-
RelroLevel, SanitizerSet, SplitDebuginfo, StackProtector, TargetTriple, TlsModel,
2913+
CodeModel, FramePointer, MergeFunctions, OnBrokenPipe, PanicStrategy, RelocModel,
2914+
RelroLevel, SanitizerSet, SplitDebuginfo, StackProtector, TargetTriple, TlsModel, WasmCAbi,
29172915
};
29182916
use std::collections::BTreeMap;
29192917
use std::hash::{DefaultHasher, Hash};
@@ -2967,6 +2965,7 @@ pub(crate) mod dep_tracking {
29672965
lint::Level,
29682966
WasiExecModel,
29692967
u32,
2968+
FramePointer,
29702969
RelocModel,
29712970
CodeModel,
29722971
TlsModel,

compiler/rustc_session/src/options.rs

Lines changed: 17 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -12,10 +12,9 @@ use rustc_span::edition::Edition;
1212
use rustc_span::RealFileName;
1313
use rustc_span::SourceFileHashAlgorithm;
1414
use rustc_target::spec::{
15-
CodeModel, LinkerFlavorCli, MergeFunctions, OnBrokenPipe, PanicStrategy, SanitizerSet, WasmCAbi,
16-
};
17-
use rustc_target::spec::{
18-
RelocModel, RelroLevel, SplitDebuginfo, StackProtector, TargetTriple, TlsModel,
15+
CodeModel, FramePointer, LinkerFlavorCli, MergeFunctions, OnBrokenPipe, PanicStrategy,
16+
RelocModel, RelroLevel, SanitizerSet, SplitDebuginfo, StackProtector, TargetTriple, TlsModel,
17+
WasmCAbi,
1918
};
2019
use std::collections::BTreeMap;
2120
use std::hash::{DefaultHasher, Hasher};
@@ -374,6 +373,7 @@ mod desc {
374373
pub const parse_opt_comma_list: &str = parse_comma_list;
375374
pub const parse_number: &str = "a number";
376375
pub const parse_opt_number: &str = parse_number;
376+
pub const parse_frame_pointer: &str = parse_bool;
377377
pub const parse_threads: &str = parse_number;
378378
pub const parse_time_passes_format: &str = "`text` (default) or `json`";
379379
pub const parse_passes: &str = "a space-separated list of passes, or `all`";
@@ -670,6 +670,18 @@ mod parse {
670670
}
671671
}
672672

673+
pub(crate) fn parse_frame_pointer(slot: &mut FramePointer, v: Option<&str>) -> bool {
674+
let mut boolish = false;
675+
let mut is_parsed = parse_bool(&mut boolish, v);
676+
if boolish & is_parsed {
677+
*slot = FramePointer::Always;
678+
} else if false {
679+
/* TODO: add NonLeaf as an unstable opt */
680+
is_parsed = true;
681+
};
682+
is_parsed
683+
}
684+
673685
pub(crate) fn parse_passes(slot: &mut Passes, v: Option<&str>) -> bool {
674686
match v {
675687
Some("all") => {
@@ -1494,7 +1506,7 @@ options! {
14941506
"emit bitcode in rlibs (default: yes)"),
14951507
extra_filename: String = (String::new(), parse_string, [UNTRACKED],
14961508
"extra data to put in each output filename"),
1497-
force_frame_pointers: Option<bool> = (None, parse_opt_bool, [TRACKED],
1509+
force_frame_pointers: FramePointer = (FramePointer::MayOmit, parse_frame_pointer, [TRACKED],
14981510
"force use of the frame pointers"),
14991511
#[rustc_lint_opt_deny_field_access("use `Session::must_emit_unwind_tables` instead of this field")]
15001512
force_unwind_tables: Option<bool> = (None, parse_opt_bool, [TRACKED],

0 commit comments

Comments
 (0)