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
use esp8266_hal::gpio::*;
use esp8266_hal::target::GPIO;
use paste;

// This macro is a helper for defining a `Pins` type within a board support
// crate. This type is used to provide more meaningful aliases for the various
// GPIO pins for a given board.
macro_rules! define_pins {
    (
        $(
            $(#[$attr:meta])*
            pin $name:ident = ($pin_ident:ident, $pin_mode:ty)
        ),+ ,
    ) => {

paste::item! {
    /// Maps labelled pin names to their physical pins.
    pub struct Pins {
        $(
            $(#[$attr])*
            pub $name: [<$pin_ident:camel>]<$pin_mode>
        ),+
    }
}

impl Pins {
    /// Returns the pins for the device.
    pub fn new(gpio: GPIO) -> Self {
        let pins = gpio.split();

        Self {
            $( $name: pins.$pin_ident ),+
        }
    }
}

    };
}

define_pins!(
    /// Digital pin 0
    pin d0 = (gpio16, Input<Floating>),
    /// Digital pin 1, SCL
    pin d1 = (gpio5, Input<Floating>),
    /// Digital pin 2, SDA
    pin d2 = (gpio4, Input<Floating>),
    /// Digital pin 3 (10k pull-up)
    pin d3 = (gpio0, Input<Floating>),
    /// Digital pin 4 (10k pull-up), built-in LED
    pin d4 = (gpio2, Input<Floating>),
    /// Digital pin 5, SCK
    pin d5 = (gpio14, UnInitialized),
    /// Digital pin 6, MISO
    pin d6 = (gpio12, UnInitialized),
    /// Digital pin 7, MOSI, CTS
    pin d7 = (gpio13, UART),
    /// Digital pin 8 (10k pull-down), SS, RTS
    pin d8 = (gpio15, UART),

    /// UART receive pin
    pin rx = (gpio3, UART),
    /// UART transmit pin
    pin tx = (gpio1, UART),
);