shithub: lwext4

ref: 866f7592283a1352846baa6b1b231356c9402b38
dir: /demos/chibios/apps/redbull_v1_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>

static THD_WORKING_AREA(led_thread, 128);
static THD_FUNCTION(led_task, arg)
{
    (void)arg;

    printf("led_task\n");
    while (true) {
        palSetPad(GPIOF, 6);
        chThdSleepMilliseconds(500);
        palClearPad(GPIOF, 6);
        chThdSleepMilliseconds(500);
    }
}

#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();

    chThdCreateStatic(led_thread, sizeof(led_thread), NORMALPRIO + 1,
            led_task, NULL);

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