shithub: lwext4

ref: c1adeee6bee2febf7a4da6fb76d7f0ce06c57ff2
dir: /demos/chibios/apps/olimex_stm32_lcd_sd/main.c/

View raw version


#include "ch.h"
#include "hal.h"
#include "chprintf.h"
#include "sdc.h"

#include <sdc_lwext4.h>
#include <test_lwext4.h>
#include <timings.h>

#include <stdio.h>
#include <inttypes.h>
#include <string.h>



#define TEST_DELAY_MS    1000

#define DIR_CNT     1000
#define FILE_CNT    1000
#define FILE_SIZE   8192

static void lwext4_tests(void)
{
    printf("lwext4_tests:\n");

    struct ext4_blockdev *bdev = sdc_bdev_get();
    struct ext4_bcache *bcache = sdc_cache_get();

    tim_wait_ms(TEST_DELAY_MS);
    if(!test_lwext4_mount(bdev, bcache))
        return;

    tim_wait_ms(TEST_DELAY_MS);
    test_lwext4_cleanup();
    tim_wait_ms(TEST_DELAY_MS);

    tim_wait_ms(TEST_DELAY_MS);
    if(!test_lwext4_dir_test(DIR_CNT))
        return;

    tim_wait_ms(TEST_DELAY_MS);
    if(!test_lwext4_file_test(FILE_SIZE, FILE_CNT))
        return;

    //test_lwext4_mp_stats();
    //test_lwext4_block_stats();
    //test_lwext4_cleanup();

    if(!test_lwext4_umount())
        return;

    printf("test finished\n\n");
}


int main(void)
{
    halInit();
    chSysInit();
    sdStart(&STDOUT_SD, NULL);

    printf("\n\n\n\n\nboard: %s\n", BOARD_NAME);
    lwext4_tests();

    while (TRUE) {
        chThdSleepMilliseconds(500);
    }
}