์ฃผ๋ณ€๊ธฐ๊ธฐ ์•ก์„ธ์Šค ํฌ๋ ˆ์ดํŠธ

svd2rust ํฌ๋ ˆ์ดํŠธ๋ฅผ ์ด์šฉํ•˜๋ฉด ๋ฉ”๋ชจ๋ฆฌ ๋งคํ•‘๋œ ์ฃผ๋ณ€์žฅ์น˜๋ฅผ ๊ธฐ์ˆ ํ•˜๋Š” CMSIS-SVD ํŒŒ์ผ๋กœ๋ถ€ํ„ฐ Rust ๋ž˜ํผ๋ฅผ ์ƒ์„ฑํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

#![no_main]
#![no_std]

extern crate panic_halt as _;

use cortex_m_rt::entry;
use nrf52833_pac::Peripherals;

#[entry]
fn main() -> ! {
    let p = Peripherals::take().unwrap();
    let gpio0 = p.P0;

    // GPIO 0 ํ•€ 21 ๋ฐ 28์„ ํ‘ธ์‹œ-ํ’€ ์ถœ๋ ฅ์œผ๋กœ ๊ตฌ์„ฑํ•ฉ๋‹ˆ๋‹ค.
    gpio0.pin_cnf[21].write(|w| {
        w.dir().output();
        w.input().disconnect();
        w.pull().disabled();
        w.drive().s0s1();
        w.sense().disabled();
        w
    });
    gpio0.pin_cnf[28].write(|w| {
        w.dir().output();
        w.input().disconnect();
        w.pull().disabled();
        w.drive().s0s1();
        w.sense().disabled();
        w
    });

    // ํ•€ 28์„ ๋‚ฎ๊ฒŒ, ํ•€ 21์„ ๋†’๊ฒŒ ์„ค์ •ํ•˜์—ฌ LED๋ฅผ ์ผญ๋‹ˆ๋‹ค.
    gpio0.outclr.write(|w| w.pin28().clear());
    gpio0.outset.write(|w| w.pin21().set());

    loop {}
}
  • SVD(System View Description) ํŒŒ์ผ์€ ์ผ๋ฐ˜์ ์œผ๋กœ ์‹ค๋ฆฌ์ฝ˜ ๊ณต๊ธ‰์—…์ฒด์—์„œ ์ œ๊ณตํ•˜๋Š” XML ํŒŒ์ผ๋กœ, ๊ธฐ๊ธฐ์˜ ๋ฉ”๋ชจ๋ฆฌ ๋งต์„ ๊ธฐ์ˆ ํ•ฉ๋‹ˆ๋‹ค.
    • ์ฃผ๋ณ€๊ธฐ๊ธฐ, ๋ ˆ์ง€์Šคํ„ฐ, ํ•„๋“œ, ๊ฐ’์œผ๋กœ ๊ตฌ์„ฑ๋˜๋ฉฐ ์ด๋ฆ„, ์„ค๋ช…, ์ฃผ์†Œ ๋“ฑ์ด ํฌํ•จ๋ฉ๋‹ˆ๋‹ค.
    • SVD ํŒŒ์ผ์—๋Š” ๋ฒ„๊ทธ๊ฐ€ ์žˆ์„ ์ˆ˜ ์žˆ๊ณ  ๋ถˆ์™„์ „ํ•˜๊ธฐ ๋•Œ๋ฌธ์—, ์ด๋Ÿฌํ•œ ๋ฌธ์ œ๋“ค์„ ํŒจ์น˜ํ•˜๋Š” ๋‹ค์–‘ํ•œ ํ”„๋กœ์ ํŠธ๋“ค์ด ์žˆ์Šต๋‹ˆ๋‹ค.
  • cortex-m-rt๋Š” ๋ฌด์—‡๋ณด๋‹ค๋„ ๋ฒกํ„ฐ ํ…Œ์ด๋ธ”์„ ์ œ๊ณตํ•ฉ๋‹ˆ๋‹ค.
  • cargo install cargo-binutils์„ ์‹คํ–‰ํ•œ ํ›„, cargo objdump --bin pac -- -d --no-show-raw-insn์„ ์‹คํ–‰ํ•˜์—ฌ ์ƒ์„ฑ๋œ ๋ฐ”์ด๋„ˆ๋ฆฌ์˜ ๋‚ด์šฉ์„ ํ™•์ธํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

์•„๋ž˜ ๋ช…๋ น์–ด๋กœ ์˜ˆ์ œ ์ฝ”๋“œ๋ฅผ ์‹คํ–‰ํ•˜์„ธ์š”.

cargo embed --bin pac