svd-generator 0.7.0

Converts device information from flattened device tree into an SVD description
Documentation
use crate::svd::peripheral::dw_mmc::DwMmcVersion;
use crate::svd::{
    create_bit_range, create_field_constraint, create_register, create_register_properties,
    create_write_constraint,
};
use crate::Result;

/// Creates Synopsys DesignWare MMC FIFO Data register definitions.
pub fn create(version: DwMmcVersion, fifo_len: usize) -> Result<svd::RegisterCluster> {
    Ok(svd::RegisterCluster::Register(create_register(
        "data",
        "MMC FIFO data",
        version.data_offset(),
        create_register_properties(32, 0)?,
        Some(&[create_field_constraint(
            "data",
            "MMC FIFO data",
            create_bit_range("[31:0]")?,
            svd::Access::ReadWrite,
            create_write_constraint(0, 0xffff_ffff)?,
            None,
        )?]),
        Some(
            svd::DimElement::builder()
                .dim((fifo_len as u32).saturating_div(4))
                .dim_increment(0x4)
                .build(svd::ValidateLevel::Strict)?,
        ),
    )?))
}