|
|
2 mesi fa | |
|---|---|---|
| .. | ||
| .github | 2 mesi fa | |
| examples | 2 mesi fa | |
| src | 2 mesi fa | |
| .gitattributes | 2 mesi fa | |
| .piopm | 2 mesi fa | |
| LICENSE | 2 mesi fa | |
| README.md | 2 mesi fa | |
| README_EN.md | 2 mesi fa | |
| keywords.txt | 2 mesi fa | |
| library.properties | 2 mesi fa | |
Быстрые функции для работы с пинами AVR (полный список смотри в gio_avr.h), ESP8266, ESP32
| Версия | Частота | |
|---|---|---|
| AVR | 1.8.19 | 16 |
| ESP8266 | 3.1.2 | 80 |
| ESP32 | 2.0.11 | 240 |
| ESP32C3 | 2.0.11 | 80 |
| write NC | write | read NC | read | mode NC | mode | |
|---|---|---|---|---|---|---|
| AVR Ardu | 5.3 | 5.3 | 4.8 | 4.8 | 3.3 | 3.3 |
| AVR gio | 1.6 | 0.125 | 1.75 | 0.075 | 1.8 | 0.125 |
| ESP8266 Ardu | 1.5 | 1.5 | 0.54 | 0.54 | 1.4 | 1.4 |
| ESP8266 gio | 0.29 | 0.08 | 0.5 | 0.17 | 1.29 | 0.58 |
| ESP32 Ardu | 0.33 | 0.33 | 0.124 | 0.124 | 16 | 16 |
| ESP32 gio | 0.04 | 0.04 | 0.085 | 0.085 | 0.126 | 0.08 |
| ESP32C3 Ardu | 0.91 | 0.91 | 0.25 | 0.25 | 21 | 21 |
| ESP32C3 gio | 0.05 | 0.05 | 0.4 | 0.08 | 0.49 | 0.08 |
NC - пины не константы
Жирным выделено худшее время (Arduino не константы), жирным курсивом - лучшее (gio константы)
| shiftOut | gio::shift | |
|---|---|---|
| AVR NC | 0.06 | 0.66 |
| AVR | 0.06 | 1.3 |
| ESP8266 | 0.2 | 1.1 |
| ESP32 | 0.96 | 6 |
| ESP32C3 | 0.35 | 2.6 |
NC - пины не константы
Совместима со всеми Arduino платформами (используются Arduino-функции)
pinMode() (mode()) работает только на режимы INPUT/OUTPUT! В остальных режимах вызывается штатный pinMode()Быстые функции для работы с пинами
int gio::read(int P);
void gio::high(int P);
void gio::low(int P)
void gio::write(int P, int V);
//
void gio::toggle(int P);
// режим пина. Для esp8266/esp32 только INPUT/OUTPUT!
void gio::mode(int P, int V);
// нужно вызывать для esp8266/esp32 при инициализации пина
// иначе mode() не будет работать!
void gio::init(int P);
У esp8266/esp32 нужно обязательно вызвать
gio::initперед использованием!
Быстрый аналог shiftIn/shiftOut (отправка данных с клоком)
// прочитать пакет. Вернёт true, если хотя бы один бит отличается
bool gio::shift::read(uint8_t dat_pin, uint8_t clk_pin, uint8_t order, uint8_t* data, uint16_t len, uint8_t delay = 0);
// прочитать байт
uint8_t gio::shift::read_byte(uint8_t dat_pin, uint8_t clk_pin, uint8_t order, uint8_t delay = 0);
// прочитать пакет + cs пин. Вернёт true, если хотя бы один бит отличается
bool gio::shift::read_cs(uint8_t dat_pin, uint8_t clk_pin, uint8_t cs_pin, uint8_t order, uint8_t* data, uint16_t len, uint8_t delay = 0);
// прочитать байт + cs пин
uint8_t gio::shift::read_cs_byte(uint8_t dat_pin, uint8_t clk_pin, uint8_t cs_pin, uint8_t order, uint8_t delay = 0);
// отправить пакет
void gio::shift::send(uint8_t dat_pin, uint8_t clk_pin, uint8_t order, uint8_t* data, uint16_t len, uint8_t delay = 0);
// отправить байт
void gio::shift::send_byte(uint8_t dat_pin, uint8_t clk_pin, uint8_t order, uint8_t data, uint8_t delay = 0);
// отправить пакет + cs пин
void gio::shift::send_cs(uint8_t dat_pin, uint8_t clk_pin, uint8_t cs_pin, uint8_t order, uint8_t* data, uint16_t len, uint8_t delay = 0);
// отправить байт + cs пин
void gio::shift::send_cs_byte(uint8_t dat_pin, uint8_t clk_pin, uint8_t cs_pin, uint8_t order, uint8_t data, uint8_t delay = 0);
Параметр order может быть:
LSBFIRST/LSB_NORMAL - LSB, прямой порядок байтовMSBFIRST/MSB_NORMAL - MSB, прямой порядок байтовLSB_REVERSE - LSB, обратный порядок байтовMSB_REVERSE - MSB, обратный порядок байтовdelay в микросекундах, позволяет уменьшить скорость передачи. Например 1 мкс ограничит скорость до ~1 МГц, 2 мкс до ~500 кГцOUTPUT самостоятельно до отправки (при запуске программы например)Универсальный класс программно-аппаратного SPI с оптимизацией количества переменных для пинов
SSPI<0, freq> spi; // аппаратный без пина CS
SSPI<0, freq, cs> spi; // аппаратный с пином CS в шаблоне
SSPI<0, freq> spi(cs); // аппаратный с пином CS в классе
SSPI<1, freq, cs, dt, clk> spi; // программный с пинами в шаблоне
SSPI<1, freq> spi(cs, dt, clk); // программный с пинами в классе
#define GIO_USE_ARDUINO // отключить быстрые функции (заменить на стандартные)
#define GIO_NO_MASK // отключить быстрый IO на основе маски для AVR (в классе PinIO и всех shift)
#include <GyverIO_SPI.h>
gio::write(3, 1); // включить пин 3
// отправить данные по пинам 3 и 4
uint8_t data[] = {34, 63, 231, 9};
gio::shift::send(3, 4, MSBFIRST, data, 4);
SSPI<0, f, cs> spi;
spi.send(0x12);
Читай более подробную инструкцию по установке библиотек здесь
Рекомендую всегда обновлять библиотеку: в новых версиях исправляются ошибки и баги, а также проводится оптимизация и добавляются новые фичи
Через менеджер библиотек IDE: найти библиотеку как при установке и нажать "Обновить"
Вручную: удалить папку со старой версией, а затем положить на её место новую. "Замену" делать нельзя: иногда в новых версиях удаляются файлы, которые останутся при замене и могут привести к ошибкам!
При нахождении багов создавайте Issue, а лучше сразу пишите на почту alex@alexgyver.ru
Библиотека открыта для доработки и ваших Pull Request'ов!
При сообщении о багах или некорректной работе библиотеки нужно обязательно указывать: