Add a wasmtime settings command to print Cranelift settings.
This commit adds the `wasmtime settings` command to print out available Cranelift settings for a target (defaults to the host). The compile command has been updated to remove the Cranelift ISA options in favor of encouraging users to use `wasmtime settings` to discover what settings are available. This will reduce the maintenance cost for syncing the compile command with Cranelift ISA flags.
This commit is contained in:
@@ -44,6 +44,34 @@ pub trait Configurable {
|
||||
fn enable(&mut self, name: &str) -> SetResult<()>;
|
||||
}
|
||||
|
||||
/// Represents the kind of setting.
|
||||
#[derive(Clone, Copy, Debug, Eq, PartialEq)]
|
||||
pub enum SettingKind {
|
||||
/// The setting is an enumeration.
|
||||
Enum,
|
||||
/// The setting is a number.
|
||||
Num,
|
||||
/// The setting is a boolean.
|
||||
Bool,
|
||||
/// The setting is a preset.
|
||||
Preset,
|
||||
}
|
||||
|
||||
/// Represents an available builder setting.
|
||||
///
|
||||
/// This is used for iterating settings in a builder.
|
||||
#[derive(Clone, Copy, Debug)]
|
||||
pub struct Setting {
|
||||
/// The name of the setting.
|
||||
pub name: &'static str,
|
||||
/// The description of the setting.
|
||||
pub description: &'static str,
|
||||
/// The kind of the setting.
|
||||
pub kind: SettingKind,
|
||||
/// The supported values of the setting (for enum values).
|
||||
pub values: Option<&'static [&'static str]>,
|
||||
}
|
||||
|
||||
/// Collect settings values based on a template.
|
||||
#[derive(Clone, Hash)]
|
||||
pub struct Builder {
|
||||
@@ -66,6 +94,30 @@ impl Builder {
|
||||
self.bytes
|
||||
}
|
||||
|
||||
/// Iterates the available settings in the builder.
|
||||
pub fn iter(&self) -> impl Iterator<Item = Setting> {
|
||||
let template = self.template;
|
||||
|
||||
template.descriptors.iter().map(move |d| {
|
||||
let (kind, values) = match d.detail {
|
||||
detail::Detail::Enum { last, enumerators } => {
|
||||
let values = template.enums(last, enumerators);
|
||||
(SettingKind::Enum, Some(values))
|
||||
}
|
||||
detail::Detail::Num => (SettingKind::Num, None),
|
||||
detail::Detail::Bool { .. } => (SettingKind::Bool, None),
|
||||
detail::Detail::Preset => (SettingKind::Preset, None),
|
||||
};
|
||||
|
||||
Setting {
|
||||
name: d.name,
|
||||
description: d.description,
|
||||
kind,
|
||||
values,
|
||||
}
|
||||
})
|
||||
}
|
||||
|
||||
/// Set the value of a single bit.
|
||||
fn set_bit(&mut self, offset: usize, bit: u8, value: bool) {
|
||||
let byte = &mut self.bytes[offset];
|
||||
@@ -288,6 +340,9 @@ pub mod detail {
|
||||
/// Lower snake-case name of setting as defined in meta.
|
||||
pub name: &'static str,
|
||||
|
||||
/// The description of the setting.
|
||||
pub description: &'static str,
|
||||
|
||||
/// Offset of byte containing this setting.
|
||||
pub offset: u32,
|
||||
|
||||
|
||||
Reference in New Issue
Block a user