ref: bde1eace786b1ddfcd275d71ada8500a65c02e46
dir: /demos/chibios/apps/redbull_v1_sd/main.c/
#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); } }