ESP32 ボードと SPI バス経由で接続された Winbond W25N01 (1Gbit) NAND フラッシュ チップがあります。Mongoose OS とその Winbond VFS ドライバーを使用しています。私はLittleFSを使用しています。
ほとんどの場合は機能しますが、約 20 個のファイルを開いた後、「スーパーブロックが書き込み不能になりました」というエラーが表示されます。最小限のテストを行うためにいくつかの Arduino コードを作成しました。現在はブレッドボード上にありますが、ハードウェアは優れていると思います。
私の構成とコードが正しいかどうか疑問に思っており、コメントをいただければ幸いです。
#include "mgos.h"
#include "mgos_system.h"
#include "mgos_vfs_dev_w25xxx.h"
#include <stdio.h>
#define W25XXX_DEBUG 1
#define LED_PIN 13
static void timer_cb(void *arg)
{
#if 1
static uint16_t ctr = 0;
FILE *fp;
char c[] = "this is a test";
char buffer[100];
char writeBuf[100];
char fileName[50];
sprintf(fileName, "/data/file-%d.txt", ctr);
LOG(LL_ERROR, ("***** File Name: %s\r\n", fileName));
/* Open file for both reading and writing */
fp = fopen(fileName, "w+");
if(fp == NULL)
{
LOG(LL_ERROR, ("fopen() failed"));
return;
}
else
{
LOG(LL_ERROR, ("fopen() SUCCESS!!"));
}
/* Write data to the file */
sprintf(writeBuf, "Here is some data for the file - %d", ctr);
fwrite(writeBuf, strlen(writeBuf) + 1, 1, fp);
/* Seek to the beginning of the file */
fseek(fp, 0, SEEK_SET);
/* Read and display data */
fread(buffer, strlen(writeBuf)+1, 1, fp);
LOG(LL_ERROR, ("Read: %s", buffer));
fclose(fp);
ctr++;
#endif
#ifdef LED_PIN
mgos_gpio_toggle(LED_PIN);
#endif
(void) arg;
}
enum mgos_app_init_result mgos_app_init(void)
{
mgos_wdt_disable();
mgos_gpio_set_mode(LED_PIN, MGOS_GPIO_MODE_OUTPUT);
mgos_set_timer(2000, MGOS_TIMER_REPEAT, timer_cb, NULL);
return MGOS_APP_INIT_SUCCESS;
}
mos.yml
author: mongoose-os
description: A Mongoose OS app skeleton
version: 1.0
libs_version: ${mos.version}
modules_version: ${mos.version}
mongoose_os_version: ${mos.version}
# From the W25Nxxx driver code:
#define W25XXX_PAGE_SIZE 2048U
#define W25XXX_BLOCK_SIZE (64 * W25XXX_PAGE_SIZE)
#define W25XXX_DIE_SIZE (1024 * W25XXX_BLOCK_SIZE)
# Optional. List of tags for online search.
tags:
- c
# List of files / directories with C sources. No slashes at the end of dir names.
sources:
- src
# List of dirs. Files from these dirs will be copied to the device filesystem
filesystem:
- fs
config_schema:
- ["spi.enable", true]
# Other SPI interface options go here.
- ["spi.miso_gpio", 19]
- ["spi.mosi_gpio", 18]
- ["spi.sclk_gpio", 5]
- ["spi.cs0_gpio", 21]
- ["devtab.dev0.name", "spif0"]
- ["devtab.dev0.type", "w25xxx"]
- ["devtab.dev0.opts", '{"cs": 0, "freq": 10000000, "ecc_chk": 0}']
# json_scanf(opts, strlen(opts),
# "{cs: %d, freq: %d, mode: %d, "
# "bb_reserve: %u, ecc_chk: %B, spi: %T}",
# &cs_num, &spi_freq, &spi_mode, &bb_reserve, &ecc_chk,
# &spi_cfg_json);
- ["fstab.fs0.dev", "spif0"]
- ["fstab.fs0.type", "LFS"]
- ["fstab.fs0.opts", '{"bs": 131072}'] # bs 1024*64 # Fails without this line
- ["fstab.fs0.path", "/data"]
- ["fstab.fs0.create", true]
# // block device configuration
# .read_size = 16,
# .prog_size = 16,
# .block_size = 2048*64,
# .block_count = 1024,
# .lookahead = 2048,
- ["debug.level", 3]
libs:
- origin: https://github.com/mongoose-os-libs/vfs-dev-w25xxx
- origin: https://github.com/mongoose-os-libs/fstab
# Used by the mos tool to catch mos binaries incompatible with this file format
manifest_version: 2017-09-29
エラー:
[Mar 17 14:44:13.752] main.c:57 ***** File Name: /data/file-20.txt
[Mar 17 14:44:13.752]
[Mar 17 14:44:13.758] mgos_vfs.c:283 /data/file-20.txt -> /data/file-20.txt pl 5 -> 2 0x3ffb7e4c (refs 1)
[Mar 17 14:44:14.055] /data/fwbuild-volumes/latest/apps/winbond-w25n-test/esp32/build_contexts/build_ctx_434460174/deps/vfs-fs-lfs/littlefs/lfs.c:1691:warn: Superblock 0x1 has become unwritable
[Mar 17 14:44:14.074] mgos_vfs.c:377 open /data/file-20.txt 0x602 0x1b6 => 0x3ffb7e4c file-20.txt -6 => -6 (refs 0)
[Mar 17 14:44:14.076] main.c:66 fopen() failed