2013-04-05 23:46:56 +03:00
|
|
|
/**
|
|
|
|
******************************************************************************
|
|
|
|
*
|
2013-05-19 17:37:30 +03:00
|
|
|
* @file pios_sdcard.c
|
2013-04-05 23:46:56 +03:00
|
|
|
* @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2010.
|
2013-05-19 17:37:30 +03:00
|
|
|
* Parts by Thorsten Klose (tk@midibox.org)
|
2013-04-05 23:46:56 +03:00
|
|
|
* @brief Sets up basic system hardware, functions are called from Main.
|
|
|
|
* @see The GNU Public License (GPL) Version 3
|
|
|
|
* @defgroup PIOS_SDCARD SDCard Functions
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
*****************************************************************************/
|
2013-05-19 17:37:30 +03:00
|
|
|
/*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 3 of the License, or
|
2013-04-05 23:46:56 +03:00
|
|
|
* (at your option) any later version.
|
2013-05-19 17:37:30 +03:00
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful, but
|
|
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
|
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
2013-04-05 23:46:56 +03:00
|
|
|
* for more details.
|
2013-05-19 17:37:30 +03:00
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License along
|
|
|
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
2013-04-05 23:46:56 +03:00
|
|
|
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/* Project Includes */
|
|
|
|
#include "pios.h"
|
|
|
|
|
|
|
|
#if defined(PIOS_INCLUDE_SDCARD)
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2013-05-19 17:37:30 +03:00
|
|
|
* Initialises SPI pins and peripheral to access MMC/SD Card
|
|
|
|
* \param[in] mode currently only mode 0 supported
|
|
|
|
* \return < 0 if initialisation failed
|
|
|
|
*/
|
2013-04-05 23:46:56 +03:00
|
|
|
int32_t PIOS_SDCARD_Init(uint32_t spi_id)
|
|
|
|
{
|
2013-05-19 17:37:30 +03:00
|
|
|
/* No error */
|
|
|
|
return 0;
|
2013-04-05 23:46:56 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2013-05-19 17:37:30 +03:00
|
|
|
* Connects to SD Card
|
|
|
|
* \return < 0 if initialisation sequence failed
|
|
|
|
*/
|
2013-04-05 23:46:56 +03:00
|
|
|
int32_t PIOS_SDCARD_PowerOn(void)
|
|
|
|
{
|
2013-05-19 17:37:30 +03:00
|
|
|
return 0; /* Status should be 0 if nothing went wrong! */
|
2013-04-05 23:46:56 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2013-05-19 17:37:30 +03:00
|
|
|
* Disconnects from SD Card
|
|
|
|
* \return < 0 on errors
|
|
|
|
*/
|
2013-04-05 23:46:56 +03:00
|
|
|
int32_t PIOS_SDCARD_PowerOff(void)
|
|
|
|
{
|
2013-05-19 17:37:30 +03:00
|
|
|
return 0; // no error
|
2013-04-05 23:46:56 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2013-05-19 17:37:30 +03:00
|
|
|
* If SD card was previously available: Checks if the SD Card is still
|
|
|
|
* available by sending the STATUS command.<BR>
|
|
|
|
* This takes ca. 10 uS
|
|
|
|
*
|
|
|
|
* If SD card was previously not available: Checks if the SD Card is
|
|
|
|
* available by sending the IDLE command at low speed.<BR>
|
|
|
|
* This takes ca. 500 uS!<BR>
|
|
|
|
* Once we got a positive response, SDCARD_PowerOn() will be
|
|
|
|
* called by this function to initialize the card completely.
|
|
|
|
*
|
|
|
|
* Example for Connection/Disconnection detection:
|
|
|
|
* \code
|
|
|
|
* // this function is called each second from a low-priority task
|
|
|
|
* // If multiple tasks are accessing the SD card, add a semaphore/mutex
|
|
|
|
* // to avoid IO access collisions with other tasks!
|
|
|
|
* u8 sdcard_available;
|
|
|
|
* int32_t CheckSDCard(void)
|
|
|
|
* {
|
|
|
|
* // check if SD card is available
|
|
|
|
* // High speed access if the card was previously available
|
|
|
|
* u8 prev_sdcard_available = sdcard_available;
|
|
|
|
* sdcard_available = PIOS_SDCARD_CheckAvailable(prev_sdcard_available);
|
|
|
|
*
|
|
|
|
* if(sdcard_available && !prev_sdcard_available) {
|
|
|
|
* // SD Card has been connected
|
|
|
|
*
|
|
|
|
* // now it's possible to read/write sectors
|
|
|
|
*
|
|
|
|
* } else if( !sdcard_available && prev_sdcard_available ) {
|
|
|
|
* // SD Card has been disconnected
|
|
|
|
*
|
|
|
|
* // here you can notify your application about this state
|
|
|
|
* }
|
|
|
|
*
|
|
|
|
* return 0; // no error
|
|
|
|
* }
|
|
|
|
* \endcode
|
|
|
|
* \param[in] was_available should only be set if the SD card was previously available
|
|
|
|
* \return 0 if no response from SD Card
|
|
|
|
* \return 1 if SD card is accessible
|
|
|
|
*/
|
2013-04-05 23:46:56 +03:00
|
|
|
int32_t PIOS_SDCARD_CheckAvailable(uint8_t was_available)
|
|
|
|
{
|
2013-05-19 17:37:30 +03:00
|
|
|
return 1; /* 1 = available, 0 = not available. */
|
2013-04-05 23:46:56 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2013-05-19 17:37:30 +03:00
|
|
|
* Sends command to SD card
|
|
|
|
* \param[in] cmd SD card command
|
|
|
|
* \param[in] addr 32bit address
|
|
|
|
* \param[in] crc precalculated CRC
|
|
|
|
* \return >= 0x00 if command has been sent successfully (contains received byte)
|
|
|
|
* \return -1 if no response from SD Card (timeout)
|
|
|
|
*/
|
2013-04-05 23:46:56 +03:00
|
|
|
int32_t PIOS_SDCARD_SendSDCCmd(uint8_t cmd, uint32_t addr, uint8_t crc)
|
|
|
|
{
|
2013-05-19 17:37:30 +03:00
|
|
|
return -1;
|
2013-04-05 23:46:56 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2013-05-19 17:37:30 +03:00
|
|
|
* Reads 512 bytes from selected sector
|
|
|
|
* \param[in] sector 32bit sector
|
|
|
|
* \param[in] *buffer pointer to 512 byte buffer
|
|
|
|
* \return 0 if whole sector has been successfully read
|
|
|
|
* \return -error if error occured during read operation:<BR>
|
|
|
|
* <UL>
|
|
|
|
* <LI>Bit 0 - In idle state if 1
|
|
|
|
* <LI>Bit 1 - Erase Reset if 1
|
|
|
|
* <LI>Bit 2 - Illgal Command if 1
|
|
|
|
* <LI>Bit 3 - Com CRC Error if 1
|
|
|
|
* <LI>Bit 4 - Erase Sequence Error if 1
|
|
|
|
* <LI>Bit 5 - Address Error if 1
|
|
|
|
* <LI>Bit 6 - Parameter Error if 1
|
|
|
|
* <LI>Bit 7 - Not used, always '0'
|
|
|
|
* </UL>
|
|
|
|
* \return -256 if timeout during command has been sent
|
|
|
|
* \return -257 if timeout while waiting for start token
|
|
|
|
*/
|
2013-04-05 23:46:56 +03:00
|
|
|
int32_t PIOS_SDCARD_SectorRead(uint32_t sector, uint8_t *buffer)
|
|
|
|
{
|
2013-05-19 17:37:30 +03:00
|
|
|
return -256;
|
2013-04-05 23:46:56 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2013-05-19 17:37:30 +03:00
|
|
|
* Writes 512 bytes into selected sector
|
|
|
|
* \param[in] sector 32bit sector
|
|
|
|
* \param[in] *buffer pointer to 512 byte buffer
|
|
|
|
* \return 0 if whole sector has been successfully read
|
|
|
|
* \return -error if error occured during read operation:<BR>
|
|
|
|
* <UL>
|
|
|
|
* <LI>Bit 0 - In idle state if 1
|
|
|
|
* <LI>Bit 1 - Erase Reset if 1
|
|
|
|
* <LI>Bit 2 - Illgal Command if 1
|
|
|
|
* <LI>Bit 3 - Com CRC Error if 1
|
|
|
|
* <LI>Bit 4 - Erase Sequence Error if 1
|
|
|
|
* <LI>Bit 5 - Address Error if 1
|
|
|
|
* <LI>Bit 6 - Parameter Error if 1
|
|
|
|
* <LI>Bit 7 - Not used, always '0'
|
|
|
|
* </UL>
|
|
|
|
* \return -256 if timeout during command has been sent
|
|
|
|
* \return -257 if write operation not accepted
|
|
|
|
* \return -258 if timeout during write operation
|
|
|
|
*/
|
2013-04-05 23:46:56 +03:00
|
|
|
int32_t PIOS_SDCARD_SectorWrite(uint32_t sector, uint8_t *buffer)
|
|
|
|
{
|
2013-05-19 17:37:30 +03:00
|
|
|
return -256;
|
2013-04-05 23:46:56 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2013-05-19 17:37:30 +03:00
|
|
|
* Reads the CID informations from SD Card
|
|
|
|
* \param[in] *cid pointer to buffer which holds the CID informations
|
|
|
|
* \return 0 if the informations haven been successfully read
|
|
|
|
* \return -error if error occured during read operation
|
|
|
|
* \return -256 if timeout during command has been sent
|
|
|
|
* \return -257 if timeout while waiting for start token
|
|
|
|
*/
|
2013-04-05 23:46:56 +03:00
|
|
|
int32_t PIOS_SDCARD_CIDRead(SDCARDCidTypeDef *cid)
|
|
|
|
{
|
2013-05-19 17:37:30 +03:00
|
|
|
return -256;
|
2013-04-05 23:46:56 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2013-05-19 17:37:30 +03:00
|
|
|
* Reads the CSD informations from SD Card
|
|
|
|
* \param[in] *csd pointer to buffer which holds the CSD informations
|
|
|
|
* \return 0 if the informations haven been successfully read
|
|
|
|
* \return -error if error occured during read operation
|
|
|
|
* \return -256 if timeout during command has been sent
|
|
|
|
* \return -257 if timeout while waiting for start token
|
|
|
|
*/
|
2013-04-05 23:46:56 +03:00
|
|
|
int32_t PIOS_SDCARD_CSDRead(SDCARDCsdTypeDef *csd)
|
|
|
|
{
|
2013-05-19 17:37:30 +03:00
|
|
|
return -256;
|
2013-04-05 23:46:56 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2013-05-19 17:37:30 +03:00
|
|
|
* Attempts to write a startup log to the SDCard
|
|
|
|
* return 0 No errors
|
|
|
|
* return -1 Error deleting file
|
|
|
|
* return -2 Error opening file
|
|
|
|
* return -3 Error writing file
|
|
|
|
*/
|
2013-04-05 23:46:56 +03:00
|
|
|
int32_t PIOS_SDCARD_StartupLog(void)
|
|
|
|
{
|
2013-05-19 17:37:30 +03:00
|
|
|
return -3;
|
2013-04-05 23:46:56 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Check if the SD card has been mounted
|
|
|
|
* @return 0 if no
|
|
|
|
* @return 1 if yes
|
|
|
|
*/
|
|
|
|
int32_t PIOS_SDCARD_IsMounted()
|
|
|
|
{
|
2013-05-19 17:37:30 +03:00
|
|
|
return 1;
|
2013-04-05 23:46:56 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2013-05-19 17:37:30 +03:00
|
|
|
* Mounts the file system
|
|
|
|
* param[in] CreateStartupLog 1 = True, 0 = False
|
|
|
|
* return 0 No errors
|
|
|
|
* return -1 SDCard not available
|
|
|
|
* return -2 Cannot find first partition
|
|
|
|
* return -3 No volume information
|
|
|
|
* return -4 Error writing startup log file
|
|
|
|
*/
|
2013-04-05 23:46:56 +03:00
|
|
|
int32_t PIOS_SDCARD_MountFS(uint32_t CreateStartupLog)
|
|
|
|
{
|
2013-05-19 17:37:30 +03:00
|
|
|
return 0;
|
2013-04-05 23:46:56 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2013-05-19 17:37:30 +03:00
|
|
|
* Mounts the file system
|
|
|
|
* return Amount of free bytes
|
|
|
|
*/
|
2013-04-05 23:46:56 +03:00
|
|
|
int32_t PIOS_SDCARD_GetFree(void)
|
|
|
|
{
|
2013-05-19 17:37:30 +03:00
|
|
|
return 10240;
|
2013-04-05 23:46:56 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2013-05-19 17:37:30 +03:00
|
|
|
* Read from file
|
|
|
|
* return 0 No error
|
|
|
|
* return -1 DFS_ReadFile failed
|
|
|
|
* return -2 Less bytes read than expected
|
|
|
|
*/
|
|
|
|
// int32_t PIOS_SDCARD_ReadBuffer(PFILEINFO fileinfo, uint8_t *buffer, uint32_t len)
|
|
|
|
// {
|
|
|
|
/* No error */
|
|
|
|
// return -1;
|
|
|
|
// }
|
2013-04-05 23:46:56 +03:00
|
|
|
|
|
|
|
/**
|
2013-05-19 17:37:30 +03:00
|
|
|
* Read a line from file
|
|
|
|
* returns Number of bytes read
|
|
|
|
*/
|
|
|
|
// int32_t PIOS_SDCARD_ReadLine(PFILEINFO fileinfo, uint8_t *buffer, uint32_t max_len)
|
|
|
|
// {
|
|
|
|
// return -1;
|
|
|
|
// }
|
2013-04-05 23:46:56 +03:00
|
|
|
|
|
|
|
/**
|
2013-05-19 17:37:30 +03:00
|
|
|
* Copy a file
|
|
|
|
* WARNING: This will overwrite the destination file even if it exists
|
|
|
|
* param[in] *Source Path to file to copy
|
|
|
|
* param[in] *Destination Path to destination file
|
|
|
|
* return 0 No errors
|
|
|
|
* return -1 Source file doesn't exist
|
|
|
|
* return -2 Failed to create destination file
|
|
|
|
* return -3 DFS_ReadFile failed
|
|
|
|
* return -4 DFS_WriteFile failed
|
|
|
|
*/
|
2013-04-05 23:46:56 +03:00
|
|
|
int32_t PIOS_SDCARD_FileCopy(char *Source, char *Destination)
|
|
|
|
{
|
2013-05-19 17:37:30 +03:00
|
|
|
return -2;
|
2013-04-05 23:46:56 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2013-05-19 17:37:30 +03:00
|
|
|
* Delete a file
|
|
|
|
* param[in] *Filename File to delete
|
|
|
|
* return 0 No errors
|
|
|
|
* return -1 Error deleting file
|
|
|
|
*/
|
2013-04-05 23:46:56 +03:00
|
|
|
int32_t PIOS_SDCARD_FileDelete(char *Filename)
|
|
|
|
{
|
2013-05-19 17:37:30 +03:00
|
|
|
return -1;
|
2013-04-05 23:46:56 +03:00
|
|
|
}
|
|
|
|
|
2013-05-19 17:37:30 +03:00
|
|
|
#endif /* if defined(PIOS_INCLUDE_SDCARD) */
|