uboot代码1:uboot启动大体流程, stage1 + stage2

本文详细介绍了U-Boot启动过程的关键步骤,包括初始化CPU到svc32模式、禁用看门狗、屏蔽所有IRQ中断等操作。此外还介绍了如何设置堆栈、初始化时钟,并将U-Boot代码从ROM复制到RAM中运行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

start.S

 

stage 1:

  reset:

      set the cpu to svc32 mode

      disable the watchdog

      mask all IRQs(INTMSK, INTSUBMSK)

      

      cpu_init_crit(mmu, bus width status controller)

      set up the stack

      clock_init

      

      relocate u-boot ro RAM:

        copy code to RAM

        clear bbs

        setLoadFlag

 

stage 2:

      start_armboot()

      {

        gd = (gd_t*)(_armboot_start - CFG_MALLOC_LEN - sizeof(gd_t));

        memset gd;

        init_sequence();

        

        for(;;)

        {

          main_loop();

        }

      }

转载于:https://www.cnblogs.com/mylinux/p/5052995.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值