1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/drivers/dfplayer/include/dfplayer_constants.h
2020-06-28 21:06:43 +02:00

190 lines
8.8 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 Constants used in the DFPlayer Mini Driver
*
* @author Marian Buschsieweke <marian.buschsieweke@ovgu.de>
*/
#ifndef DFPLAYER_CONSTANTS_H
#define DFPLAYER_CONSTANTS_H
#include <stdint.h>
#include <periph/gpio.h>
#include <mutex.h>
#ifdef __cplusplus
extern "C" {
#endif
/**
* @name Constants used in frames send to the DFPlayer Mini
*/
#define DFPLAYER_START (0x7e) /**< Start symbol */
#define DFPLAYER_VERSION (0xff) /**< Value to use in version field */
#define DFPLAYER_LEN (0x06) /**< Length of a frame */
#define DFPLAYER_NO_ACK (0x00) /**< No acknowledgement of CMD required */
#define DFPLAYER_ACK (0x01) /**< Acknowledgement of CMD required */
#define DFPLAYER_END (0xef) /**< End symbol */
/** @} */
/**
* @name UART settings of the DFPlayer Mini
*/
#define DFPLAYER_BAUD (9600) /**< Symbol rate of the DFPlayer mini */
#define DFPLAYER_DATA_BITS (UART_DATA_BITS_8) /**< The DFPlayer uses 8 data bits */
#define DFPLAYER_PARITY (UART_PARITY_NONE) /**< The DFPlayer does not use a parity bit */
#define DFPLAYER_STOP_BITS (UART_STOP_BITS_1) /**< The DFPlayer uses 1 stop bit */
/** @} */
/**
* @name Commands supported by the DFPlayer Mini
*/
#define DFPLAYER_CMD_NEXT (0x01) /**< Start playing the next song */
#define DFPLAYER_CMD_PREV (0x02) /**< Start playing the next song */
#define DFPLAYER_CMD_VOLUME_INC (0x04) /**< Increase volume */
#define DFPLAYER_CMD_VOLUME_DEC (0x05) /**< Decrease volume */
#define DFPLAYER_CMD_SET_VOLUME (0x06) /**< Set the volume to the given level */
#define DFPLAYER_CMD_SET_EQUALIZER (0x07) /**< Set the equalizer to the given setting */
#define DFPLAYER_CMD_SET_SOURCE (0x09) /**< Set the source to play files from */
#define DFPLAYER_CMD_STANDBY_ENTER (0x0a) /**< Enter low power mode */
#define DFPLAYER_CMD_STANDBY_EXIT (0x0b) /**< Exit low power mode, back to normal mode */
#define DFPLAYER_CMD_RESET (0x0c) /**< Reset the DFPlayer Mini */
#define DFPLAYER_CMD_PLAY (0x0d) /**< Start playing the selected file */
#define DFPLAYER_CMD_PAUSE (0x0e) /**< Pause the playback */
#define DFPLAYER_CMD_FILE (0x0f) /**< Play the given file */
#define DFPLAYER_CMD_PLAY_FROM_MP3 (0x12) /**< Play the given file (1-9999) from the folder `"MP3"` */
#define DFPLAYER_CMD_PLAY_ADVERT (0x13) /**< Play the given file (1-9999) from the folder `"ADVERT"`, resume current playback afterwards */
#define DFPLAYER_CMD_ABORT_ADVERT (0x15) /**< Play the given file (1-9999) from the folder `"ADVERT"`, resume current playback afterwards */
#define DFPLAYER_CMD_REPEAT_FOLDER (0x17) /**< Start repeat-playing the given folder (1-99) */
#define DFPLAYER_CMD_RANDOM (0x18) /**< Start playing all files in random order */
#define DFPLAYER_CMD_REPEAT (0x19) /**< 0 = repeat currently played file, 1 = stop repeating */
#define DFPLAYER_CMD_GET_STATUS (0x42) /**< Retrieve the current status */
#define DFPLAYER_CMD_GET_VOLUME (0x43) /**< Retrieve the current volume */
#define DFPLAYER_CMD_GET_EQUALIZER (0x44) /**< Retrieve the current equalizer setting */
#define DFPLAYER_CMD_GET_MODE (0x45) /**< Retrieve the current playback mode */
#define DFPLAYER_CMD_GET_VERSION (0x46) /**< Retrieve the device's software version */
#define DFPLAYER_CMD_FILES_USB (0x47) /**< Get the total number of files on USB storage */
#define DFPLAYER_CMD_FILES_SDCARD (0x48) /**< Get the total number of files on the SD card */
#define DFPLAYER_CMD_FILES_FLASH (0x49) /**< Get the total number of files on NOR flash */
#define DFPLAYER_CMD_FILENO_USB (0x4b) /**< Get the currently select file number on the USB storage */
#define DFPLAYER_CMD_FILENO_SDCARD (0x4c) /**< Get the currently select file number on the SD-Card */
#define DFPLAYER_CMD_FILENO_FLASH (0x4d) /**< Get the currently select file number on the NOR flash */
/** @} */
/**
* @name Classes of messages received from the DFPlayer
*/
#define DFPLAYER_CLASS_MASK (0xf0) /**< Use this mask to get the class from a response code */
#define DFPLAYER_CLASS_NOTIFY (0x30) /**< Message is an event notification (unrelated to any command) */
#define DFPLAYER_CLASS_RESPONSE (0x40) /**< Message is a response to the most recent command */
/** @} */
/**
* @name Notification codes send by the DFPlayer Mini
*/
#define DFPLAYER_NOTIFY_INSERT (0x3a) /**< A USB storage device or an SD card was inserted */
#define DFPLAYER_NOTIFY_EJECT (0x3b) /**< A USB storage device or an SD card was ejected */
#define DFPLAYER_NOTIFY_DONE_USB (0x3c) /**< Completed playing the indicated track from USB storage */
#define DFPLAYER_NOTIFY_DONE_SDCARD (0x3d) /**< Completed playing the indicated track from SD card */
#define DFPLAYER_NOTIFY_DONE_FLASH (0x3e) /**< Completed playing the indicated track from flash */
/**
* @brief The DFPlayer is ready
*
* This notification is send after boot/reset when the DFPlayer Mini has become
* ready. As additional info the 4 least significant bits indicate which
* playback sources are available.
*/
#define DFPLAYER_NOTIFY_READY (0x3f)
/** @} */
/**
* @name Bitmasks identifying the playback sources in the ready notification
*/
#define DFPLAYER_MASK_USB (0x01) /**< USB stick is connected */
#define DFPLAYER_MASK_SDCARD (0x02) /**< SD-Card is connected */
#define DFPLAYER_MASK_PC (0x04) /**< Unclear, has something to do with debugging */
#define DFPLAYER_MASK_FLASH (0x08) /**< NOR flash is connected */
/** @} */
/**
* @name Response codes codes send by the DFPlayer Mini
*/
#define DFPLAYER_RESPONSE_ERROR (0x40) /**< While processing the most recent command an error occurred */
#define DFPLAYER_RESPONSE_OK (0x41) /**< Last command succeeded */
/* Beware: Handle every code of class response (0x4*) that does not indicate
* an error (0x40) as success */
/** @} */
/**
* @name Error codes send as parameter of error messages
*/
#define DFPLAYER_ERROR_BUSY (0x00) /**< Module is busy */
#define DFPLAYER_ERROR_FRAME (0x01) /**< Received incomplete frame */
#define DFPLAYER_ERROR_FCS (0x02) /**< Frame check sequence of last frame didn't match */
/**
* @brief File/folder selected for playback (command 0x06) does not exit
*
* Beware: The DFPlayer Mini will acknowledge the command 0x06 first blindly,
* and send a second acknowledgement when the file exists (0x41), or an error
* (0x40) if not.
*/
#define DFPLAYER_ERROR_NO_SUCH_FILE (0x06)
/** @} */
/**
* @name Device identifiers in insert/eject notifications
*/
#define DFPLAYER_DEVICE_USB (0x01) /**< A USB storage device was inserted/ejected */
#define DFPLAYER_DEVICE_SDCARD (0x02) /**< An SD card was inserted/ejected */
/** @} */
/**
* @name Status bitmasks
*
* These values have been obtained by reverse engineering.
*/
#define DFPLAYER_STATUS_PLAYING (0x01) /**< The DFPlayer is currently playing a song */
#define DFPLAYER_STATUS_PAUSE (0x02) /**< The DFPlayer is paused */
/** @} */
/**
* @name Flags to store info about the driver state
*/
/**
* @brief The next command will be affected by the no-ACK bug
*
* After playback of a file completed, the next command does not get ack'ed by
* the device. Any subsequent command is however normally ack'ed. Luckily,
* query commands (0x40 and higher) are not affected. The driver works around
* this issue by querying the volume prior to sending a control command when
* this flag is set
*/
#define DFPLAYER_FLAG_NO_ACK_BUG (0x01)
/** @} */
#define DFPLAYER_BOOTUP_TIME_MS (3000) /**< Boot up of the device takes 1.5 to 3 secs */
#define DFPLAYER_TIMEOUT_MS (100) /**< Timeout waiting for a replay in milliseconds */
#define DFPLAYER_SEND_DELAY_MS (100) /**< Wait 100ms after a cmd to work around hw bug */
#ifndef DFPLAYER_RETRIES
#define DFPLAYER_RETRIES (5) /**< How often to retry a command on timeout */
#endif /* DFPLAYER_RETRIES */
#define DFPLAYER_MAX_VOLUME (30) /**< Maximum supported volume */
#define DFPLAYER_MAX_FOLDER (99) /**< Highest supported folder number */
#define DFPLAYER_MAX_MP3_FILE (9999) /**< Highest supported file number in the `"MP3"` folder */
#define DFPLAYER_MAX_ADVERT_FILE (9999) /**< Highest supported file number in the `"ADVERT"` folder */
#define DFPLAYER_LOWEST_QUERY (0x40) /**< Query commands are 0x40 or higher */
#endif /* DFPLAYER_CONSTANTS_H */
/** @} */