|
| 1 | +mod nb { |
| 2 | + use core::ops::Deref; |
| 3 | + |
| 4 | + use super::super::{Error, Instance, RegisterBlockImpl, Rx, Serial, Tx}; |
| 5 | + use embedded_hal_nb::serial::{ErrorKind, Read, Write}; |
| 6 | + |
| 7 | + impl embedded_hal_nb::serial::Error for Error { |
| 8 | + fn kind(&self) -> ErrorKind { |
| 9 | + match self { |
| 10 | + Error::Overrun => ErrorKind::Overrun, |
| 11 | + Error::FrameFormat => ErrorKind::FrameFormat, |
| 12 | + Error::Parity => ErrorKind::Parity, |
| 13 | + Error::Noise => ErrorKind::Noise, |
| 14 | + Error::Other => ErrorKind::Other, |
| 15 | + } |
| 16 | + } |
| 17 | + } |
| 18 | + |
| 19 | + impl<USART: Instance, WORD> embedded_hal_nb::serial::ErrorType for Serial<USART, WORD> { |
| 20 | + type Error = Error; |
| 21 | + } |
| 22 | + impl<USART: Instance, WORD> embedded_hal_nb::serial::ErrorType for Rx<USART, WORD> { |
| 23 | + type Error = Error; |
| 24 | + } |
| 25 | + impl<USART: Instance, WORD> embedded_hal_nb::serial::ErrorType for Tx<USART, WORD> { |
| 26 | + type Error = Error; |
| 27 | + } |
| 28 | + |
| 29 | + impl<USART: Instance, WORD: Copy> Read<WORD> for Serial<USART, WORD> |
| 30 | + where |
| 31 | + Rx<USART, WORD>: Read<WORD, Error = Error>, |
| 32 | + { |
| 33 | + fn read(&mut self) -> nb::Result<WORD, Self::Error> { |
| 34 | + self.rx.read() |
| 35 | + } |
| 36 | + } |
| 37 | + |
| 38 | + impl<USART: Instance> Read<u8> for Rx<USART, u8> |
| 39 | + where |
| 40 | + <USART as Instance>::RegisterBlock: RegisterBlockImpl, |
| 41 | + { |
| 42 | + fn read(&mut self) -> nb::Result<u8, Self::Error> { |
| 43 | + unsafe { (*USART::ptr()).read_u8() } |
| 44 | + } |
| 45 | + } |
| 46 | + |
| 47 | + /// Reads 9-bit words from the UART/USART |
| 48 | + /// |
| 49 | + /// If the UART/USART was configured with `WordLength::DataBits9`, the returned value will contain |
| 50 | + /// 9 received data bits and all other bits set to zero. Otherwise, the returned value will contain |
| 51 | + /// 8 received data bits and all other bits set to zero. |
| 52 | + impl<USART: Instance> Read<u16> for Rx<USART, u16> |
| 53 | + where |
| 54 | + <USART as Instance>::RegisterBlock: RegisterBlockImpl, |
| 55 | + { |
| 56 | + fn read(&mut self) -> nb::Result<u16, Self::Error> { |
| 57 | + unsafe { (*USART::ptr()).read_u16() } |
| 58 | + } |
| 59 | + } |
| 60 | + |
| 61 | + impl<USART: Instance, WORD: Copy> Write<WORD> for Serial<USART, WORD> |
| 62 | + where |
| 63 | + Tx<USART, WORD>: Write<WORD, Error = Error>, |
| 64 | + { |
| 65 | + fn flush(&mut self) -> nb::Result<(), Self::Error> { |
| 66 | + self.tx.flush() |
| 67 | + } |
| 68 | + |
| 69 | + fn write(&mut self, byte: WORD) -> nb::Result<(), Self::Error> { |
| 70 | + self.tx.write(byte) |
| 71 | + } |
| 72 | + } |
| 73 | + |
| 74 | + impl<USART: Instance> Write<u8> for Tx<USART, u8> |
| 75 | + where |
| 76 | + <USART as Instance>::RegisterBlock: RegisterBlockImpl, |
| 77 | + USART: Deref<Target = <USART as Instance>::RegisterBlock>, |
| 78 | + { |
| 79 | + fn write(&mut self, word: u8) -> nb::Result<(), Self::Error> { |
| 80 | + self.usart.write_u8(word) |
| 81 | + } |
| 82 | + fn flush(&mut self) -> nb::Result<(), Self::Error> { |
| 83 | + self.usart.flush() |
| 84 | + } |
| 85 | + } |
| 86 | + |
| 87 | + /// Writes 9-bit words to the UART/USART |
| 88 | + /// |
| 89 | + /// If the UART/USART was configured with `WordLength::DataBits9`, the 9 least significant bits will |
| 90 | + /// be transmitted and the other 7 bits will be ignored. Otherwise, the 8 least significant bits |
| 91 | + /// will be transmitted and the other 8 bits will be ignored. |
| 92 | + impl<USART: Instance> Write<u16> for Tx<USART, u16> |
| 93 | + where |
| 94 | + <USART as Instance>::RegisterBlock: RegisterBlockImpl, |
| 95 | + USART: Deref<Target = <USART as Instance>::RegisterBlock>, |
| 96 | + { |
| 97 | + fn write(&mut self, word: u16) -> nb::Result<(), Self::Error> { |
| 98 | + self.usart.write_u16(word) |
| 99 | + } |
| 100 | + |
| 101 | + fn flush(&mut self) -> nb::Result<(), Self::Error> { |
| 102 | + self.usart.flush() |
| 103 | + } |
| 104 | + } |
| 105 | +} |
| 106 | + |
| 107 | +mod io { |
| 108 | + use core::ops::Deref; |
| 109 | + |
| 110 | + use super::super::{Error, Instance, RegisterBlockImpl, Rx, Serial, Tx}; |
| 111 | + use embedded_io::Write; |
| 112 | + |
| 113 | + impl embedded_io::Error for Error { |
| 114 | + // TODO: fix error conversion |
| 115 | + fn kind(&self) -> embedded_io::ErrorKind { |
| 116 | + embedded_io::ErrorKind::Other |
| 117 | + } |
| 118 | + } |
| 119 | + |
| 120 | + impl<USART: Instance, WORD> embedded_io::ErrorType for Serial<USART, WORD> { |
| 121 | + type Error = Error; |
| 122 | + } |
| 123 | + |
| 124 | + impl<USART: Instance, WORD> embedded_io::ErrorType for Tx<USART, WORD> { |
| 125 | + type Error = Error; |
| 126 | + } |
| 127 | + |
| 128 | + impl<USART: Instance, WORD> embedded_io::ErrorType for Rx<USART, WORD> { |
| 129 | + type Error = Error; |
| 130 | + } |
| 131 | + |
| 132 | + impl<USART: Instance> Write for Tx<USART, u8> |
| 133 | + where |
| 134 | + <USART as Instance>::RegisterBlock: RegisterBlockImpl, |
| 135 | + USART: Deref<Target = <USART as Instance>::RegisterBlock>, |
| 136 | + { |
| 137 | + /* |
| 138 | + fn write(&mut self, bytes: &[u8]) -> Result<usize, Self::Error> { |
| 139 | + let mut iter = bytes.iter(); |
| 140 | + let Some(first) = iter.next() else { |
| 141 | + return Ok(0); |
| 142 | + }; |
| 143 | + // block for first byte |
| 144 | + self.usart.write_u8(*first)?; |
| 145 | + let mut i = 1; |
| 146 | +
|
| 147 | + // write more bytes if it's possible |
| 148 | + for byte in iter { |
| 149 | + match self.usart.write_u8(*byte) { |
| 150 | + Ok(_) => { |
| 151 | + i += 1; |
| 152 | + } |
| 153 | + Err(nb::Error::WouldBlock) => { |
| 154 | + return Ok(i); |
| 155 | + } |
| 156 | + Err(nb::Error::Other(e)) => { |
| 157 | + return Err(e); |
| 158 | + } |
| 159 | + } |
| 160 | + } |
| 161 | + Ok(i) |
| 162 | + }*/ |
| 163 | + fn write(&mut self, bytes: &[u8]) -> Result<usize, Self::Error> { |
| 164 | + let mut i = 0; |
| 165 | + for byte in bytes.iter() { |
| 166 | + match self.usart.write_u8(*byte) { |
| 167 | + Ok(_) => { |
| 168 | + i += 1; |
| 169 | + } |
| 170 | + Err(nb::Error::WouldBlock) => { |
| 171 | + return Ok(i); |
| 172 | + } |
| 173 | + Err(nb::Error::Other(e)) => { |
| 174 | + return Err(e); |
| 175 | + } |
| 176 | + } |
| 177 | + } |
| 178 | + Ok(i) |
| 179 | + } |
| 180 | + |
| 181 | + fn flush(&mut self) -> Result<(), Self::Error> { |
| 182 | + self.usart.bflush()?; |
| 183 | + Ok(()) |
| 184 | + } |
| 185 | + } |
| 186 | + |
| 187 | + impl<USART: Instance> Write for Serial<USART, u8> |
| 188 | + where |
| 189 | + Tx<USART, u8>: Write<Error = Error>, |
| 190 | + { |
| 191 | + fn write(&mut self, bytes: &[u8]) -> Result<usize, Self::Error> { |
| 192 | + self.tx.write(bytes) |
| 193 | + } |
| 194 | + |
| 195 | + fn flush(&mut self) -> Result<(), Self::Error> { |
| 196 | + self.tx.flush() |
| 197 | + } |
| 198 | + } |
| 199 | +} |
0 commit comments