之前的回答不知道有没有帮助到你,你并没有采纳我的答案。
查看代码可知,idle 线程是使用 rt_thread_init 接口进行的初始化,在初始化完成之后,调用 startup 接口,线程的状态就会由 init 变为 ready 状态,这个和单核是一致的。
因为必须保证每个 CPU 在空闲的时候一定有任务在执行,所以每个核上的 idle 线程是不允许发生核迁移的。
tick 定时器使能只有会由一个定时器的中断,在这个中断里面中主要生效的函数是 rt_tick_increase, 这里面对 tick 值进行了加 1 的操作,在 RT-Thread SMP 默认系统时间使用的是 #define rt_tick rt_cpu_index(0)->tick ,所以这里使用的一定是 CORE0 的值,也就是说,无论你实现多少个定时器,虽然他们进了中断都会加1,但是系统只认 CORE0 的值。
所以在 SMP 里面每个核是否要实现一个 tick 定时器并不是必须的。
之前的回答不知道有没有帮助到你,你并没有采纳我的答案。
查看代码可知,idle 线程是使用 rt_thread_init 接口进行的初始化,在初始化完成之后,调用 startup 接口,线程的状态就会由 init 变为 ready 状态,这个和单核是一致的。
因为必须保证每个 CPU 在空闲的时候一定有任务在执行,所以每个核上的 idle 线程是不允许发生核迁移的。
tick 定时器使能只有会由一个定时器的中断,在这个中断里面中主要生效的函数是 rt_tick_increase, 这里面对 tick 值进行了加 1 的操作,在 RT-Thread SMP 默认系统时间使用的是 #define rt_tick rt_cpu_index(0)->tick ,所以这里使用的一定是 CORE0 的值,也就是说,无论你实现多少个定时器,虽然他们进了中断都会加1,但是系统只认 CORE0 的值。
所以在 SMP 里面每个核是否要实现一个 tick 定时器并不是必须的。
举报