141 lines
4.3 KiB
Markdown
Raw Normal View History

2021-01-29 12:31:58 +01:00
[![Arduino CI](https://github.com/RobTillaart/DAC8554/workflows/Arduino%20CI/badge.svg)](https://github.com/marketplace/actions/arduino_ci)
2021-08-30 14:09:24 +02:00
[![Arduino-lint](https://github.com/RobTillaart/DAC8554/actions/workflows/arduino-lint.yml/badge.svg)](https://github.com/RobTillaart/DAC8554/actions/workflows/arduino-lint.yml)
[![JSON check](https://github.com/RobTillaart/DAC8554/actions/workflows/jsoncheck.yml/badge.svg)](https://github.com/RobTillaart/DAC8554/actions/workflows/jsoncheck.yml)
2023-10-19 15:28:53 +02:00
[![GitHub issues](https://img.shields.io/github/issues/RobTillaart/DAC8554.svg)](https://github.com/RobTillaart/DAC8554/issues)
2021-01-29 12:31:58 +01:00
[![License: MIT](https://img.shields.io/badge/license-MIT-green.svg)](https://github.com/RobTillaart/DAC8554/blob/master/LICENSE)
[![GitHub release](https://img.shields.io/github/release/RobTillaart/DAC8554.svg?maxAge=3600)](https://github.com/RobTillaart/DAC8554/releases)
2023-10-19 15:28:53 +02:00
[![PlatformIO Registry](https://badges.registry.platformio.org/packages/robtillaart/library/DAC8554.svg)](https://registry.platformio.org/libraries/robtillaart/DAC8554)
2021-01-29 12:31:58 +01:00
2021-06-02 08:50:22 +02:00
# DAC8554
2021-01-29 12:31:58 +01:00
2021-12-15 14:57:49 +01:00
Arduino library for DAC8554 SPI Digital Analog Convertor.
2021-01-29 12:31:58 +01:00
2020-11-27 11:10:47 +01:00
## Description
2021-01-29 12:31:58 +01:00
The DAC8554 is a SPI based 16 bit DAC with four channels.
2021-08-30 14:09:24 +02:00
**Warning** This library is not tested extensively
2021-01-29 12:31:58 +01:00
## Interface
2023-10-19 15:28:53 +02:00
```cpp
#include "DAC8554.h"
```
2021-01-29 12:31:58 +01:00
### Core
- **DAC8554(uint8_t slaveSelect, uint8_t address = 0)** Constructor for hardware SPI,
since 0.2.0 the slaveSelect pin needs to be defined.
2021-12-15 14:57:49 +01:00
- **DAC8554(uint8_t spiData, uint8_t spiClock, uint8_t slaveSelect, uint8_t address = 0)**
Constructor for the software SPI
2021-01-29 12:31:58 +01:00
- **void begin()** initializes all pins to default state
- **void setValue(uint8_t channel, uint16_t value)** set the value of the channel to 0 - 65535
2021-12-15 14:57:49 +01:00
- **void setSingleValue(uint8_t channel, uint16_t value)** writes the value to the channel but
does not affect buffered ones. TODO - elaborate.
2021-01-29 12:31:58 +01:00
- **uint16_t getValue(uint8_t channel)** returns the last value written.
2021-08-30 14:09:24 +02:00
### Hardware SPI
To be used only if one needs a specific speed.
- **void setSPIspeed(uint32_t speed)** set SPI transfer rate.
- **uint32_t getSPIspeed()** returns SPI transfer rate.
- **bool usesHWSPI()** returns true if HW SPI is used.
### ESP32 specific
- **void selectHSPI()** in case hardware SPI, the ESP32 has two options HSPI and VSPI.
- **void selectVSPI()** see above.
- **bool usesHSPI()** returns true if HSPI is used.
- **bool usesVSPI()** returns true if VSPI is used.
The **selectVSPI()** or the **selectHSPI()** needs to be called
BEFORE the **begin()** function.
2023-10-19 15:28:53 +02:00
#### Experimental
2021-08-30 14:09:24 +02:00
2021-12-15 14:57:49 +01:00
- **void setGPIOpins(uint8_t clk, uint8_t miso, uint8_t mosi, uint8_t select)**
overrule GPIO pins of ESP32 for hardware SPI.
Needs to be called AFTER the **begin()** function.
2021-08-30 14:09:24 +02:00
2021-01-29 12:31:58 +01:00
### Power down
2021-08-30 14:09:24 +02:00
Check datasheet for details.
2021-01-29 12:31:58 +01:00
- **void setPowerDown(uint8_t powerDownMode)** sets power down mode. 0 - 3.
- **uint8_t getPowerDownMode()** returns last written mode.
- **void setSinglePowerDown(uint8_t channel, uint8_t powerDownMode)** does not affect other channels.
2021-08-30 14:09:24 +02:00
| Power down mode | Value |
|:----------------------------|:-----:|
| DAC8554_POWERDOWN_NORMAL | 0x00 |
| DAC8554_POWERDOWN_1K | 0x40 |
| DAC8554_POWERDOWN_100K | 0x80 |
| DAC8554_POWERDOWN_HIGH_IMP | 0xC0 |
2021-01-29 12:31:58 +01:00
### Broadcast
- **void bufferValue(uint8_t channel, uint16_t value)** prepare a new value for a channel.
2021-12-15 14:57:49 +01:00
- **void broadcastBuffer()** write all buffers to all(up to 4) 8554's channel's.
- **void broadcastValue(uint16_t value)** write value to all(up to 4) 8554's channel's.
- **void broadcastPowerDown(uint8_t powerDownMode)** write powerDownMode to all 8554's channel's.
2021-08-30 14:09:24 +02:00
2020-11-27 11:10:47 +01:00
## Operation
See examples
**demo_hw_spi.ino**
2021-01-29 12:31:58 +01:00
- write a sawtooth to channel A followed by a sinus
- uses HW SPI
2020-11-27 11:10:47 +01:00
**demo_sw_spi.ino**
2021-01-29 12:31:58 +01:00
- write a sawtooth to channel A followed by a sinus
- uses SW SPI
2020-11-27 11:10:47 +01:00
**demo_same_time_write.ino**
2021-01-29 12:31:58 +01:00
- writes two square waves that trigger at the same time
2020-11-27 11:10:47 +01:00
**demo_sequential_write.ino**
2021-01-29 12:31:58 +01:00
- writes two square waves sequentially (slight time difference)
2020-11-27 11:10:47 +01:00
**demo_powerdown.ino**
2021-01-29 12:31:58 +01:00
- idem
2020-11-27 11:10:47 +01:00
2021-12-15 14:57:49 +01:00
## Future
2023-10-19 15:28:53 +02:00
#### Must
- improve documentation
- testing with hardware
#### Should
#### Could
- performance measurements
#### 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.
2021-12-15 14:57:49 +01:00
2023-10-19 15:28:53 +02:00
Thank you,