-
Notifications
You must be signed in to change notification settings - Fork 3
/
lib.rs
154 lines (139 loc) · 3.57 KB
/
lib.rs
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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
#![no_std]
//! Manages a new L298N a Dual H-Bridge Motor Controller module
#![deny(
missing_docs,
missing_debug_implementations,
missing_copy_implementations,
trivial_casts,
trivial_numeric_casts,
unstable_features,
unused_import_braces,
unused_qualifications,
warnings
)]
#![allow(dead_code)]
use embedded_hal::digital::v2::OutputPin;
use embedded_hal::PwmPin;
/// Struct for L298N. Two enable inputs are provided to enable or disable the device
/// independently of the input signals. The emitters of the lower transistors of each
/// bridge are connected together and the corresponding external terminal can be used
/// for the connection of an external sensing resistor. An additional supply input is
/// provided so that the logic works at a lower voltage.
#[derive(Debug)]
pub struct L298N<INA, INB, INC, IND, PWMA, PWMB>
where
INA: OutputPin,
INB: OutputPin,
INC: OutputPin,
IND: OutputPin,
PWMA: PwmPin,
PWMB: PwmPin,
{
/// motor A
pub a: Motor<INA, INB, PWMA>,
/// motor B
pub b: Motor<INC, IND, PWMB>,
}
impl<INA, INB, INC, IND, PWMA, PWMB> L298N<INA, INB, INC, IND, PWMA, PWMB>
where
INA: OutputPin,
INB: OutputPin,
INC: OutputPin,
IND: OutputPin,
PWMA: PwmPin,
PWMB: PwmPin,
{
/// Creates a new `L298N` motor controller
pub fn new(
ina1: INA,
ina2: INB,
pwma: PWMA,
inb1: INC,
inb2: IND,
pwmb: PWMB,
) -> L298N<INA, INB, INC, IND, PWMA, PWMB>
where
INA: OutputPin,
INB: OutputPin,
INC: OutputPin,
IND: OutputPin,
PWMA: PwmPin,
PWMB: PwmPin,
{
L298N {
a: Motor::new(ina1, ina2, pwma),
b: Motor::new(inb1, inb2, pwmb),
}
}
}
/// Struct for single bridge
#[derive(Debug)]
pub struct Motor<INF, INS, PWM>
where
INF: OutputPin,
INS: OutputPin,
PWM: PwmPin,
{
in1: INF,
in2: INS,
pwm: PWM,
}
impl<INF, INS, PWM> Motor<INF, INS, PWM>
where
INF: OutputPin,
INS: OutputPin,
PWM: PwmPin,
{
/// Creates a new single `Motor` controller
pub fn new(in1: INF, in2: INS, pwm: PWM) -> Motor<INF, INS, PWM>
where
INF: OutputPin,
INS: OutputPin,
PWM: PwmPin,
{
let mut pwm = pwm;
pwm.enable();
Motor { in1, in2, pwm }
}
/// Brakes the motor - Fast Motor Stop
/// with Ven = H then C = D Fast Motor Stop
pub fn brake(&mut self) -> &mut Self {
self.in1.set_high().ok();
self.in2.set_high().ok();
self
}
/// Stops the motor - Free Running Motor Stop
/// Ven = L then with C = X ; D = X
pub fn stop(&mut self) -> &mut Self {
self.in1.set_high().ok();
self.in2.set_high().ok();
self
}
/// Makes the motor forward direction
/// with Ven = H then C = H ; D = L Forward
pub fn forward(&mut self) -> &mut Self {
self.in1.set_low().ok();
self.in2.set_high().ok();
self
}
/// Makes the motor reverse direction
/// with Ven = H then C = L ; D = H Reverse
pub fn reverse(&mut self) -> &mut Self {
self.in1.set_high().ok();
self.in2.set_low().ok();
self
}
/// Returns the maximum
pub fn get_max_duty(&self) -> PWM::Duty {
self.pwm.get_max_duty()
}
/// Changes the motor speed
pub fn set_duty(&mut self, duty: PWM::Duty) -> &mut Self {
self.pwm.set_duty(duty);
self
}
/// Get the actual motor speed
pub fn get_current_duty(&self) -> PWM::Duty {
self.pwm.get_duty()
}
}