C/C++ API Reference
Loading...
Searching...
No Matches
uart_non_blocking.h
1// Copyright 2024 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 <cstdint>
18
19#include "pw_bytes/span.h"
20#include "pw_function/function.h"
21#include "pw_status/status.h"
22#include "pw_status/status_with_size.h"
23#include "pw_uart/uart_base.h"
24
25namespace pw::uart {
26
28
33
34class UartNonBlocking : public UartBase {
35 public:
36 ~UartNonBlocking() override = default;
37
64 ByteSpan rx_buffer,
65 Function<void(Status status, ConstByteSpan buffer)>&& callback) {
66 return DoRead(rx_buffer, rx_buffer.size(), std::move(callback));
67 }
68
95 ByteSpan rx_buffer,
96 size_t min_bytes,
97 Function<void(Status status, ConstByteSpan buffer)>&& callback) {
98 return DoRead(rx_buffer, min_bytes, std::move(callback));
99 }
100
114 bool CancelRead() { return DoCancelRead(); }
115
139 Function<void(StatusWithSize status)>&& callback) {
140 return DoWrite(tx_buffer, std::move(callback));
141 }
142
156 bool CancelWrite() { return DoCancelWrite(); }
157
178 Status FlushOutput(Function<void(Status status)>&& callback) {
179 return DoFlushOutput(std::move(callback));
180 }
181
193
194 private:
224 virtual Status DoRead(
225 ByteSpan rx_buffer,
226 size_t min_bytes,
227 Function<void(Status status, ConstByteSpan buffer)>&& callback) = 0;
228
240 virtual bool DoCancelRead() = 0;
241
267 virtual Status DoWrite(ConstByteSpan tx_buffer,
268 Function<void(StatusWithSize status)>&& callback) = 0;
269
281 virtual bool DoCancelWrite() = 0;
282
303 virtual Status DoFlushOutput(Function<void(Status status)>&& /*callback*/) {
304 return Status::Unimplemented();
305 }
306
317 virtual bool DoCancelFlushOutput() { return false; }
318};
319
320} // namespace pw::uart
Definition: status.h:120
static constexpr Status Unimplemented()
Definition: status.h:280
Definition: status_with_size.h:51
Definition: uart_base.h:32
Definition: uart_non_blocking.h:34
fit::function_impl< function_internal::config::kInlineCallableSize, !function_internal::config::kEnableDynamicAllocation, FunctionType, PW_FUNCTION_DEFAULT_ALLOCATOR_TYPE > Function
Definition: function.h:73
Status FlushOutput(Function< void(Status status)> &&callback)
Definition: uart_non_blocking.h:178
Status ReadExactly(ByteSpan rx_buffer, Function< void(Status status, ConstByteSpan buffer)> &&callback)
Definition: uart_non_blocking.h:63
bool CancelRead()
Definition: uart_non_blocking.h:114
virtual bool DoCancelFlushOutput()
Definition: uart_non_blocking.h:317
Status ReadAtLeast(ByteSpan rx_buffer, size_t min_bytes, Function< void(Status status, ConstByteSpan buffer)> &&callback)
Definition: uart_non_blocking.h:94
bool CancelFlushOutput()
Definition: uart_non_blocking.h:192
virtual bool DoCancelRead()=0
bool CancelWrite()
Definition: uart_non_blocking.h:156
virtual bool DoCancelWrite()=0
virtual Status DoWrite(ConstByteSpan tx_buffer, Function< void(StatusWithSize status)> &&callback)=0
virtual Status DoRead(ByteSpan rx_buffer, size_t min_bytes, Function< void(Status status, ConstByteSpan buffer)> &&callback)=0
Status Write(ConstByteSpan tx_buffer, Function< void(StatusWithSize status)> &&callback)
Definition: uart_non_blocking.h:138
virtual Status DoFlushOutput(Function< void(Status status)> &&)
Definition: uart_non_blocking.h:303
Core UART interfaces.
Definition: blocking_adapter.h:21