C/C++ API Reference
Loading...
Searching...
No Matches
uart.h
1// Copyright 2023 The Pigweed Authors
2//
3// Licensed under the Apache License, Version 2.0 (the "License"); you may not
4// use this file except in compliance with the License. You may obtain a copy of
5// the License at
6//
7// https://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
11// WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
12// License for the specific language governing permissions and limitations under
13// the License.
14
15#pragma once
16
17#include <cstddef>
18#include <cstdint>
19#include <optional>
20
21#include "pw_assert/assert.h"
22#include "pw_bytes/span.h"
23#include "pw_chrono/system_clock.h"
24#include "pw_status/status.h"
25#include "pw_status/status_with_size.h"
26#include "pw_uart/uart_base.h"
27
29namespace pw::uart {
30
32
37
38class Uart : public UartBase {
39 public:
40 ~Uart() override = default;
41
52 StatusWithSize ReadAtLeast(ByteSpan rx_buffer, size_t min_bytes) {
53 return DoTryReadFor(rx_buffer, min_bytes, std::nullopt);
54 }
55
66 return DoTryReadFor(rx_buffer, rx_buffer.size(), std::nullopt);
67 }
68
80 // TODO: https://pwbug.dev/368149122 - Remove after transition
81 Status Read(ByteSpan rx_buffer) {
82 return DoTryReadFor(rx_buffer, std::nullopt).status();
83 }
84
103 size_t min_bytes,
105 return DoTryReadFor(rx_buffer, min_bytes, timeout);
106 }
107
126 return DoTryReadFor(rx_buffer, rx_buffer.size(), timeout);
127 }
128
148 // TODO: https://pwbug.dev/368149122 - Remove after transition
149 return DoTryReadFor(rx_buffer, timeout);
150 }
151
161 return DoTryWriteFor(tx_buffer, std::nullopt).status();
162 }
163
181 return DoTryWriteFor(tx_buffer, timeout);
182 }
183
194 Status FlushOutput() { return DoFlushOutput(); }
195
196 private:
217 // TODO: https://pwbug.dev/368149122 - Remove after transition.
219 ByteSpan rx_buffer,
220 std::optional<chrono::SystemClock::duration> timeout) {
221 return DoTryReadFor(rx_buffer, rx_buffer.size(), timeout);
222 }
223
246 // TODO: https://pwbug.dev/368149122 - Make pure virtual after transition.
248 ByteSpan /*rx_buffer*/,
249 size_t /*min_bytes*/,
250 std::optional<chrono::SystemClock::duration> /*timeout*/) {
251 return StatusWithSize::Unimplemented();
252 }
253
276 ConstByteSpan tx_buffer,
277 std::optional<chrono::SystemClock::duration> timeout) = 0;
278 virtual Status DoFlushOutput() = 0;
279};
280
281} // namespace pw::uart
Definition: status.h:120
Definition: status_with_size.h:51
Definition: uart_base.h:32
Definition: uart.h:38
std::chrono::duration< rep, period > duration
Alias for durations representable with this clock.
Definition: system_clock.h:90
StatusWithSize TryReadExactlyFor(ByteSpan rx_buffer, chrono::SystemClock::duration timeout)
Definition: uart.h:124
Status FlushOutput()
Definition: uart.h:194
virtual StatusWithSize DoTryReadFor(ByteSpan rx_buffer, std::optional< chrono::SystemClock::duration > timeout)
Definition: uart.h:218
virtual StatusWithSize DoTryWriteFor(ConstByteSpan tx_buffer, std::optional< chrono::SystemClock::duration > timeout)=0
Writes data from a provided buffer to the UART with an optional timeout.
virtual StatusWithSize DoTryReadFor(ByteSpan, size_t, std::optional< chrono::SystemClock::duration >)
Definition: uart.h:247
StatusWithSize ReadExactly(ByteSpan rx_buffer)
Definition: uart.h:65
StatusWithSize ReadAtLeast(ByteSpan rx_buffer, size_t min_bytes)
Definition: uart.h:52
StatusWithSize TryReadAtLeastFor(ByteSpan rx_buffer, size_t min_bytes, chrono::SystemClock::duration timeout)
Definition: uart.h:102
Status Write(ConstByteSpan tx_buffer)
Definition: uart.h:160
StatusWithSize TryWriteFor(ConstByteSpan tx_buffer, chrono::SystemClock::duration timeout)
Definition: uart.h:179
StatusWithSize TryReadFor(ByteSpan rx_buffer, chrono::SystemClock::duration timeout)
Definition: uart.h:146
Status Read(ByteSpan rx_buffer)
Definition: uart.h:81
Core UART interfaces.
Definition: blocking_adapter.h:21