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)
|
|
|
|
[![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)
|
|
|
|
|
|
|
|
|
|
|
|
# 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
|
|
|
|
|
|
|
#### should
|
2023-02-20 19:36:46 +01:00
|
|
|
|
2022-11-05 10:55:35 +01:00
|
|
|
|
|
|
|
#### could
|
2023-02-20 19:36:46 +01:00
|
|
|
|
2022-11-05 10:55:35 +01:00
|
|
|
- **void ignoreRead()**
|
|
|
|
- add Print interface?
|
|
|
|
|
|
|
|
|