完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
看代号好象目标前是增加当前核的tick,但是是对imx6q这种四核的话,其他核的线程是不是就不能新tick了? This function will notify kernel there is one tick passed. Normally, this function is invoked by clock ISR. |
|
相关推荐
3个回答
|
|
rt_cpu_self()->tick ++;
是不是必须改成 for(int i =0 ;i } 然后线程全部替换为rt_cpu_index(i)->current_thread? |
|
|
|
|
|
|
|
OS滴答计数,整个系统只有一个的;如果多个都去计数就乱了。
#ifdef RT_USING_SMP static void rt_hw_timer2_isr(int vector, void *param) { rt_tick_increase(); /* clear interrupt */ timer_clear_pending(0); } void rt_hw_secondary_cpu_up(void) { extern void set_secondary_cpu_boot_address(void); set_secondary_cpu_boot_address(); __asm__ volatile ("dsb":::"memory"); rt_hw_ipi_send(0, 1 << 1); } void secondary_cpu_c_start(void) { rt_hw_vector_init(); rt_hw_spin_lock(&_cpus_lock); arm_gic_cpu_init(0, REALVIEW_GIC_CPU_BASE); arm_gic_set_cpu(0, IRQ_PBA8_TIMER0_1, 0x2); timer_init(0, 1000); rt_hw_interrupt_install(IRQ_PBA8_TIMER0_1, rt_hw_timer2_isr, RT_NULL, "tick"); rt_hw_interrupt_umask(IRQ_PBA8_TIMER0_1); rt_system_scheduler_start(); } void rt_hw_secondary_cpu_idle_exec(void) { asm volatile ("wfe":::"memory", "cc"); } #endif 如上是qemu_vexpress_a9中 secondary_cpu.c,在启动2核心时又重新定义了一个计算器,其ISR中就重新对OS_TICK进行更新 |
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
889 浏览 0 评论
【英飞凌PSoC 6 RTT开发板试用】串口测试标准输入输出重定向
908 浏览 0 评论
2911 浏览 0 评论
1456 浏览 0 评论
【英飞凌PSoC 6 RTT开发板试用】以搭积木方式实现简单的互联型家庭网关
1227 浏览 0 评论
31700 浏览 21 评论
【参与有奖】激扬代码,千元现金!RT-Thread主题征文大赛
55941 浏览 88 评论
15119 浏览 47 评论
【资料活动】从入门到提升,嵌入式linux常用电子书教程合集(共47本)
212320 浏览 63 评论
野火 ISO STM32资料合集(程序、原理图、项目初高级篇)
17334 浏览 44 评论
45059 浏览 27 评论
255248 浏览 71 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 粤ICP备14022951号 )
GMT+8, 2024-1-9 14:19 , Processed in 0.898323 second(s), Total 34, Slave 29 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 深圳华秋电子有限公司
电子发烧友 (电路图) 粤公网安备 44030402000349 号 电信与信息服务业务经营许可证:粤 B2-20160233 工商网监 湘ICP备2023018690号