summaryrefslogtreecommitdiffstats
path: root/ble/src/main.rs
blob: 6f167a599d0cb50aaa43c57e54bab95406a5f17d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
//! BLE interface.

#![no_std]
#![no_main]

mod logger;
mod macros;
mod rtc;

use clint::HandlerArray;
use core::mem;
use cortex_m::asm::wfi;
use cortex_m_rt::entry;
use log::{info, trace, LevelFilter};

#[allow(unused_imports)]
extern crate panic_semihosting;

use nrf52840_mdk_bsp::{
    hal::{
        target::{interrupt, Interrupt, UARTE0},
        Clocks, Rtc,
    },
    Board,
};

// TODO:
//   * set up serial reader for trinket
//   * set up i²c interface for keyboard reports
//   * and, finally, bluetooth

// Interrupt handler table.
static HANDLERS: HandlerArray = HandlerArray::new();

#[entry]
fn main() -> ! {
    let nrf52 = Board::take().unwrap();

    let uart_wrapped = logger::WriteWrapper::new(nrf52.cdc);
    let logger = logger::SerialLogger::new(uart_wrapped);
    let logger_ref: &'static logger::SerialLogger<UARTE0> = unsafe { mem::transmute(&logger) };
    log::set_logger(logger_ref).expect("setting logger");
    log::set_max_level(LevelFilter::Trace);

    nrf52.RTC0.intenset.write(|w| w.tick().set());

    let mut nvic = nrf52.NVIC;
    let mut rtc_handler = rtc::setup(Rtc::new(nrf52.RTC0), Clocks::new(nrf52.CLOCK));

    logln_now!("logln_now?");
    HANDLERS.with_overrides(|hs| {
        hs.register(0, &mut rtc_handler);
        nvic.enable(Interrupt::RTC0);

        info!("Bootstrap complete.");
        let mut last_tick = rtc::millis();
        last_tick -= last_tick % 1024;
        loop {
            let tick = rtc::millis();
            if tick >= last_tick + 1024 {
                last_tick = tick;
                last_tick -= last_tick % 1024;
                trace!(".");
            }
            wfi();
        }
    });
    unreachable!();
}

// TODO: RTC0/1/2 exist. See which is best, if it matters.
#[interrupt]
fn RTC0() {
    HANDLERS.call(0);
}