页次: 1
各位大佬,求助D133在挂载 rodata 失败,怎么解决。我是用的是mmc,以下是启动信息:
01-01 08:00:00 I/SDMC: SDMC1 BW 1, sclk 49500 KHz, clk expt 400 KHz(act 399 KHz), div 2-62
[I] aic_sdmc_probe()683 SDMC1 driver loaded
01-01 08:00:00 I/sensor: rt_sensor[temp_tsen_cpu] init success
01-01 08:00:00 I/sensor: rt_sensor[temp_tsen_gpai] init success
01-01 08:00:00 I/WDT: ArtInChip WDT loaded
01-01 08:00:00 E/DFS: mount fs[elm] on /rodata failed.
01-01 08:00:00 E/DFS: mount fs[elm] on /sdcard failed.可以看到这个时候 sdcard 也挂载失败了。
然后在最后,启动lvgl 的时候 sdcard 竟然又挂载上了,测试过可以正常使用文件系统,而 rodata 还是不行。
01-01 08:00:00 I/LVGL: Success to create LVGL thread
D13x /> info: cmd ring buf size:1920
info: cmd ring buf size:1920
lvgl is occupying gt911 device
id = GT911 
range_x = 1024 
range_y = 600 
point_num = 5 
01-01 08:00:00 I/SDMC: SDMC1 BW 1, sclk 49500 KHz, clk expt 400 KHz(act 399 KHz), div 2-62
01-01 08:00:00 I/SDIO: SD card capacity 491520 KB.
01-01 08:00:00 I/SDMC: SDMC1 BW 1, sclk 49500 KHz, clk expt 50000 KHz(act 49500 KHz), div 1-0
01-01 08:00:00 I/DFS: mount fs[elm] device[sd0] to /sdcard ok.跑 debug 看,挂载 rodata 失败是因为 (\kernel\rt-thread\components\dfs\src\dfs_fs.c) 中:
int dfs_mount(const char   *device_name,
              const char   *path,
              const char   *filesystemtype,
              unsigned long rwflag,
              const void   *data)
{
    const struct dfs_filesystem_ops **ops;
    struct dfs_filesystem *iter;
    struct dfs_filesystem *fs = NULL;
    char *fullpath = NULL;
    rt_device_t dev_id;
    /* open specific device */
    if (device_name == NULL)
    {
        /* which is a non-device filesystem mount */
        dev_id = NULL;
    }
    else if ((dev_id = rt_device_find(device_name)) == NULL)
    {
        /* no this device */
        rt_set_errno(-ENODEV);
        return -1;
    }在 rt_device_find 的时候失败了,在 board.c 中,挂载 rodata 的地方为:
{"blk_rodata", "/rodata", "elm", 0, 0, 0},而正是因为前面没有找到 "blk_rodata" 相关的设备,就退出了挂载。而后面,经过我摸索,"blk_rodata" 在 env.txt 中有声明,
但是我使用的是 mmc,烧录程序的时候如果勾选上 env (配置按照文档正确操作)就会出现以下错误(D133串口输出):
CBW tag 0x1765
TRANS_LAYER_CMD_WRITE, data len 2048
[E] mmc_fwc_raw_write()413 not find env;env_r part info.
CPU Exception: NO.5
x1: 4020ae8c    x2: 4022bbc4    x3: 40229000    x4: 00000000
x5: ffffffff    x6: fffffffd    x7: ffffffff    x8: 00000000
x9: 00000004    x10: 00000039   x11: 00000000   x12: ffffffff
x13: ffffffff   x14: 000f40e2   x15: 00000000   x16: 0000000a
x17: 4022b961   x18: 40294750   x19: 00000800   x20: 40294708
x21: 40295208   x22: 40284620   x23: 4021cc4c   x24: 402247c4
x25: 4022475c   x26: 4022479c   x27: 00004001   x28: 0000000a
x29: 00000200   x30: 00000000   x31: 00000004
mcause : 30000005
mtval  : 0000009c
mepc   : 4020adce
mstatus: 00003800这就很头大,更不理解的是,在后面 sdcard 设备又挂载上了,目前我还在找它是从什么地方挂载的.......
感谢各位大佬能提供解决思路!
各位大佬,有D133EBS的img文件吗?我这边编译之后出现以下问题(AiBurn 日志):
[debug] WinEvent: Some devnode changed
[info ] Set upg work mode: 1
[debug] Blocksize 1 , chunk 1048576 * 0 , rest 2048
[debug] Offset: 0 Size: 2048
[debug]  Dev "1:1-4-2" Send the rest data 2048
[error] Dev "1:1-4-2" Failed to send data 2048
[error]  Dev "1:1-4-2" Failed to send 2048
[warn ] Try to resend firmware component image.info , try count: 1
[warn ] Try to recovery the connection
[error] Connection recovery failed!
串口输出:
Pre-Boot Program ... (24-05-30 17:09 569b02e)
USB/UART
cs=0, phase=3
cs=1, phase=2
Psram_init done.
goto run SPL
tinySPL [Built on Sep 19 2024 13:31:10]
[W] usbh_get_connect_id()107 usb 0 port change wait failed.
[E] main()172 Not find udisk.
Startup reason: Power-On-Reset
Firmware Component:
    name:      image.info
    partition: 
    attr:      required
    Media:     RAM(0)
qspi0 freq (input): 99000000Hz
qspi0 freq ( bus ): 49500000Hz
[E] sfud_probe()475 sfud_device_init failed: ret 4
Failed to probe spinor flash.
[E] image_info_proc()117 NOR prepare failed
刚入门,我们这边是自己画的板子,因此想试试是硬件问题还是软件问题。
希望有大佬能提供编译好的D133EBS镜像文件。提前感谢各位大佬!
页次: 1