90 lines
2.9 KiB
Markdown
Raw Normal View History

2022-11-05 10:55:35 +01:00
[![Arduino CI](https://github.com/RobTillaart/FastShiftInOut/workflows/Arduino%20CI/badge.svg)](https://github.com/marketplace/actions/arduino_ci)
[![Arduino-lint](https://github.com/RobTillaart/FastShiftInOut/actions/workflows/arduino-lint.yml/badge.svg)](https://github.com/RobTillaart/FastShiftInOut/actions/workflows/arduino-lint.yml)
[![JSON check](https://github.com/RobTillaart/FastShiftInOut/actions/workflows/jsoncheck.yml/badge.svg)](https://github.com/RobTillaart/FastShiftInOut/actions/workflows/jsoncheck.yml)
2023-11-01 12:26:45 +01:00
[![GitHub issues](https://img.shields.io/github/issues/RobTillaart/FastShiftInOut.svg)](https://github.com/RobTillaart/FastShiftInOut/issues)
2022-11-05 10:55:35 +01:00
[![License: MIT](https://img.shields.io/badge/license-MIT-green.svg)](https://github.com/RobTillaart/FastShiftInOut/blob/master/LICENSE)
[![GitHub release](https://img.shields.io/github/release/RobTillaart/FastShiftInOut.svg?maxAge=3600)](https://github.com/RobTillaart/FastShiftInOut/releases)
2023-11-01 12:26:45 +01:00
[![PlatformIO Registry](https://badges.registry.platformio.org/packages/robtillaart/library/FastShiftInOut.svg)](https://registry.platformio.org/libraries/robtillaart/FastShiftInOut)
2022-11-05 10:55:35 +01:00
# FastShiftInOut
2022-11-06 20:27:03 +01:00
Arduino library for **AVR** optimized shiftInOut (simultaneously).
2022-11-05 10:55:35 +01:00
2022-11-06 20:27:03 +01:00
Related libraries
- https://github.com/RobTillaart/FastShiftIn
- https://github.com/RobTillaart/FastShiftOut
- https://github.com/RobTillaart/ShiftInSlow
- https://github.com/RobTillaart/ShiftOutSlow
2022-11-05 10:55:35 +01:00
## Description
FastShiftInOut is a class that can send and receive bytes simultaneously.
In that sense it mimics a SPI bus.
2022-11-05 18:42:15 +01:00
Experimental.
2022-11-05 10:55:35 +01:00
## Performance
performance of **write()**
| version | UNO (us) | ESP32 (us) |
2023-02-20 19:36:46 +01:00
|:---------:|-----------:|-------------:|
2022-11-05 10:55:35 +01:00
| 0.1.0 | 181.08 | 4.32 |
2022-11-05 18:42:15 +01:00
| 0.1.1 | 26.84 | 4.32 |
2023-02-20 19:36:46 +01:00
| 0.1.2 | 26.84 | no data |
| 0.1.3 | 25.52 | 4.32 |
2022-11-05 10:55:35 +01:00
## Interface
2023-02-20 19:36:46 +01:00
```cpp
#include "FastShiftInOut.h"
```
#### Functions
2022-11-05 10:55:35 +01:00
bitOrder = { LSBFIRST, MSBFIRST };
2023-02-20 19:36:46 +01:00
- **FastShiftInOut(uint8_t dataIn, uint8_t dataOut, uint8_t clockPin, uint8_t bitOrder = LSBFIRST)** Constructor.
2022-11-05 10:55:35 +01:00
- **uint8_t write(uint8_t data)** reads and writes simultaneously.
2023-02-20 19:36:46 +01:00
- **uint8_t lastWritten(void)** returns last byte written.
- **uint8_t lastRead(void)** returns last byte read.
- **bool setBitOrder(uint8_t bitOrder)** bitOrder must be LSBFIRST or MSBFIRST.
2022-11-05 10:55:35 +01:00
- **uint8_t getBitOrder(void)** idem.
2023-02-20 19:36:46 +01:00
- **uint8_t writeLSBFIRST(uint8_t data)** optimized version, in practice almost no difference.
- **uint8_t writeMSBFIRST(uint8_t data)** optimized version, in practice almost no difference.
2022-11-05 10:55:35 +01:00
## Future
2023-02-20 19:36:46 +01:00
#### Must
2022-11-05 10:55:35 +01:00
- documentation
2023-02-20 19:36:46 +01:00
- follow FastShiftIn and FastShiftOut
2022-11-05 10:55:35 +01:00
2023-11-01 12:26:45 +01:00
#### Should
2023-02-20 19:36:46 +01:00
2022-11-05 10:55:35 +01:00
2023-11-01 12:26:45 +01:00
#### Could
2023-02-20 19:36:46 +01:00
2022-11-05 10:55:35 +01:00
- **void ignoreRead()**
- add Print interface?
2023-11-01 12:26:45 +01:00
#### Wont
## Support
If you appreciate my libraries, you can support the development and maintenance.
Improve the quality of the libraries by providing issues and Pull Requests, or
donate through PayPal or GitHub sponsors.
Thank you,
2022-11-05 10:55:35 +01:00