Merge pull request #2582 from embassy-rs/update-metapac-44
stm32: update metapac.
This commit is contained in:
commit
26fc17e8a7
3 changed files with 27 additions and 55 deletions
|
@ -68,7 +68,7 @@ rand_core = "0.6.3"
|
||||||
sdio-host = "0.5.0"
|
sdio-host = "0.5.0"
|
||||||
critical-section = "1.1"
|
critical-section = "1.1"
|
||||||
#stm32-metapac = { version = "15" }
|
#stm32-metapac = { version = "15" }
|
||||||
stm32-metapac = { git = "https://github.com/embassy-rs/stm32-data-generated", tag = "stm32-data-3cc1a1603e61881a6f0a1a47c12c16c57c245ba8" }
|
stm32-metapac = { git = "https://github.com/embassy-rs/stm32-data-generated", tag = "stm32-data-6097928f720646c73d6483a3245f922bd5faee2f" }
|
||||||
vcell = "0.1.3"
|
vcell = "0.1.3"
|
||||||
bxcan = "0.7.0"
|
bxcan = "0.7.0"
|
||||||
nb = "1.0.0"
|
nb = "1.0.0"
|
||||||
|
@ -89,7 +89,7 @@ critical-section = { version = "1.1", features = ["std"] }
|
||||||
proc-macro2 = "1.0.36"
|
proc-macro2 = "1.0.36"
|
||||||
quote = "1.0.15"
|
quote = "1.0.15"
|
||||||
#stm32-metapac = { version = "15", default-features = false, features = ["metadata"]}
|
#stm32-metapac = { version = "15", default-features = false, features = ["metadata"]}
|
||||||
stm32-metapac = { git = "https://github.com/embassy-rs/stm32-data-generated", tag = "stm32-data-3cc1a1603e61881a6f0a1a47c12c16c57c245ba8", default-features = false, features = ["metadata"]}
|
stm32-metapac = { git = "https://github.com/embassy-rs/stm32-data-generated", tag = "stm32-data-6097928f720646c73d6483a3245f922bd5faee2f", default-features = false, features = ["metadata"]}
|
||||||
|
|
||||||
|
|
||||||
[features]
|
[features]
|
||||||
|
|
|
@ -5,8 +5,7 @@ use std::{env, fs};
|
||||||
|
|
||||||
use proc_macro2::{Ident, TokenStream};
|
use proc_macro2::{Ident, TokenStream};
|
||||||
use quote::{format_ident, quote};
|
use quote::{format_ident, quote};
|
||||||
use stm32_metapac::metadata::ir::{BlockItemInner, Enum, FieldSet};
|
use stm32_metapac::metadata::{MemoryRegionKind, PeripheralRccKernelClock, StopMode, METADATA};
|
||||||
use stm32_metapac::metadata::{MemoryRegionKind, PeripheralRccRegister, StopMode, METADATA};
|
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
let target = env::var("TARGET").unwrap();
|
let target = env::var("TARGET").unwrap();
|
||||||
|
@ -414,38 +413,6 @@ fn main() {
|
||||||
.find(|r| r.kind == "rcc")
|
.find(|r| r.kind == "rcc")
|
||||||
.unwrap();
|
.unwrap();
|
||||||
|
|
||||||
// ========
|
|
||||||
// Generate rcc fieldset and enum maps
|
|
||||||
let rcc_enum_map: HashMap<&str, HashMap<&str, &Enum>> = {
|
|
||||||
let rcc_blocks = rcc_registers.ir.blocks.iter().find(|b| b.name == "Rcc").unwrap().items;
|
|
||||||
let rcc_fieldsets: HashMap<&str, &FieldSet> = rcc_registers.ir.fieldsets.iter().map(|f| (f.name, f)).collect();
|
|
||||||
let rcc_enums: HashMap<&str, &Enum> = rcc_registers.ir.enums.iter().map(|e| (e.name, e)).collect();
|
|
||||||
|
|
||||||
rcc_blocks
|
|
||||||
.iter()
|
|
||||||
.filter_map(|b| match &b.inner {
|
|
||||||
BlockItemInner::Register(register) => register.fieldset.map(|f| (b.name, f)),
|
|
||||||
_ => None,
|
|
||||||
})
|
|
||||||
.filter_map(|(b, f)| {
|
|
||||||
rcc_fieldsets.get(f).map(|f| {
|
|
||||||
(
|
|
||||||
b,
|
|
||||||
f.fields
|
|
||||||
.iter()
|
|
||||||
.filter_map(|f| {
|
|
||||||
let enumm = f.enumm?;
|
|
||||||
let enumm = rcc_enums.get(enumm)?;
|
|
||||||
|
|
||||||
Some((f.name, *enumm))
|
|
||||||
})
|
|
||||||
.collect(),
|
|
||||||
)
|
|
||||||
})
|
|
||||||
})
|
|
||||||
.collect()
|
|
||||||
};
|
|
||||||
|
|
||||||
// ========
|
// ========
|
||||||
// Generate RccPeripheral impls
|
// Generate RccPeripheral impls
|
||||||
|
|
||||||
|
@ -494,8 +461,8 @@ fn main() {
|
||||||
|
|
||||||
let ptype = if let Some(reg) = &p.registers { reg.kind } else { "" };
|
let ptype = if let Some(reg) = &p.registers { reg.kind } else { "" };
|
||||||
let pname = format_ident!("{}", p.name);
|
let pname = format_ident!("{}", p.name);
|
||||||
let en_reg = format_ident!("{}", en.register);
|
let en_reg = format_ident!("{}", en.register.to_ascii_lowercase());
|
||||||
let set_en_field = format_ident!("set_{}", en.field);
|
let set_en_field = format_ident!("set_{}", en.field.to_ascii_lowercase());
|
||||||
|
|
||||||
let refcount =
|
let refcount =
|
||||||
force_refcount.contains(ptype) || *rcc_field_count.get(&(en.register, en.field)).unwrap() > 1;
|
force_refcount.contains(ptype) || *rcc_field_count.get(&(en.register, en.field)).unwrap() > 1;
|
||||||
|
@ -523,21 +490,25 @@ fn main() {
|
||||||
(TokenStream::new(), TokenStream::new())
|
(TokenStream::new(), TokenStream::new())
|
||||||
};
|
};
|
||||||
|
|
||||||
let mux_for = |mux: Option<&'static PeripheralRccRegister>| {
|
let clock_frequency = match &rcc.kernel_clock {
|
||||||
let mux = mux?;
|
PeripheralRccKernelClock::Mux(mux) => {
|
||||||
let fieldset = rcc_enum_map.get(mux.register)?;
|
let ir = &rcc_registers.ir;
|
||||||
let enumm = fieldset.get(mux.field)?;
|
let fieldset_name = mux.register.to_ascii_lowercase();
|
||||||
|
let fieldset = ir
|
||||||
|
.fieldsets
|
||||||
|
.iter()
|
||||||
|
.find(|i| i.name.eq_ignore_ascii_case(&fieldset_name))
|
||||||
|
.unwrap();
|
||||||
|
let field_name = mux.field.to_ascii_lowercase();
|
||||||
|
let field = fieldset.fields.iter().find(|i| i.name == field_name).unwrap();
|
||||||
|
let enum_name = field.enumm.unwrap();
|
||||||
|
let enumm = ir.enums.iter().find(|i| i.name == enum_name).unwrap();
|
||||||
|
|
||||||
Some((mux, *enumm))
|
let fieldset_name = format_ident!("{}", fieldset_name);
|
||||||
};
|
let field_name = format_ident!("{}", field_name);
|
||||||
|
let enum_name = format_ident!("{}", enum_name);
|
||||||
|
|
||||||
let clock_frequency = match mux_for(rcc.mux.as_ref()) {
|
let match_arms: TokenStream = enumm
|
||||||
Some((mux, rcc_enumm)) => {
|
|
||||||
let fieldset_name = format_ident!("{}", mux.register);
|
|
||||||
let field_name = format_ident!("{}", mux.field);
|
|
||||||
let enum_name = format_ident!("{}", rcc_enumm.name);
|
|
||||||
|
|
||||||
let match_arms: TokenStream = rcc_enumm
|
|
||||||
.variants
|
.variants
|
||||||
.iter()
|
.iter()
|
||||||
.filter(|v| v.name != "DISABLE")
|
.filter(|v| v.name != "DISABLE")
|
||||||
|
@ -561,9 +532,10 @@ fn main() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
None => {
|
PeripheralRccKernelClock::Clock(clock) => {
|
||||||
let clock_name = format_ident!("{}", rcc.clock);
|
let clock = clock.to_ascii_lowercase();
|
||||||
clock_names.insert(rcc.clock.to_string());
|
let clock_name = format_ident!("{}", clock);
|
||||||
|
clock_names.insert(clock.to_string());
|
||||||
quote! {
|
quote! {
|
||||||
unsafe { crate::rcc::get_freqs().#clock_name.unwrap() }
|
unsafe { crate::rcc::get_freqs().#clock_name.unwrap() }
|
||||||
}
|
}
|
||||||
|
|
|
@ -49,7 +49,7 @@ impl Default for Config {
|
||||||
apb2_pre: APBPrescaler::DIV1,
|
apb2_pre: APBPrescaler::DIV1,
|
||||||
apb7_pre: APBPrescaler::DIV1,
|
apb7_pre: APBPrescaler::DIV1,
|
||||||
ls: Default::default(),
|
ls: Default::default(),
|
||||||
adc_clock_source: AdcClockSource::HCLK1,
|
adc_clock_source: AdcClockSource::HCLK4,
|
||||||
voltage_scale: VoltageScale::RANGE2,
|
voltage_scale: VoltageScale::RANGE2,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue