yaffs Fixed some tests in direct/timothy_tests/quick_tests
[yaffs2.git] / direct / basic-test / yaffscfg2k.c
index 4aa97a3d4a2d6013e29cd050533b1be13af5151a..f83aad11e69ad789879193823c9ded641de5aa71 100644 (file)
@@ -25,6 +25,7 @@
 #include "yaffs_nandemul2k.h"
 #include "yaffs_norif1.h"
 #include "yaffs_trace.h"
+#include "yaffs_osglue.h"
 
 
 #include <errno.h>
@@ -43,61 +44,6 @@ unsigned yaffs_trace_mask =
        0;
         
 
-static int yaffsfs_lastError;
-
-void yaffsfs_SetError(int err)
-{
-       //Do whatever to set error
-       yaffsfs_lastError = err;
-}
-
-
-int yaffsfs_GetLastError(void)
-{
-       return yaffsfs_lastError;
-}
-
-void yaffsfs_Lock(void)
-{
-}
-
-void yaffsfs_Unlock(void)
-{
-}
-
-__u32 yaffsfs_CurrentTime(void)
-{
-       return 0;
-}
-
-
-static int yaffs_kill_alloc = 0;
-static size_t total_malloced = 0;
-static size_t malloc_limit = 0 & 6000000;
-
-void *yaffs_malloc(size_t size)
-{
-       void * this;
-       if(yaffs_kill_alloc)
-               return NULL;
-       if(malloc_limit && malloc_limit <(total_malloced + size) )
-               return NULL;
-
-       this = malloc(size);
-       if(this)
-               total_malloced += size;
-       return this;
-}
-
-void yaffs_free(void *ptr)
-{
-       free(ptr);
-}
-
-void yaffsfs_LocalInitialisation(void)
-{
-       // Define locking semaphore.
-}
 
 // Configuration
 
@@ -106,53 +52,53 @@ void yaffsfs_LocalInitialisation(void)
 #include "yaffs_flashif2.h"
 #include "yaffs_nandemul2k.h"
 
