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
70 ByteSpan rx_buffer,
71 Function<void(Status status, ConstByteSpan buffer)>&& callback) {
72 return DoRead(rx_buffer, rx_buffer.size(), std::move(callback));
73 }
74
107 ByteSpan rx_buffer,
108 size_t min_bytes,
109 Function<void(Status status, ConstByteSpan buffer)>&& callback) {
110 return DoRead(rx_buffer, min_bytes, std::move(callback));
111 }
112
126 bool CancelRead() { return DoCancelRead(); }
127
157 Function<void(StatusWithSize status)>&& callback) {
158 return DoWrite(tx_buffer, std::move(callback));
159 }
160
174 bool CancelWrite() { return DoCancelWrite(); }
175
202 Status FlushOutput(Function<void(Status status)>&& callback) {
203 return DoFlushOutput(std::move(callback));
204 }
205
220
221 private:
257 virtual Status DoRead(
258 ByteSpan rx_buffer,
259 size_t min_bytes,
260 Function<void(Status status, ConstByteSpan buffer)>&& callback) = 0;
261
277 virtual bool DoCancelRead() = 0;
278
310 virtual Status DoWrite(ConstByteSpan tx_buffer,
311 Function<void(StatusWithSize status)>&& callback) = 0;
312
328 virtual bool DoCancelWrite() = 0;
329
356 virtual Status DoFlushOutput(Function<void(Status status)>&& /*callback*/) {
357 return Status::Unimplemented();
358 }
359
373 virtual bool DoCancelFlushOutput() { return false; }
374};
375
376} // namespace pw::uart
Definition: status.h:86
Definition: status_with_size.h:49
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:202
Status ReadExactly(ByteSpan rx_buffer, Function< void(Status status, ConstByteSpan buffer)> &&callback)
Definition: uart_non_blocking.h:69
bool CancelRead()
Definition: uart_non_blocking.h:126
virtual bool DoCancelFlushOutput()
Definition: uart_non_blocking.h:373
Status ReadAtLeast(ByteSpan rx_buffer, size_t min_bytes, Function< void(Status status, ConstByteSpan buffer)> &&callback)
Definition: uart_non_blocking.h:106
bool CancelFlushOutput()
Definition: uart_non_blocking.h:219
virtual bool DoCancelRead()=0
bool CancelWrite()
Definition: uart_non_blocking.h:174
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:156
virtual Status DoFlushOutput(Function< void(Status status)> &&)
Definition: uart_non_blocking.h:356
Core UART interfaces.
Definition: blocking_adapter.h:21