start.c代码分析

start.c代码分析

start.c包含了main函数运行前被调用的语句,如下图所示:
start.c代码分析start.c代码分析start.c代码分析11行定义了在上一篇文章里声明的stack0符号,它要求16bit对齐,
14行定义了共享变量,它是和timer驱动之间传递数据用的,在接下来的代码中可以看到,17行声明了timer中断处理函数,它会在接下来的timer初始化函数中被用到。第21行进入了start函数,第24~27行使CPU进入supervisor模式,第31行设置了汇编指令mret后,pc 指针跳转的函数(也就是主角main函数),第34行关闭分页功能,也就是使用物理地址,接下来的37和38行把所有的中断异常处理设定在supervisor模式下,接下来时候是clock的初始化,它的具体实现在文件的下半部分,然后是把cpu的id保存在tp寄存器中,以供后来使用,最后调用返回指令mret,然后进入main函数执行。

接下来看看clock时钟驱动的初始化函数,从59行开始,首先读出cpu id,然后设置中断时间间隔,这里设置的是0.1秒,接下来是利用刚才在文件开头声明的mscratch0变量,把刚才的cpu id和设置的中断间隔设置到mscratch寄存器中,以供clock驱动使用。接下来是设置中断处理函数,打开中断。

下一篇文章将进入主角部分main.c