Pigweed
 
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
31
32class UartNonBlocking : public UartBase {
33 public:
34 ~UartNonBlocking() override = default;
35
68 ByteSpan rx_buffer,
69 Function<void(Status status, ConstByteSpan buffer)>&& callback) {
70 return DoRead(rx_buffer, rx_buffer.size(), std::move(callback));
71 }
72
105 ByteSpan rx_buffer,
106 size_t min_bytes,
107 Function<void(Status status, ConstByteSpan buffer)>&& callback) {
108 return DoRead(rx_buffer, min_bytes, std::move(callback));
109 }
110
124 bool CancelRead() { return DoCancelRead(); }
125
154 Status Write(ConstByteSpan tx_buffer,
155 Function<void(StatusWithSize status)>&& callback) {
156 return DoWrite(tx_buffer, std::move(callback));
157 }
158
172 bool CancelWrite() { return DoCancelWrite(); }
173
200 Status FlushOutput(Function<void(Status status)>&& callback) {
201 return DoFlushOutput(std::move(callback));
202 }
203
218
219 private:
255 virtual Status DoRead(
256 ByteSpan rx_buffer,
257 size_t min_bytes,
258 Function<void(Status status, ConstByteSpan buffer)>&& callback) = 0;
259
275 virtual bool DoCancelRead() = 0;
276
308 virtual Status DoWrite(ConstByteSpan tx_buffer,
309 Function<void(StatusWithSize status)>&& callback) = 0;
310
326 virtual bool DoCancelWrite() = 0;
327
354 virtual Status DoFlushOutput(Function<void(Status status)>&& /*callback*/) {
355 return Status::Unimplemented();
356 }
357
371 virtual bool DoCancelFlushOutput() { return false; }
372};
373
374} // namespace pw::uart
Definition: status.h:85
Definition: status_with_size.h:49
Definition: uart_base.h:30
Definition: uart_non_blocking.h:32
Status FlushOutput(Function< void(Status status)> &&callback)
Definition: uart_non_blocking.h:200
Status ReadExactly(ByteSpan rx_buffer, Function< void(Status status, ConstByteSpan buffer)> &&callback)
Definition: uart_non_blocking.h:67
bool CancelRead()
Definition: uart_non_blocking.h:124
virtual bool DoCancelFlushOutput()
Definition: uart_non_blocking.h:371
Status ReadAtLeast(ByteSpan rx_buffer, size_t min_bytes, Function< void(Status status, ConstByteSpan buffer)> &&callback)
Definition: uart_non_blocking.h:104
bool CancelFlushOutput()
Definition: uart_non_blocking.h:217
virtual bool DoCancelRead()=0
bool CancelWrite()
Definition: uart_non_blocking.h:172
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:154
virtual Status DoFlushOutput(Function< void(Status status)> &&)
Definition: uart_non_blocking.h:354
fit::function_impl< function_internal::config::kInlineCallableSize, !function_internal::config::kEnableDynamicAllocation, FunctionType, PW_FUNCTION_DEFAULT_ALLOCATOR_TYPE > Function
Definition: function.h:74