Sync with sample stuffing (#69)
* upgrade to IDF v5.1.1
* add new synchronization implementation, use sample stuffing / removal to keep up sync
* use big DMA buffer for I2S and improve sync
* Add DAC TAS5805M as custom board
* add wifi credential reset
o press reset button (nRESET pin) 3 times
but wait about 1s between button presses
the button press counter is reset 5s after boot
* Add support for PT8211 DAC (#78)
* upgrade ethernet interface to IDF v5 (#84)
* port official example of ethernet for IDF v5.x
* Fix cmake if guard for ethernet
Signed-off-by: Karl Osterseher <karli_o@gmx.at>
Co-authored-by: DerPicknicker <64746593+DerPicknicker@users.noreply.github.com>
Co-authored-by: whc2001 <ianwang0122@outlook.com>
This commit is contained in:
committed by
GitHub
Unverified
parent
fd701a1ead
commit
fae271186c
@@ -6,10 +6,10 @@
|
||||
* Permission is hereby granted for use on all ESPRESSIF SYSTEMS products, in
|
||||
* which case, it is free of charge, to any person obtaining a copy of this
|
||||
* software and associated documentation files (the "Software"), to deal in the
|
||||
* Software without restriction, including without limitation the rights to
|
||||
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
* copies of the Software, and to permit persons to whom the Software is
|
||||
* furnished to do so, subject to the following conditions:
|
||||
* Software without restriction, including without limitation the rights to use,
|
||||
* copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||
* the Software, and to permit persons to whom the Software is furnished to do
|
||||
* so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in
|
||||
* all copies or substantial portions of the Software.
|
||||
@@ -18,69 +18,61 @@
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
|
||||
* IN THE SOFTWARE.
|
||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
* SOFTWARE.
|
||||
*
|
||||
*/
|
||||
|
||||
#ifndef _PERIPH_CONSOLE_H_
|
||||
#define _PERIPH_CONSOLE_H_
|
||||
|
||||
#include "audio_error.h"
|
||||
#include "esp_peripherals.h"
|
||||
#include "sys/queue.h"
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C"
|
||||
{
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
typedef esp_err_t (*console_cmd_callback_t) (esp_periph_handle_t periph,
|
||||
int argc, char *argv[]);
|
||||
typedef esp_err_t (*console_cmd_callback_t)(esp_periph_handle_t periph,
|
||||
int argc, char *argv[]);
|
||||
|
||||
#define CONSOLE_DEFAULT_TASK_PRIO (5)
|
||||
#define CONSOLE_DEFAULT_TASK_STACK (1024 * 5)
|
||||
#define CONSOLE_DEFAULT_BUFFER_SIZE (256)
|
||||
#define CONSOLE_DEFAULT_PROMPT_STRING "esp32>"
|
||||
|
||||
/**
|
||||
* @brief Command structure
|
||||
*/
|
||||
typedef struct
|
||||
{
|
||||
const char *cmd; /*!< Name of command, must be unique */
|
||||
int id; /*!< Command ID will be sent together when the command is matched
|
||||
*/
|
||||
const char *help; /*!< Explanation of the command */
|
||||
console_cmd_callback_t func; /*!< Function callback for the command */
|
||||
} periph_console_cmd_t;
|
||||
/**
|
||||
* @brief Command structure
|
||||
*/
|
||||
typedef struct {
|
||||
const char *cmd; /*!< Name of command, must be unique */
|
||||
int id; /*!< Command ID will be sent together when the command is matched */
|
||||
const char *help; /*!< Explanation of the command */
|
||||
console_cmd_callback_t func; /*!< Function callback for the command */
|
||||
} periph_console_cmd_t;
|
||||
|
||||
/**
|
||||
* @brief Console Peripheral configuration
|
||||
*/
|
||||
typedef struct
|
||||
{
|
||||
int command_num; /*!< Total number of commands */
|
||||
const periph_console_cmd_t *commands; /*!< Pointer to array of commands */
|
||||
int task_stack; /*!< Console task stack, using default if the value is zero
|
||||
*/
|
||||
int task_prio; /*!< Console task priority (based on freeRTOS priority),
|
||||
using default if the value is zero */
|
||||
int buffer_size; /*!< Size of console input buffer */
|
||||
const char
|
||||
*prompt_string; /*!< Console prompt string, using default
|
||||
CONSOLE_PROMPT_STRING if the pointer is NULL */
|
||||
} periph_console_cfg_t;
|
||||
/**
|
||||
* @brief Console Peripheral configuration
|
||||
*/
|
||||
typedef struct {
|
||||
int command_num; /*!< Total number of commands */
|
||||
const periph_console_cmd_t *commands; /*!< Pointer to array of commands */
|
||||
int task_stack; /*!< Console task stack, using default if the value is zero */
|
||||
int task_prio; /*!< Console task priority (based on freeRTOS priority), using
|
||||
default if the value is zero */
|
||||
int buffer_size; /*!< Size of console input buffer */
|
||||
const char *prompt_string; /*!< Console prompt string, using default
|
||||
CONSOLE_PROMPT_STRING if the pointer is NULL */
|
||||
} periph_console_cfg_t;
|
||||
|
||||
/**
|
||||
* @brief Initialize Console Peripheral
|
||||
*
|
||||
* @param config The configuration
|
||||
*
|
||||
* @return The esp peripheral handle
|
||||
*/
|
||||
esp_periph_handle_t periph_console_init (periph_console_cfg_t *config);
|
||||
/**
|
||||
* @brief Initialize Console Peripheral
|
||||
*
|
||||
* @param config The configuration
|
||||
*
|
||||
* @return The esp peripheral handle
|
||||
*/
|
||||
esp_periph_handle_t periph_console_init(periph_console_cfg_t *config);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user