Ошибка аппаратного сбоя u-boot после инициализации оперативной памяти - PullRequest
0 голосов
/ 03 августа 2020

Я портировал U-boot на мою плату Waveshare coreH7 stm32h743. Я использовал файлы stm32h743-disco и деревья устройств в качестве шаблона для переноса. Моя встроенная SDRAM - IS42S16400J, то есть 8 МБ. Я вычислил параметры своего SDRAM и поместил их в файл дерева устройств платы, как показано ниже:

/*
             * Memory configuration from sdram datasheet IS42S32800G-6BLI
             * firsct bank is bank@0
             * second bank is bank@1
             */
            bank2: bank@1 {
                st,sdram-control = /bits/ 8 <NO_COL_8
                                 NO_ROW_12
                                 MWIDTH_16
                                 BANKS_4
                                 CAS_3
                                 SDCLK_2
                                 RD_BURST_EN
                                 RD_PIPE_DL_0>;
                st,sdram-timing = /bits/ 8 <TMRD_1
                                TXSR_1
                                TRAS_1
                                TRC_6
                                TRP_2
                                TWR_1
                                TRCD_1>;
                st,sdram-refcount = <300>;
            };

также, я настроил значения r cc для подачи драма на 100 МГц .

но когда uboot начинает инициализацию, он переходит в режим аппаратного аварийного прерывания.

это журнал:

lib/fdtdec.c:fdtdec_setup_mem_size_base_fdt() fdtdec_setup_mem_size_base_fdt: Initial DRAM size 2000000
include/initcall.h:initcall_run_list() initcall: 08008a89
common/board_f.c:setup_dest_addr() Monitor len: 00039F80
common/board_f.c:setup_dest_addr() Ram size: 02000000
common/board_f.c:setup_dest_addr() Ram top: D2000000
include/initcall.h:initcall_run_list() initcall: 08008665
include/initcall.h:initcall_run_list() initcall: 0800117d
arch/arm/lib/cache.c:arm_reserve_mmu() TLB table from d1ff0000 to d1ff4000
include/initcall.h:initcall_run_list() initcall: 080088c3
include/initcall.h:initcall_run_list() initcall: 080088c7
include/initcall.h:initcall_run_list() initcall: 080086b1
common/board_f.c:reserve_uboot() Reserving 231k for U-Boot at: d1fb6000
include/initcall.h:initcall_run_list() initcall: 080088ed
common/board_f.c:reserve_malloc() Reserving 1032k for malloc() at: d1eb4000
include/initcall.h:initcall_run_list() initcall: 08008821
Hard fault
pc : 0800087e    lr : 00000000    xPSR : 21000000
r12 : d1eb3ff0   r3 : 00000000    r2 : 00000010
r1 : 00000000    r0 : d1eb3fb0
Resetting CPU ...

в чем проблема? ОЗУ инициализировано неудачно? Зачем? может неправильные параметры? как я могу узнать, что оперативная память успешно инициализирована? это нормальный информационный журнал u-boot:

U-Boot 2020.07-00610-g610e1487c8-dirty (Aug 04 2020 - 00:34:13 +0430)

Model: Waveshare STM32H743i-Coreh7 board
DRAM:  Hard fault
pc : 0800087e    lr : 00000000    xPSR : 21000000
r12 : d1eb3ff0   r3 : 00000000    r2 : 00000010
r1 : 00000000    r0 : d1eb3fb0
Resetting CPU ...

1 Ответ

0 голосов
/ 04 августа 2020

ваш размер барана неправильный. как вы упомянули, фактический размер оперативной памяти составляет 8 МБ, что составляет 0x7A1200 в шестнадцатеричном формате. но в журнале U-загрузки стоит «Начальный размер DRAM 2000000». вы должны изменить его в дереве устройств на вашей плате.

memory {
      device_type = "memory";
      reg = <0xd0000000 0x7A1200>;
};
...