aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--testhal/ATSAMA5D2/SDMMC/Makefile10
-rw-r--r--testhal/ATSAMA5D2/SDMMC/chconf.h2
-rw-r--r--testhal/ATSAMA5D2/SDMMC/main.c3
-rw-r--r--testhal/ATSAMA5D2/SDMMC/reledgetest.c304
4 files changed, 163 insertions, 156 deletions
diff --git a/testhal/ATSAMA5D2/SDMMC/Makefile b/testhal/ATSAMA5D2/SDMMC/Makefile
index 69264a063..1a69f01f9 100644
--- a/testhal/ATSAMA5D2/SDMMC/Makefile
+++ b/testhal/ATSAMA5D2/SDMMC/Makefile
@@ -131,18 +131,24 @@ include $(CHIBIOS)/os/common/ports/ARMCAx-TZ/compilers/GCC/mk/port_generic.mk
#include $(CHIBIOS)/test/rt/rt_test.mk
#include $(CHIBIOS)/test/oslib/oslib_test.mk
include $(CHIBIOS)/os/various/reledge_bindings/reledge.mk
-include $(CHIBIOS)/os/various/fatfs_bindings/fatfs.mk
+#include $(CHIBIOS)/os/various/fatfs_bindings/fatfs.mk
include $(CHIBIOS)/os/hal/lib/streams/streams.mk
# Define linker script file here
#LDSCRIPT= $(STARTUPLD)/SAMA5D2.ld
LDSCRIPT= $(STARTUPLD)/SAMA5D2ddr.ld
+FATFSINC = $(CHIBIOS)/ext/fatfs/src
# C sources that can be compiled in ARM or THUMB mode depending on the global
# setting.
-CSRC = $(ALLCSRC) /os/various/syscalls.c \
+CSRC = $(ALLCSRC) \
main.c fat32test.c reledgetest.c redconf.c
+CSRC += $(CHIBIOS)/os/various/syscalls.c
+CSRC += $(CHIBIOS)/os/various/fatfs_bindings/fatfs_syscall.c
+CSRC += $(CHIBIOS)/ext/fatfs/src/ff.c
+CSRC += $(CHIBIOS)/ext/fatfs/src/ffunicode.c
+
# C++ sources that can be compiled in ARM or THUMB mode depending on the global
# setting.
CPPSRC = $(ALLCPPSRC)
diff --git a/testhal/ATSAMA5D2/SDMMC/chconf.h b/testhal/ATSAMA5D2/SDMMC/chconf.h
index 3ab41afae..875a46084 100644
--- a/testhal/ATSAMA5D2/SDMMC/chconf.h
+++ b/testhal/ATSAMA5D2/SDMMC/chconf.h
@@ -419,7 +419,7 @@
*
* @note The default is @p FALSE.
*/
-#define CH_DBG_ENABLE_ASSERTS FALSE
+#define CH_DBG_ENABLE_ASSERTS TRUE
/**
* @brief Debug option, trace buffer.
diff --git a/testhal/ATSAMA5D2/SDMMC/main.c b/testhal/ATSAMA5D2/SDMMC/main.c
index 2f2e99061..0030167c5 100644
--- a/testhal/ATSAMA5D2/SDMMC/main.c
+++ b/testhal/ATSAMA5D2/SDMMC/main.c
@@ -25,7 +25,7 @@
//0 (SLOT0) or 1 (SLOT1)
#define DEMO_SLOT 0
//1 for FFLib, 0 for Reliance
-#define DEMO_FAT 1
+#define DEMO_FAT 0
//----------------------------------------------------------
#define BLOCK_CNT_MAX 32u
@@ -157,6 +157,7 @@ bool sdmmcGetInstance(uint8_t index, SdmmcDriver **sdmmcp)
(void)index;
*sdmmcp = &SDMMCD1;
+ read();
return true;
}
diff --git a/testhal/ATSAMA5D2/SDMMC/reledgetest.c b/testhal/ATSAMA5D2/SDMMC/reledgetest.c
index 2fb743113..a374c8b98 100644
--- a/testhal/ATSAMA5D2/SDMMC/reledgetest.c
+++ b/testhal/ATSAMA5D2/SDMMC/reledgetest.c
@@ -42,227 +42,227 @@ extern const VOLCONF gaRedVolConf[REDCONF_VOLUME_COUNT];
void relianceedge_demo(void)
{
- int32_t ret;
- int volnum = 0;
- const char *pszVolume = gaRedVolConf[volnum].pszPathPrefix;
-
- chprintf(ts,"Init Reliance Edge FS\r\n" );
- ret = red_init();
-
- chprintf(ts,"Start formatting fs ... " );
- ret = format(volnum);
-
- if ( ret == 0 )
- {
- chprintf(ts,"OK , mounting volume .." );
-
- ret = red_mount(pszVolume);
- if ( ret == 0 )
- {
- chprintf(ts,"OK\r\n writing files ..\r\n" );
- writefiles(volnum);
- chprintf(ts,"OK\r\n reading files ..\r\n" );
- readfiles();
- chprintf(ts,"OK\r\n" );
- }
- }
- else
- {
- chprintf(ts,"FAILED! \r\n" );
- }
+ int32_t ret;
+ int volnum = 0;
+ const char *pszVolume = gaRedVolConf[volnum].pszPathPrefix;
+
+ chprintf(ts,"Init Reliance Edge FS\r\n" );
+ ret = red_init();
+
+ chprintf(ts,"Start formatting fs ... " );
+ ret = format(volnum);
+
+ if ( ret == 0 )
+ {
+ chprintf(ts,"OK , mounting volume .." );
+
+ ret = red_mount(pszVolume);
+ if ( ret == 0 )
+ {
+ chprintf(ts,"OK\r\n writing files ..\r\n" );
+ writefiles(volnum);
+ chprintf(ts,"OK\r\n reading files ..\r\n" );
+ readfiles();
+ chprintf(ts,"OK\r\n" );
+ }
+ }
+ else
+ {
+ chprintf(ts,"FAILED! \r\n" );
+ }
}
static void writefiles(uint8_t volnum)
{
- uint32_t i, j;
- char path[ 64 ];
- const uint32_t filen = 5;
+ uint32_t i, j;
+ char path[ 64 ];
+ const uint32_t filen = 5;
- uint32_t ulEventMask;
- int32_t written, filedescr, status;
- int iByte;
+ uint32_t ulEventMask;
+ int32_t written, filedescr, status;
+ int iByte;
- const char *pszVolume = gaRedVolConf[volnum].pszPathPrefix;
- /* Save the current transaction point settings. */
- status = red_gettransmask( pszVolume, &ulEventMask );
- osalDbgCheck( status == 0 );
+ const char *pszVolume = gaRedVolConf[volnum].pszPathPrefix;
+ /* Save the current transaction point settings. */
+ status = red_gettransmask( pszVolume, &ulEventMask );
+ osalDbgCheck( status == 0 );
- /* Disable automatic transaction points so that all of the files can be
+ /* Disable automatic transaction points so that all of the files can be
created in one atomic operation. */
- status = red_settransmask( pszVolume, RED_TRANSACT_MANUAL );
- osalDbgCheck( status == 0 );
+ status = red_settransmask( pszVolume, RED_TRANSACT_MANUAL );
+ osalDbgCheck( status == 0 );
- /* Create filen files. Each created file will be
+ /* Create filen files. Each created file will be
( i * fsRAM_BUFFER_SIZE ) bytes in length, and filled
with a different repeating character. */
- for( i = 1; i <= filen; i++ )
- {
- /* Generate a file name. */
- sprintf( path, "/root%03d.txt", (int)i );
+ for( i = 1; i <= filen; i++ )
+ {
+ /* Generate a file name. */
+ sprintf( path, "/root%03d.txt", (int)i );
- /* Print out the file name and the directory into which the file is
+ /* Print out the file name and the directory into which the file is
being written. */
- chprintf(ts,"Creating file %s\r\n", path );
+ chprintf(ts,"Creating file %s\r\n", path );
- /* Open the file, creating the file if it does not already exist. */
- filedescr = red_open( path, RED_O_CREAT|RED_O_TRUNC|RED_O_WRONLY );
- osalDbgCheck( filedescr != -1 );
+ /* Open the file, creating the file if it does not already exist. */
+ filedescr = red_open( path, RED_O_CREAT|RED_O_TRUNC|RED_O_WRONLY );
+ osalDbgCheck( filedescr != -1 );
- /* Fill the RAM buffer with data that will be written to the file. This
+ /* Fill the RAM buffer with data that will be written to the file. This
is just a repeating ascii character that indicates the file number. */
- memset( cRAMBuffer, ( int ) ( '0' + i ), fsRAM_BUFFER_SIZE );
+ memset( cRAMBuffer, ( int ) ( '0' + i ), fsRAM_BUFFER_SIZE );
- /* Write the RAM buffer to the opened file a number of times. The
+ /* Write the RAM buffer to the opened file a number of times. The
number of times the RAM buffer is written to the file depends on the
file number, so the length of each created file will be different. */
- for( j = 0; j < i; j++ )
- {
- written = red_write( filedescr, cRAMBuffer, fsRAM_BUFFER_SIZE );
- osalDbgCheck( written == fsRAM_BUFFER_SIZE );
- }
-
- /* Close the file so another file can be created. */
- status = red_close( filedescr );
- osalDbgCheck( status == 0 );
- }
-
- /* Commit a transaction point, atomically adding the set of files to the
+ for( j = 0; j < i; j++ )
+ {
+ written = red_write( filedescr, cRAMBuffer, fsRAM_BUFFER_SIZE );
+ osalDbgCheck( written == fsRAM_BUFFER_SIZE );
+ }
+
+ /* Close the file so another file can be created. */
+ status = red_close( filedescr );
+ osalDbgCheck( status == 0 );
+ }
+
+ /* Commit a transaction point, atomically adding the set of files to the
transacted state. */
- status = red_transact( pszVolume );
- osalDbgCheck( status == 0 );
+ status = red_transact( pszVolume );
+ osalDbgCheck( status == 0 );
- /* Create a sub directory. */
- chprintf(ts,"Creating directory %s\r\n", pcDirectory1 );
+ /* Create a sub directory. */
+ chprintf(ts,"Creating directory %s\r\n", pcDirectory1 );
- status = red_mkdir( pcDirectory1 );
- osalDbgCheck( status == 0 );
+ status = red_mkdir( pcDirectory1 );
+ osalDbgCheck( status == 0 );
- /* Create a subdirectory in the new directory. */
- chprintf(ts, "Creating directory %s\r\n", pcDirectory2 );
+ /* Create a subdirectory in the new directory. */
+ chprintf(ts, "Creating directory %s\r\n", pcDirectory2 );
- status = red_mkdir( pcDirectory2 );
- osalDbgCheck( status == 0 );
+ status = red_mkdir( pcDirectory2 );
+ osalDbgCheck( status == 0 );
- /* Generate the file name. */
- sprintf( path, "%s/file.txt", pcDirectory2 );
+ /* Generate the file name. */
+ sprintf( path, "%s/file.txt", pcDirectory2 );
- /* Print out the file name and the directory into which the file is being
+ /* Print out the file name and the directory into which the file is being
written. */
- chprintf(ts, "Writing file %s\r\n", path );
+ chprintf(ts, "Writing file %s\r\n", path );
- filedescr = red_open( path, RED_O_CREAT|RED_O_TRUNC|RED_O_WRONLY );
+ filedescr = red_open( path, RED_O_CREAT|RED_O_TRUNC|RED_O_WRONLY );
- /* Write the file. It is filled with incrementing ascii characters starting
+ /* Write the file. It is filled with incrementing ascii characters starting
from '0'. */
- for( iByte = 0; iByte < fsRAM_BUFFER_SIZE; iByte++ )
- {
- cRAMBuffer[ iByte ] = ( char ) ( ( int ) '0' + iByte );
- }
+ for( iByte = 0; iByte < fsRAM_BUFFER_SIZE; iByte++ )
+ {
+ cRAMBuffer[ iByte ] = ( char ) ( ( int ) '0' + iByte );
+ }
- written = red_write( filedescr, cRAMBuffer, fsRAM_BUFFER_SIZE );
- osalDbgCheck( written == fsRAM_BUFFER_SIZE );
+ written = red_write( filedescr, cRAMBuffer, fsRAM_BUFFER_SIZE );
+ osalDbgCheck( written == fsRAM_BUFFER_SIZE );
- /* Finished so close the file. */
- status = red_close( filedescr );
- osalDbgCheck( status == 0 );
+ /* Finished so close the file. */
+ status = red_close( filedescr );
+ osalDbgCheck( status == 0 );
- /* Commit a transaction point, atomically adding the set of files and
+ /* Commit a transaction point, atomically adding the set of files and
directories to the transacted state. */
- status = red_transact( pszVolume );
- osalDbgCheck( status == 0 );
+ status = red_transact( pszVolume );
+ osalDbgCheck( status == 0 );
- /* Restore previous transaction point settings. */
- status = red_settransmask( pszVolume, ulEventMask );
- osalDbgCheck( status == 0 );
+ /* Restore previous transaction point settings. */
+ status = red_settransmask( pszVolume, ulEventMask );
+ osalDbgCheck( status == 0 );
}
static void readfiles(void)
{
- uint32_t i, j;
- char path[ 64 ];
- const uint32_t filen = 5;
- long lChar;
- int32_t lBytesRead, filedescr, status;
- int iByte;
+ uint32_t i, j;
+ char path[ 64 ];
+ const uint32_t filen = 5;
+ long lChar;
+ int32_t lBytesRead, filedescr, status;
+ int iByte;
- /* Read back the files that were created by prvCreateDemoFiles(). */
- for( i = 1; i <= filen; i++ )
- {
- /* Generate the file name. */
- sprintf( path, "/root%03d.txt",(int) i );
+ /* Read back the files that were created by prvCreateDemoFiles(). */
+ for( i = 1; i <= filen; i++ )
+ {
+ /* Generate the file name. */
+ sprintf( path, "/root%03d.txt",(int) i );
- /* Print out the file name and the directory from which the file is
+ /* Print out the file name and the directory from which the file is
being read. */
- chprintf(ts,"Reading file %s\r\n", path );
+ chprintf(ts,"Reading file %s\r\n", path );
- /* Open the file for reading. */
- filedescr = red_open( path, RED_O_RDONLY );
- osalDbgCheck( filedescr != -1 );
+ /* Open the file for reading. */
+ filedescr = red_open( path, RED_O_RDONLY );
+ osalDbgCheck( filedescr != -1 );
- /* Read the file into the RAM buffer, checking the file contents are as
+ /* Read the file into the RAM buffer, checking the file contents are as
expected. The size of the file depends on the file number. */
- for( j = 0; j < i; j++ )
- {
- /* Start with the RAM buffer clear. */
- memset( cRAMBuffer, 0x00, fsRAM_BUFFER_SIZE );
+ for( j = 0; j < i; j++ )
+ {
+ /* Start with the RAM buffer clear. */
+ memset( cRAMBuffer, 0x00, fsRAM_BUFFER_SIZE );
- lBytesRead = red_read( filedescr, cRAMBuffer, fsRAM_BUFFER_SIZE );
- osalDbgCheck( lBytesRead == fsRAM_BUFFER_SIZE );
+ lBytesRead = red_read( filedescr, cRAMBuffer, fsRAM_BUFFER_SIZE );
+ osalDbgCheck( lBytesRead == fsRAM_BUFFER_SIZE );
- /* Check the RAM buffer is filled with the expected data. Each
+ /* Check the RAM buffer is filled with the expected data. Each
file contains a different repeating ascii character that indicates
the number of the file. */
- for( lChar = 0; lChar < fsRAM_BUFFER_SIZE; lChar++ )
- {
- osalDbgCheck( cRAMBuffer[ lChar ] == ( '0' + ( char ) i ) );
- }
- }
+ for( lChar = 0; lChar < fsRAM_BUFFER_SIZE; lChar++ )
+ {
+ osalDbgCheck( cRAMBuffer[ lChar ] == ( '0' + ( char ) i ) );
+ }
+ }
- /* Close the file. */
- status = red_close( filedescr );
- osalDbgCheck( status == 0 );
- }
+ /* Close the file. */
+ status = red_close( filedescr );
+ osalDbgCheck( status == 0 );
+ }
- /* Generate the file name. */
- sprintf( path, "%s/file.txt", pcDirectory2 );
+ /* Generate the file name. */
+ sprintf( path, "%s/file.txt", pcDirectory2 );
- /* Print out the file name and the directory from which the file is being
+ /* Print out the file name and the directory from which the file is being
read. */
- chprintf(ts, "Reading file %s\r\n", path );
+ chprintf(ts, "Reading file %s\r\n", path );
- /* This time the file is opened for reading. */
- filedescr = red_open( path, RED_O_RDONLY );
- osalDbgCheck( filedescr != -1 );
+ /* This time the file is opened for reading. */
+ filedescr = red_open( path, RED_O_RDONLY );
+ osalDbgCheck( filedescr != -1 );
- /* Read the file. */
- lBytesRead = red_read( filedescr, cRAMBuffer, fsRAM_BUFFER_SIZE );
- osalDbgCheck( lBytesRead == fsRAM_BUFFER_SIZE );
+ /* Read the file. */
+ lBytesRead = red_read( filedescr, cRAMBuffer, fsRAM_BUFFER_SIZE );
+ osalDbgCheck( lBytesRead == fsRAM_BUFFER_SIZE );
- /* Verify the file 1 byte at a time. */
- for( iByte = 0; iByte < fsRAM_BUFFER_SIZE; iByte++ )
- {
- osalDbgCheck( cRAMBuffer[ iByte ] == ( char ) ( ( int ) '0' + iByte ) );
- }
+ /* Verify the file 1 byte at a time. */
+ for( iByte = 0; iByte < fsRAM_BUFFER_SIZE; iByte++ )
+ {
+ osalDbgCheck( cRAMBuffer[ iByte ] == ( char ) ( ( int ) '0' + iByte ) );
+ }
- /* Finished so close the file. */
- status = red_close( filedescr );
- osalDbgCheck( status == 0 );
+ /* Finished so close the file. */
+ status = red_close( filedescr );
+ osalDbgCheck( status == 0 );
}
static int32_t format(uint8_t volnum)
{
- int32_t ret=-1;
+ int32_t ret=-1;
#if REDCONF_API_POSIX_FORMAT == 1
- const char *pszVolume = gaRedVolConf[volnum].pszPathPrefix;
- ret = red_format(pszVolume);
+ const char *pszVolume = gaRedVolConf[volnum].pszPathPrefix;
+ ret = red_format(pszVolume);
#endif
- return ret;
+ return ret;
}
#endif