mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
215 lines
7.9 KiB
C
215 lines
7.9 KiB
C
/*
|
|
* Copyright 2019 Marian Buschsieweke
|
|
*
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
* directory for more details.
|
|
*/
|
|
|
|
/**
|
|
* @ingroup drivers_dfplayer
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief Internal functions of DFPlayer Mini Device driver
|
|
* @author Marian Buschsieweke <marian.buschsieweke@ovgu.de>
|
|
*/
|
|
|
|
#ifndef DFPLAYER_INTERNAL_H
|
|
#define DFPLAYER_INTERNAL_H
|
|
|
|
#include <stdint.h>
|
|
|
|
#include "dfplayer_types.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* @brief Exchange a frame with the DFPlayer Mini
|
|
*
|
|
* @param dev Device descriptor of the DFPlayer to control
|
|
* @param resp On success the response info is stored if `resp != NULL`
|
|
* @param cmd Command to send
|
|
* @param p1 First parameter to send
|
|
* @param p2 Second parameter to send
|
|
*
|
|
* @retval 0 Success
|
|
* @retval -EINVAL Called with invalid argument
|
|
* @retval -EAGAIN Device responded with error busy
|
|
* @retval -EIO Communication error
|
|
* @retval -ETIMEDOUT Reply from the DFPlayer timed out
|
|
*
|
|
* The frame format of the DFPlayer Mini is this:
|
|
*
|
|
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
*
|
|
* 0 1
|
|
* 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5
|
|
* +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|
|
* | Start | Version |
|
|
* +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|
|
* | Length | Command/Code |
|
|
* +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|
|
* | Feedback | Parameter 1 |
|
|
* +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|
|
* | Parameter 2 | FCS (MSB) |
|
|
* +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|
|
* | FCS (LSB) | Stop |
|
|
* +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|
|
*
|
|
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
*
|
|
* These are the values of the fields when **sending** a frame to the DFPlayer
|
|
*
|
|
* | Field | Value |
|
|
* |:-------------- |:------------------------------------------------------------- |
|
|
* | Start | `0x7e` |
|
|
* | Version | `0xff` |
|
|
* | Length | Length of the data (always 6) |
|
|
* | Command/Code | Command to send |
|
|
* | Feedback | `0x01` if device should acknowledge command, `0x00` otherwise |
|
|
* | Parameter 1 | First parameter of the command, or `0x00` |
|
|
* | Parameter 2 | Second parameter of the command, or `0x00` |
|
|
* | FCS | Frame check sequence, `0 - sum(data)` |
|
|
* | Stop | `0xef` |
|
|
*
|
|
* These are the values of the fields when **receiving** a frame from the DFPlayer
|
|
*
|
|
* | Field | Value |
|
|
* |:-------------- |:------------------------------------------------------------- |
|
|
* | Start | `0x7e` |
|
|
* | Version | `0xff` |
|
|
* | Length | Length of the data (always 6) |
|
|
* | Command/Code | Response code (0x41 = success, 0x40 = error, 0x3* = event) |
|
|
* | Feedback | `0x00` |
|
|
* | Parameter 1 | Additional info (most significant byte) |
|
|
* | Parameter 2 | Additional info (least significant byte) |
|
|
* | FCS | Frame check sequence, `0 - sum(data)` |
|
|
* | Stop | `0xef` |
|
|
*
|
|
*/
|
|
int dfplayer_transceive(dfplayer_t *dev, uint16_t *resp,
|
|
uint8_t cmd, uint8_t p1, uint8_t p2);
|
|
|
|
/**
|
|
* @brief Send a command selecting a playback file
|
|
*
|
|
* @param dev Device descriptor of the DFPlayer to control
|
|
* @param cmd Command starting playback of a file
|
|
* @param p1 First parameter to send
|
|
* @param p2 Second parameter to send
|
|
*
|
|
* @retval 0 Success
|
|
* @retval -EINVAL Called with invalid argument
|
|
* @retval -EAGAIN Device responded with error busy
|
|
* @retval -EIO Communication error
|
|
* @retval -ETIMEDOUT Reply from the DFPlayer timed out
|
|
* @retval -ENOENT No such file found
|
|
*
|
|
* @warning In contrast to all other functions in this header, this command
|
|
* does not lock and unlock the mutex in `dev->mutex` internally, but
|
|
* leaves this to the caller. This is required to do the booking of
|
|
* the currently played file consistent with the device state, even if
|
|
* multiple threads control the same DFPlayer.
|
|
*/
|
|
int dfplayer_file_cmd(dfplayer_t *dev, uint8_t cmd, uint8_t p1, uint8_t p2);
|
|
|
|
/**
|
|
* @brief Reset the DFPlayer Mini MP3 player
|
|
*
|
|
* @param dev Device to reset
|
|
*
|
|
* @retval 0 Success
|
|
* @retval -EINVAL Called with invalid argument
|
|
* @retval -EAGAIN Device responded with error busy
|
|
* @retval -EIO Communication error
|
|
* @retval -ETIMEDOUT Reply from the DFPlayer timed out
|
|
*/
|
|
int dfplayer_reset(dfplayer_t *dev);
|
|
|
|
/**
|
|
* @brief UART-ISR handler of the DFPLayer driver
|
|
*
|
|
* @param dev DFPlayer device descriptor for which a byte was received
|
|
* @param data The byte received over UART
|
|
*/
|
|
void dfplayer_uart_rx_cb(void *dev, uint8_t data);
|
|
|
|
/**
|
|
* @brief Send a command with two parameters to the DFPlayer Mini
|
|
*
|
|
* @param dev Device descriptor of the DFPlayer to control
|
|
* @param cmd Command to send
|
|
* @param p1 First parameter to send
|
|
* @param p2 Second parameter to send
|
|
*
|
|
* @retval 0 Success
|
|
* @retval -EAGAIN Device responded with error busy
|
|
* @retval -EIO Communication error
|
|
* @retval -ETIMEDOUT Reply from the DFPlayer timed out
|
|
*/
|
|
static inline int dfplayer_cmd_2param(dfplayer_t *dev, uint8_t cmd,
|
|
uint8_t p1, uint8_t p2)
|
|
{
|
|
return dfplayer_transceive(dev, NULL, cmd, p1, p2);
|
|
}
|
|
|
|
/**
|
|
* @brief Send a command with one parameter to the DFPlayer Mini
|
|
*
|
|
* @param dev Device descriptor of the DFPlayer to control
|
|
* @param cmd Command to send
|
|
* @param param The parameter to send
|
|
*
|
|
* @retval 0 Success
|
|
* @retval -EAGAIN Device responded with error busy
|
|
* @retval -EIO Communication error
|
|
* @retval -ETIMEDOUT Reply from the DFPlayer timed out
|
|
*/
|
|
static inline int dfplayer_cmd_1param(dfplayer_t *dev, uint8_t cmd, uint8_t param)
|
|
{
|
|
return dfplayer_transceive(dev, NULL, cmd, 0, param);
|
|
}
|
|
|
|
/**
|
|
* @brief Send a command without parameters to the DFPlayer Mini
|
|
*
|
|
* @param dev Device descriptor of the DFPlayer to control
|
|
* @param cmd Command to send
|
|
*
|
|
* @retval 0 Success
|
|
* @retval -EAGAIN Device responded with error busy
|
|
* @retval -EIO Communication error
|
|
* @retval -ETIMEDOUT Reply from the DFPlayer timed out
|
|
*/
|
|
static inline int dfplayer_cmd(dfplayer_t *dev, uint8_t cmd)
|
|
{
|
|
return dfplayer_transceive(dev, NULL, cmd, 0, 0);
|
|
}
|
|
|
|
/**
|
|
* @brief Send a query and receive the response
|
|
*
|
|
* @param dev Device descriptor of the DFPlayer to control
|
|
* @param resp The response code will be stored here
|
|
* @param cmd Query-command to send
|
|
*
|
|
* @retval 0 Success
|
|
* @retval -EAGAIN Device responded with error busy
|
|
* @retval -EIO Communication error
|
|
* @retval -ETIMEDOUT Reply from the DFPlayer timed out
|
|
*/
|
|
static inline int dfplayer_query(dfplayer_t *dev, uint16_t *resp, uint8_t cmd)
|
|
{
|
|
return dfplayer_transceive(dev, resp, cmd, 0, 0);
|
|
}
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* DFPLAYER_INTERNAL_H */
|
|
/** @} */
|