/**
******************************************************************************
* @file : ShiftRegGPIOXpander_Example01.cpp
* @brief : Code example of the use of the ShiftRegGPIOXpander_ESP32 library
*
* Repository: https://github.com/GabyGold67/ShiftRegGPIOXpander_ESP32
*
* Framework: Arduino
* Platform: ESP32
*
* @author : Gabriel D. Goldman
*
* mail <gdgoldman67@hotmail.com>
* Github <https://github.com/GabyGold67>
*
* @date First release: 16/02/2025
* Last update: 02/04/2025 13:50 GMT+0200 DST
******************************************************************************
* @warning **Use of this library is under your own responsibility**
*
* @warning The use of this library falls in the category described by The Alan
* Parsons Project (c) 1980 "Games People play":
*
* Games people play, you take it or you leave it
* Things that they say aren't alright
* If I promised you the moon and the stars, would you believe it?
*
* Released into the public domain in accordance with "GPL-3.0-or-later" license terms.
******************************************************************************
*/
#include <Arduino.h>
#include <ShiftRegGPIOXpander.h>
//==============================================>> General use definitions BEGIN
#define LoopDlyTtlTm 1500 // Time between task unblocking, time taken from the start of the task execution to the next execution
#define MainCtrlTskPrrtyLvl 5 // Task priority level
static BaseType_t xReturned; /*!<Static variable to keep returning result value from Tasks and Timers executions*/
static BaseType_t errorFlag {pdFALSE};
BaseType_t ssdExecTskCore = xPortGetCoreID();
BaseType_t ssdExecTskPrrtyCnfg = MainCtrlTskPrrtyLvl;
//================================================>> General use definitions END
//======================================>> General use function prototypes BEGIN
void Error_Handler();
//========================================>> General use function prototypes END
//====================================>> Task Callback function prototypes BEGIN
void mainCtrlTsk(void *pvParameters);
//======================================>> Task Callback function prototypes END
//===========================================>> Tasks Handles declarations BEGIN
TaskHandle_t mainCtrlTskHndl {NULL};
//=============================================>> Tasks Handles declarations END
void setup() {
// Create the Main control task for setup and execution of the main code
xReturned = xTaskCreatePinnedToCore(
mainCtrlTsk, // Callback function/task to be called
"MainControlTask", // Name of the task
2048, // Stack size (in bytes in ESP32, words in FreeRTOS), the minimum value is in the config file, for this is 768 bytes
NULL, // Pointer to the parameters for the function to work with
ssdExecTskPrrtyCnfg, // Priority level given to the task
&mainCtrlTskHndl, // Task handle
ssdExecTskCore // Run in the App Core if it's a dual core mcu (ESP-FreeRTOS specific)
);
if(xReturned != pdPASS)
Error_Handler();
}
void loop() {
vTaskDelete(NULL); // Delete this task -the ESP-Arduino LoopTask()- and remove it from the execution list
}
//===============================>> User Tasks Implementations BEGIN
void mainCtrlTsk(void *pvParameters){
delay(10); //FTPO Part of the WOKWI simulator additions, for simulation startup needs
TickType_t loopTmrStrtTm{0};
TickType_t* loopTmrStrtTmPtr{&loopTmrStrtTm};
TickType_t totalDelay {LoopDlyTtlTm};
uint8_t ds{33};
uint8_t sh_cp{26};
uint8_t st_cp{25};
uint8_t srQty{1};
uint8_t strtngVals [1] {0xFF};
uint8_t* stVlsPtr = strtngVals;
ShiftRegGPIOXpander srgx(ds, sh_cp, st_cp, srQty, stVlsPtr);
uint8_t pinUpdtd{0};
uint8_t setVal{HIGH};
for(;;){
srgx.digitalWriteSr(pinUpdtd, setVal);
vTaskDelay(1000);
pinUpdtd++;
if(pinUpdtd > srgx.getMaxPin()){
pinUpdtd = 0;
if(setVal == HIGH)
setVal = LOW;
else
setVal = HIGH;
}
}
}
//================================================>> General use functions BEGIN
//==================================================>> General use functions END
//=======================================>> User Functions Implementations BEGIN
/**
* @brief Error Handling function
*
* Placeholder for a Error Handling function, in case of an error the execution
* will be trapped in this endless loop
*/
void Error_Handler(){
for(;;)
{
}
return;
}
//=========================================>> User Functions Implementations END
esp:0
esp:2
esp:4
esp:5
esp:12
esp:13
esp:14
esp:15
esp:16
esp:17
esp:18
esp:19
esp:21
esp:22
esp:23
esp:25
esp:26
esp:27
esp:32
esp:33
esp:34
esp:35
esp:3V3
esp:EN
esp:VP
esp:VN
esp:GND.1
esp:D2
esp:D3
esp:CMD
esp:5V
esp:GND.2
esp:TX
esp:RX
esp:GND.3
esp:D1
esp:D0
esp:CLK
r20:1
r20:2
r21:1
r21:2
r22:1
r22:2
r23:1
r23:2
r24:1
r24:2
r25:1
r25:2
r26:1
r26:2
r27:1
r27:2
vcc3:VCC
sr4:Q1
sr4:Q2
sr4:Q3
sr4:Q4
sr4:Q5
sr4:Q6
sr4:Q7
sr4:GND
sr4:Q7S
sr4:MR
sr4:SHCP
sr4:STCP
sr4:OE
sr4:DS
sr4:Q0
sr4:VCC
led2:A
led2:C
led4:A
led4:C
led5:A
led5:C
led7:A
led7:C
led8:A
led8:C
led9:A
led9:C
led10:A
led10:C
led11:A
led11:C
DS
STCP
SHCP
GND
R00 - b00~07