Merge pull request #332 from bobmcwhirter/memory_x_gen
Emit a default memory.x alongside device.x from metapac.
This commit is contained in:
commit
de207764ae
@ -42,6 +42,7 @@ defmt-warn = [ ]
|
|||||||
defmt-error = [ ]
|
defmt-error = [ ]
|
||||||
sdmmc-rs = ["embedded-sdmmc"]
|
sdmmc-rs = ["embedded-sdmmc"]
|
||||||
net = ["embassy-net", "vcell"]
|
net = ["embassy-net", "vcell"]
|
||||||
|
memory-x = ["stm32-metapac/memory-x"]
|
||||||
|
|
||||||
# Reexport stm32-metapac at `embassy_stm32::pac`.
|
# Reexport stm32-metapac at `embassy_stm32::pac`.
|
||||||
# This is unstable because semver-minor (non-breaking) releases of embassy-stm32 may major-bump (breaking) the stm32-metapac version.
|
# This is unstable because semver-minor (non-breaking) releases of embassy-stm32 may major-bump (breaking) the stm32-metapac version.
|
||||||
|
@ -39,6 +39,7 @@ pub mod eth;
|
|||||||
pub mod exti;
|
pub mod exti;
|
||||||
#[cfg(i2c)]
|
#[cfg(i2c)]
|
||||||
pub mod i2c;
|
pub mod i2c;
|
||||||
|
|
||||||
#[cfg(pwr)]
|
#[cfg(pwr)]
|
||||||
pub mod pwr;
|
pub mod pwr;
|
||||||
#[cfg(rng)]
|
#[cfg(rng)]
|
||||||
|
@ -19,7 +19,7 @@ defmt-error = []
|
|||||||
[dependencies]
|
[dependencies]
|
||||||
embassy = { version = "0.1.0", path = "../../embassy", features = ["defmt", "defmt-trace"] }
|
embassy = { version = "0.1.0", path = "../../embassy", features = ["defmt", "defmt-trace"] }
|
||||||
embassy-traits = { version = "0.1.0", path = "../../embassy-traits", features = ["defmt"] }
|
embassy-traits = { version = "0.1.0", path = "../../embassy-traits", features = ["defmt"] }
|
||||||
embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = ["defmt", "defmt-trace", "stm32f429zi", "unstable-pac"] }
|
embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = ["defmt", "defmt-trace", "stm32f429zi", "unstable-pac", "memory-x"] }
|
||||||
embassy-hal-common = {version = "0.1.0", path = "../../embassy-hal-common" }
|
embassy-hal-common = {version = "0.1.0", path = "../../embassy-hal-common" }
|
||||||
|
|
||||||
defmt = "0.2.0"
|
defmt = "0.2.0"
|
||||||
|
@ -1,31 +0,0 @@
|
|||||||
//! This build script copies the `memory.x` file from the crate root into
|
|
||||||
//! a directory where the linker can always find it at build time.
|
|
||||||
//! For many projects this is optional, as the linker always searches the
|
|
||||||
//! project root directory -- wherever `Cargo.toml` is. However, if you
|
|
||||||
//! are using a workspace or have a more complicated build setup, this
|
|
||||||
//! build script becomes required. Additionally, by requesting that
|
|
||||||
//! Cargo re-run the build script whenever `memory.x` is changed,
|
|
||||||
//! updating `memory.x` ensures a rebuild of the application with the
|
|
||||||
//! new memory settings.
|
|
||||||
|
|
||||||
use std::env;
|
|
||||||
use std::fs::File;
|
|
||||||
use std::io::Write;
|
|
||||||
use std::path::PathBuf;
|
|
||||||
|
|
||||||
fn main() {
|
|
||||||
// Put `memory.x` in our output directory and ensure it's
|
|
||||||
// on the linker search path.
|
|
||||||
let out = &PathBuf::from(env::var_os("OUT_DIR").unwrap());
|
|
||||||
File::create(out.join("memory.x"))
|
|
||||||
.unwrap()
|
|
||||||
.write_all(include_bytes!("memory.x"))
|
|
||||||
.unwrap();
|
|
||||||
println!("cargo:rustc-link-search={}", out.display());
|
|
||||||
|
|
||||||
// By default, Cargo will re-run a build script whenever
|
|
||||||
// any file in the project changes. By specifying `memory.x`
|
|
||||||
// here, we ensure the build script is only re-run when
|
|
||||||
// `memory.x` is changed.
|
|
||||||
println!("cargo:rerun-if-changed=memory.x");
|
|
||||||
}
|
|
@ -1,7 +0,0 @@
|
|||||||
MEMORY
|
|
||||||
{
|
|
||||||
/* NOTE 1 K = 1 KiBi = 1024 bytes */
|
|
||||||
/* These values correspond to the STM32F429ZI */
|
|
||||||
FLASH : ORIGIN = 0x08000000, LENGTH = 2048K
|
|
||||||
RAM : ORIGIN = 0x20000000, LENGTH = 192K
|
|
||||||
}
|
|
@ -19,7 +19,7 @@ defmt-error = []
|
|||||||
[dependencies]
|
[dependencies]
|
||||||
embassy = { version = "0.1.0", path = "../../embassy", features = ["defmt", "defmt-trace"] }
|
embassy = { version = "0.1.0", path = "../../embassy", features = ["defmt", "defmt-trace"] }
|
||||||
embassy-traits = { version = "0.1.0", path = "../../embassy-traits", features = ["defmt"] }
|
embassy-traits = { version = "0.1.0", path = "../../embassy-traits", features = ["defmt"] }
|
||||||
embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = ["defmt", "defmt-trace", "stm32h743zi", "net"] }
|
embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = ["defmt", "defmt-trace", "stm32h743zi", "net", "memory-x"] }
|
||||||
embassy-hal-common = {version = "0.1.0", path = "../../embassy-hal-common" }
|
embassy-hal-common = {version = "0.1.0", path = "../../embassy-hal-common" }
|
||||||
embassy-net = { path = "../../embassy-net", default-features = false, features = ["defmt-debug", "defmt", "tcp", "medium-ethernet", "pool-16"] }
|
embassy-net = { path = "../../embassy-net", default-features = false, features = ["defmt-debug", "defmt", "tcp", "medium-ethernet", "pool-16"] }
|
||||||
stm32-metapac = { path = "../../stm32-metapac", features = ["stm32h743zi"] }
|
stm32-metapac = { path = "../../stm32-metapac", features = ["stm32h743zi"] }
|
||||||
|
@ -1,21 +0,0 @@
|
|||||||
use std::env;
|
|
||||||
use std::fs::File;
|
|
||||||
use std::io::Write;
|
|
||||||
use std::path::PathBuf;
|
|
||||||
|
|
||||||
fn main() {
|
|
||||||
// Put `memory.x` in our output directory and ensure it's
|
|
||||||
// on the linker search path.
|
|
||||||
let out = &PathBuf::from(env::var_os("OUT_DIR").unwrap());
|
|
||||||
File::create(out.join("memory.x"))
|
|
||||||
.unwrap()
|
|
||||||
.write_all(include_bytes!("memory.x"))
|
|
||||||
.unwrap();
|
|
||||||
println!("cargo:rustc-link-search={}", out.display());
|
|
||||||
|
|
||||||
// By default, Cargo will re-run a build script whenever
|
|
||||||
// any file in the project changes. By specifying `memory.x`
|
|
||||||
// here, we ensure the build script is only re-run when
|
|
||||||
// `memory.x` is changed.
|
|
||||||
println!("cargo:rerun-if-changed=memory.x");
|
|
||||||
}
|
|
@ -1,5 +0,0 @@
|
|||||||
MEMORY
|
|
||||||
{
|
|
||||||
FLASH : ORIGIN = 0x08000000, LENGTH = 2048K
|
|
||||||
RAM : ORIGIN = 0x24000000, LENGTH = 384K
|
|
||||||
}
|
|
@ -1 +1 @@
|
|||||||
Subproject commit 0ad27b2fd1126c6c9d9f4602d1331f5d82f4aa26
|
Subproject commit af0611ff9b29f2c0ab675a4f0e51d8241a4097f7
|
@ -9,6 +9,9 @@ fn main() {
|
|||||||
.unwrap()
|
.unwrap()
|
||||||
.to_ascii_lowercase();
|
.to_ascii_lowercase();
|
||||||
|
|
||||||
|
#[cfg(feature = "memory-x")]
|
||||||
|
println!("cargo:rustc-link-search=src/chips/{}/memory_x/", _chip_name);
|
||||||
|
|
||||||
#[cfg(feature = "rt")]
|
#[cfg(feature = "rt")]
|
||||||
println!("cargo:rustc-link-search=src/chips/{}", _chip_name);
|
println!("cargo:rustc-link-search=src/chips/{}", _chip_name);
|
||||||
|
|
||||||
|
@ -19,11 +19,23 @@ pub struct Chip {
|
|||||||
pub family: String,
|
pub family: String,
|
||||||
pub line: String,
|
pub line: String,
|
||||||
pub cores: Vec<Core>,
|
pub cores: Vec<Core>,
|
||||||
pub flash: u32,
|
pub flash: Memory,
|
||||||
pub ram: u32,
|
pub ram: Memory,
|
||||||
pub packages: Vec<Package>,
|
pub packages: Vec<Package>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[derive(Debug, Eq, PartialEq, Clone, Deserialize)]
|
||||||
|
pub struct Memory {
|
||||||
|
pub bytes: u32,
|
||||||
|
pub regions: HashMap<String, MemoryRegion>,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Debug, Eq, PartialEq, Clone, Deserialize)]
|
||||||
|
pub struct MemoryRegion {
|
||||||
|
pub base: u32,
|
||||||
|
pub bytes: Option<u32>,
|
||||||
|
}
|
||||||
|
|
||||||
#[derive(Debug, Eq, PartialEq, Clone, Deserialize)]
|
#[derive(Debug, Eq, PartialEq, Clone, Deserialize)]
|
||||||
pub struct Core {
|
pub struct Core {
|
||||||
pub name: String,
|
pub name: String,
|
||||||
@ -636,6 +648,9 @@ pub fn gen(options: Options) {
|
|||||||
.unwrap()
|
.unwrap()
|
||||||
.write_all(device_x.as_bytes())
|
.write_all(device_x.as_bytes())
|
||||||
.unwrap();
|
.unwrap();
|
||||||
|
|
||||||
|
// generate default memory.x
|
||||||
|
gen_memory_x(&chip_dir, &chip);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (module, version) in all_peripheral_versions {
|
for (module, version) in all_peripheral_versions {
|
||||||
@ -674,6 +689,7 @@ pub fn gen(options: Options) {
|
|||||||
let re = Regex::new("# *! *\\[.*\\]").unwrap();
|
let re = Regex::new("# *! *\\[.*\\]").unwrap();
|
||||||
let data = re.replace_all(&data, "");
|
let data = re.replace_all(&data, "");
|
||||||
file.write_all(data.as_bytes()).unwrap();
|
file.write_all(data.as_bytes()).unwrap();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Generate src/lib_inner.rs
|
// Generate src/lib_inner.rs
|
||||||
@ -734,6 +750,7 @@ pub fn gen(options: Options) {
|
|||||||
|
|
||||||
// Generate build.rs
|
// Generate build.rs
|
||||||
fs::write(out_dir.join("build.rs"), include_bytes!("assets/build.rs")).unwrap();
|
fs::write(out_dir.join("build.rs"), include_bytes!("assets/build.rs")).unwrap();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn bytes_find(haystack: &[u8], needle: &[u8]) -> Option<usize> {
|
fn bytes_find(haystack: &[u8], needle: &[u8]) -> Option<usize> {
|
||||||
@ -741,3 +758,23 @@ fn bytes_find(haystack: &[u8], needle: &[u8]) -> Option<usize> {
|
|||||||
.windows(needle.len())
|
.windows(needle.len())
|
||||||
.position(|window| window == needle)
|
.position(|window| window == needle)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn gen_memory_x(out_dir: &PathBuf, chip: &Chip) {
|
||||||
|
let mut memory_x = String::new();
|
||||||
|
|
||||||
|
let flash_bytes = chip.flash.regions.get("BANK_1").unwrap().bytes.unwrap_or(chip.flash.bytes);
|
||||||
|
let flash_origin = chip.flash.regions.get("BANK_1").unwrap().base;
|
||||||
|
|
||||||
|
let ram_bytes = chip.ram.regions.get("SRAM").unwrap().bytes.unwrap_or(chip.ram.bytes);
|
||||||
|
let ram_origin = chip.ram.regions.get("SRAM").unwrap().base;
|
||||||
|
|
||||||
|
write!(memory_x, "MEMORY\n{{\n").unwrap();
|
||||||
|
write!(memory_x, " FLASH : ORIGIN = 0x{:x}, LENGTH = {}\n", flash_origin, flash_bytes).unwrap();
|
||||||
|
write!(memory_x, " RAM : ORIGIN = 0x{:x}, LENGTH = {}\n", ram_origin, ram_bytes).unwrap();
|
||||||
|
write!(memory_x, "}}").unwrap();
|
||||||
|
|
||||||
|
fs::create_dir_all(out_dir.join("memory_x")).unwrap();
|
||||||
|
let mut file = File::create(out_dir.join("memory_x").join("memory.x")).unwrap();
|
||||||
|
file.write_all( memory_x.as_bytes() ).unwrap();
|
||||||
|
|
||||||
|
}
|
||||||
|
@ -17,6 +17,7 @@ regex = "1.5.4"
|
|||||||
|
|
||||||
[features]
|
[features]
|
||||||
rt = ["cortex-m-rt/device"]
|
rt = ["cortex-m-rt/device"]
|
||||||
|
memory-x = []
|
||||||
|
|
||||||
# BEGIN GENERATED FEATURES
|
# BEGIN GENERATED FEATURES
|
||||||
# Generated by gen_features.py. DO NOT EDIT.
|
# Generated by gen_features.py. DO NOT EDIT.
|
||||||
|
@ -27,5 +27,13 @@ fn main() {
|
|||||||
out_dir.display(),
|
out_dir.display(),
|
||||||
chip_name.to_ascii_lowercase()
|
chip_name.to_ascii_lowercase()
|
||||||
);
|
);
|
||||||
|
|
||||||
|
#[cfg(feature = "memory-x")]
|
||||||
|
println!(
|
||||||
|
"cargo:rustc-link-search={}/src/chips/{}/memory_x/",
|
||||||
|
out_dir.display(),
|
||||||
|
chip_name.to_ascii_lowercase()
|
||||||
|
);
|
||||||
|
|
||||||
println!("cargo:rerun-if-changed=build.rs");
|
println!("cargo:rerun-if-changed=build.rs");
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user