length: usize, ) -> Result<(), failure::Error> {
#[repr(C)]
#[derive(Clone, Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]
struct EraseInfo {
start: c_uint,
length: c_uint,
};
ioctl_write_ptr!(mtd_erase, b'M', 0x02, EraseInfo); // MEMERASE
ioctl_write_ptr!(mtd_lock, b'M', 0x05, EraseInfo); // MEMLOCK
ioctl_write_ptr!(mtd_unlock, b'M', 0x06, EraseInfo); // MEMUNLOCK
let ei = EraseInfo {start: start as c_uint, length: length as u32 };
unsafe { mtd_unlock(fd, &ei) };
unsafe { mtd_erase(fd, &ei) }.unwrap();
Ok(())
}
Внутри функции erase_block есть объявление структуры которая используется только в этой функции и макросы которые гененрируют объявления функций.
Насколько я понимаю, компилятор сгенерирует это все на этапе компиляции и в рантайме при вызове функции все будет работать также как и если бы все объявления были вынесены за пределы функции? Никаких дополнительных действий и никакого оверхеда в рантайме не будет. Все правильно? Может есть какие-то подводные камни?
ничего боятся не стоит, этоже компилируемый код. даже в стандартной библиотеке такая практика используется. https://doc.rust-lang.org/src/std/io/mod.rs.html#1109
Обсуждают сегодня