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
58 StatusWithSize ReadAtLeast(ByteSpan rx_buffer, size_t min_bytes) {
59 return DoTryReadFor(rx_buffer, min_bytes, std::nullopt);
60 }
61
78 return DoTryReadFor(rx_buffer, rx_buffer.size(), std::nullopt);
79 }
80
98 // TODO: https://pwbug.dev/368149122 - Remove after transition
99 Status Read(ByteSpan rx_buffer) {
100 return DoTryReadFor(rx_buffer, std::nullopt).status();
101 }
102
128 size_t min_bytes,
130 return DoTryReadFor(rx_buffer, min_bytes, timeout);
131 }
132
158 return DoTryReadFor(rx_buffer, rx_buffer.size(), timeout);
159 }
160
187 // TODO: https://pwbug.dev/368149122 - Remove after transition
188 return DoTryReadFor(rx_buffer, timeout);
189 }
190
206 return DoTryWriteFor(tx_buffer, std::nullopt).status();
207 }
208
233 return DoTryWriteFor(tx_buffer, timeout);
234 }
235
252 Status FlushOutput() { return DoFlushOutput(); }
253
254 private:
282 // TODO: https://pwbug.dev/368149122 - Remove after transition.
284 ByteSpan rx_buffer,
285 std::optional<chrono::SystemClock::duration> timeout) {
286 return DoTryReadFor(rx_buffer, rx_buffer.size(), timeout);
287 }
288
318 // TODO: https://pwbug.dev/368149122 - Make pure virtual after transition.
320 ByteSpan /*rx_buffer*/,
321 size_t /*min_bytes*/,
322 std::optional<chrono::SystemClock::duration> /*timeout*/) {
323 return StatusWithSize::Unimplemented();
324 }
325
355 ConstByteSpan tx_buffer,
356 std::optional<chrono::SystemClock::duration> timeout) = 0;
357 virtual Status DoFlushOutput() = 0;
358};
359
360} // namespace pw::uart
Definition: status.h:86
Definition: status_with_size.h:49
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:156
Status FlushOutput()
Definition: uart.h:252
virtual StatusWithSize DoTryReadFor(ByteSpan rx_buffer, std::optional< chrono::SystemClock::duration > timeout)
Definition: uart.h:283
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:319
StatusWithSize ReadExactly(ByteSpan rx_buffer)
Definition: uart.h:77
StatusWithSize ReadAtLeast(ByteSpan rx_buffer, size_t min_bytes)
Definition: uart.h:58
StatusWithSize TryReadAtLeastFor(ByteSpan rx_buffer, size_t min_bytes, chrono::SystemClock::duration timeout)
Definition: uart.h:127
Status Write(ConstByteSpan tx_buffer)
Definition: uart.h:205
StatusWithSize TryWriteFor(ConstByteSpan tx_buffer, chrono::SystemClock::duration timeout)
Definition: uart.h:231
StatusWithSize TryReadFor(ByteSpan rx_buffer, chrono::SystemClock::duration timeout)
Definition: uart.h:185
Status Read(ByteSpan rx_buffer)
Definition: uart.h:99
Core UART interfaces.
Definition: blocking_adapter.h:21