-struct yaffs_DeviceStruct ram1Dev;
-struct yaffs_DeviceStruct flashDev;
-struct yaffs_DeviceStruct m18_1Dev;
+struct yaffs_dev ram1Dev;
+struct yaffs_dev flashDev;
+struct yaffs_dev m18_1Dev;
 
 int yaffs_start_up(void)
 {
        // Stuff to configure YAFFS
        // Stuff to initialise anything special (eg lock semaphore).
-       yaffsfs_LocalInitialisation();
+       yaffsfs_OSInitialisation();
        
        // Set up devices
        // /ram1   ram, yaffs1
        memset(&ram1Dev,0,sizeof(ram1Dev));
        ram1Dev.param.name = "ram1";
-       ram1Dev.param.totalBytesPerChunk = 512;
-       ram1Dev.param.nChunksPerBlock = 32;
-       ram1Dev.param.nReservedBlocks = 2; // Set this smaller for RAM
-       ram1Dev.param.startBlock = 0; // Can use block 0
-       ram1Dev.param.endBlock = 127; // Last block in 2MB.     
-       //ram1Dev.param.useNANDECC = 1;
-       ram1Dev.param.nShortOpCaches = 0;       // Disable caching on this device.
-       ram1Dev.driverContext = (void *) 0;     // Used to identify the device in fstat.
-       ram1Dev.param.writeChunkWithTagsToNAND = yramdisk_WriteChunkWithTagsToNAND;
-       ram1Dev.param.readChunkWithTagsFromNAND = yramdisk_ReadChunkWithTagsFromNAND;
-       ram1Dev.param.eraseBlockInNAND = yramdisk_EraseBlockInNAND;
-       ram1Dev.param.initialiseNAND = yramdisk_InitialiseNAND;
+       ram1Dev.param.total_bytes_per_chunk = 512;
+       ram1Dev.param.chunks_per_block = 32;
+       ram1Dev.param.n_reserved_blocks = 2; // Set this smaller for RAM
+       ram1Dev.param.start_block = 0; // Can use block 0
+       ram1Dev.param.end_block = 127; // Last block in 2MB.    
+       //ram1Dev.param.use_nand_ecc = 1;
+       ram1Dev.param.n_caches = 0;     // Disable caching on this device.
+       ram1Dev.driver_context = (void *) 0;    // Used to identify the device in fstat.
+       ram1Dev.param.write_chunk_tags_fn = yramdisk_wr_chunk;
+       ram1Dev.param.read_chunk_tags_fn = yramdisk_rd_chunk;
+       ram1Dev.param.erase_fn = yramdisk_erase;
+       ram1Dev.param.initialise_flash_fn = yramdisk_initialise;
        
        yaffs_add_device(&ram1Dev);
 
        // /M18-1 yaffs1 on M18 nor sim
        memset(&m18_1Dev,0,sizeof(m18_1Dev));
        m18_1Dev.param.name = "M18-1";
-       m18_1Dev.param.totalBytesPerChunk = 1024;
-       m18_1Dev.param.nChunksPerBlock =248;
-       m18_1Dev.param.nReservedBlocks = 2;
-       m18_1Dev.param.startBlock = 0; // Can use block 0
-       m18_1Dev.param.endBlock = 31; // Last block
-       m18_1Dev.param.useNANDECC = 0; // use YAFFS's ECC
-       m18_1Dev.param.nShortOpCaches = 10; // Use caches
-       m18_1Dev.driverContext = (void *) 1;    // Used to identify the device in fstat.
-       m18_1Dev.param.writeChunkToNAND = ynorif1_WriteChunkToNAND;
-       m18_1Dev.param.readChunkFromNAND = ynorif1_ReadChunkFromNAND;
-       m18_1Dev.param.eraseBlockInNAND = ynorif1_EraseBlockInNAND;
-       m18_1Dev.param.initialiseNAND = ynorif1_InitialiseNAND;
-       m18_1Dev.param.deinitialiseNAND = ynorif1_DeinitialiseNAND;
-
-//     m18_1Dev.param.disableSoftDelete = 1;
+       m18_1Dev.param.total_bytes_per_chunk = 1024;
+       m18_1Dev.param.chunks_per_block =248;
+       m18_1Dev.param.n_reserved_blocks = 2;
+       m18_1Dev.param.start_block = 0; // Can use block 0
+       m18_1Dev.param.end_block = 31; // Last block
+       m18_1Dev.param.use_nand_ecc = 0; // use YAFFS's ECC
+       m18_1Dev.param.n_caches = 10; // Use caches
+       m18_1Dev.driver_context = (void *) 1;   // Used to identify the device in fstat.
+       m18_1Dev.param.write_chunk_fn = ynorif1_WriteChunkToNAND;
+       m18_1Dev.param.read_chunk_fn = ynorif1_ReadChunkFromNAND;
+       m18_1Dev.param.erase_fn = ynorif1_EraseBlockInNAND;
+       m18_1Dev.param.initialise_flash_fn = ynorif1_InitialiseNAND;
+       m18_1Dev.param.deinitialise_flash_fn = ynorif1_Deinitialise_flash_fn;
+
+//     m18_1Dev.param.disable_soft_del = 1;
 
        yaffs_add_device(&m18_1Dev);
 
@@ -161,25 +107,25 @@ int yaffs_start_up(void)
        //
        memset(&flashDev,0,sizeof(flashDev));
        flashDev.param.name = "yaffs2";
-       flashDev.param.totalBytesPerChunk = 2048;
-       flashDev.param.nChunksPerBlock = 64;
-       flashDev.param.nReservedBlocks = 5;
-       flashDev.param.inbandTags = 0;
-       flashDev.param.startBlock = 0;
-       flashDev.param.endBlock = yflash2_GetNumberOfBlocks()-1;
-       flashDev.param.isYaffs2 = 1;
-       flashDev.param.useNANDECC=1;
-       flashDev.param.wideTnodesDisabled=0;
-       flashDev.param.refreshPeriod = 1000;
-       flashDev.param.nShortOpCaches = 10; // Use caches
-       flashDev.driverContext = (void *) 2;    // Used to identify the device in fstat.
-       flashDev.param.writeChunkWithTagsToNAND = yflash2_WriteChunkWithTagsToNAND;
-       flashDev.param.readChunkWithTagsFromNAND = yflash2_ReadChunkWithTagsFromNAND;
-       flashDev.param.eraseBlockInNAND = yflash2_EraseBlockInNAND;
-       flashDev.param.initialiseNAND = yflash2_InitialiseNAND;
-       flashDev.param.markNANDBlockBad = yflash2_MarkNANDBlockBad;
-       flashDev.param.queryNANDBlock = yflash2_QueryNANDBlock;
-       flashDev.param.enableXattr = 1;
+       flashDev.param.total_bytes_per_chunk = 2048;
+       flashDev.param.chunks_per_block = 64;
+       flashDev.param.n_reserved_blocks = 5;
+       flashDev.param.inband_tags = 0;
+       flashDev.param.start_block = 0;
+       flashDev.param.end_block = yflash2_GetNumberOfBlocks()-1;
+       flashDev.param.is_yaffs2 = 1;
+       flashDev.param.use_nand_ecc=1;
+       flashDev.param.wide_tnodes_disabled=0;
+       flashDev.param.refresh_period = 1000;
+       flashDev.param.n_caches = 10; // Use caches
+       flashDev.driver_context = (void *) 2;   // Used to identify the device in fstat.
+       flashDev.param.write_chunk_tags_fn = yflash2_WriteChunkWithTagsToNAND;
+       flashDev.param.read_chunk_tags_fn = yflash2_ReadChunkWithTagsFromNAND;
+       flashDev.param.erase_fn = yflash2_EraseBlockInNAND;
+       flashDev.param.initialise_flash_fn = yflash2_InitialiseNAND;
+       flashDev.param.bad_block_fn = yflash2_MarkNANDBlockBad;
+       flashDev.param.query_block_fn = yflash2_QueryNANDBlock;
+       flashDev.param.enable_xattr = 1;
 
        yaffs_add_device(&flashDev);