标题 | 阅读 | 评论 | 转发 | 发布日期 | |
---|---|---|---|---|---|
美国大兵作战条例的另类思考 【转】 | 898 | 0 | 0 | 2008-08-04 | |
PCM,RAW,AC-3是什么及区别 | 4302 | 0 | 0 | 2008-08-01 | |
PCM,RAW,AC-3是什么及区别 | 6599 | 2 | 0 | 2008-08-01 | |
夕阳是白天的引号 | 1333 | 0 | 0 | 2008-07-31 | |
夕阳是白天的引号 | 775 | 0 | 0 | 2008-07-31 | |
内存重要参数详解 RAS CAS | 2495 | 0 | 0 | 2008-07-25 | |
内存重要参数详解 RAS CAS | 2165 | 0 | 0 | 2008-07-25 | |
SSA(serial storage architecture,串行存储体系结构) | 1434 | 0 | 0 | 2008-07-25 | |
SSA(serial storage architecture,串行存储体系结构) | 1386 | 0 | 0 | 2008-07-25 | |
【转】为什么跨入五百强的是联想而不是海尔? | 914 | 0 | 0 | 2008-07-24 | |
【转】为什么跨入五百强的是联想而不是海尔? | 871 | 0 | 0 | 2008-07-24 | |
CVBS | 997 | 0 | 0 | 2008-07-22 | |
CVBS | 914 | 0 | 0 | 2008-07-22 | |
HDMI中的CEC功能简介 | 4125 | 0 | 0 | 2008-07-22 | |
HDMI中的CEC功能简介 | 3412 | 0 | 0 | 2008-07-22 | |
SPI概述 | 1081 | 0 | 0 | 2008-07-22 | |
SPI概述 | 1872 | 0 | 0 | 2008-07-22 | |
什么是流明,色温,光单位知识一次告诉你 | 4419 | 0 | 0 | 2008-07-17 | |
什么是流明,色温,光单位知识一次告诉你 | 2181 | 0 | 0 | 2008-07-17 | |
谐 波 简 介 | 1182 | 0 | 0 | 2008-06-27 |
config20102010-01-15 01:30
若看到,一定帮我,谢谢! FPGA有2个PIN与2440中断相连。1s都可以产生1333次中断(750us)。 中断服务子程序:产生中断后将fpga寄存器的数据读出放入内存(链表的一个元素),并由2440写FPGA寄存器清除中断,通知驱动中的读函数数据已处理完毕(这一块是用等待队列,来唤醒驱动中的读函数)。从示波器上看,完成这些用了50us. 我想让每次中断产生的数据在下次中断来前执行完毕,也就是说还有700us的时间处理。但是现在两个中断同时出现不能完成,一个中断可以完成。若将中断周期换为1ms,刚两个可以同时完成。(完成思路:读取链到的一个元素(128位)到用户层,在链表中删除这个元素,再由socket送入PC)。任意时刻链表的长度为1或者0。 出现问题的现象:链表的长度瞬时变的很长,上万。我猜就是下次中断来之前数据没读走,就造成了恶性循环,再也读不完。或者两个中断突然就剩下一个,还有个没有了(1,我估计是执行的过程中,没有清楚中断就退出,恢复不了了,可能是没有保护好,不知???) 2,从时间是看,剩下的700us怎么可能处理不完这件事情呢? 3,同时处理两个难道cpu到极限的吗? 4,cpu中断返回后,是不是没有立即去等到队列等待处去执行,过了会才过去?有没有对策。 5,我估计cpu每次从中断返回到驱动中的读函数数据这个切换过程可能耗时很多(猜),所以我尝试的方法:10次中断的数据存在一起后,再唤醒驱动中的读函数的等待队列去读。结果是一样的,还是来不及?很想不通。 6, 有没有延时中断子函数的方法?local_irq_save()?
config20102010-01-15 01:30
若看到,一定帮我,谢谢! FPGA有2个PIN与2440中断相连。1s都可以产生1333次中断(750us)。 中断服务子程序:产生中断后将fpga寄存器的数据读出放入内存(链表的一个元素),并由2440写FPGA寄存器清除中断,通知驱动中的读函数数据已处理完毕(这一块是用等待队列,来唤醒驱动中的读函数)。从示波器上看,完成这些用了50us. 我想让每次中断产生的数据在下次中断来前执行完毕,也就是说还有700us的时间处理。但是现在两个中断同时出现不能完成,一个中断可以完成。若将中断周期换为1ms,刚两个可以同时完成。(完成思路:读取链到的一个元素(128位)到用户层,在链表中删除这个元素,再由socket送入PC)。任意时刻链表的长度为1或者0。 出现问题的现象:链表的长度瞬时变的很长,上万。我猜就是下次中断来之前数据没读走,就造成了恶性循环,再也读不完。或者两个中断突然就剩下一个,还有个没有了(1,我估计是执行的过程中,没有清楚中断就退出,恢复不了了,可能是没有保护好,不知???) 2,从时间是看,剩下的700us怎么可能处理不完这件事情呢? 3,同时处理两个难道cpu到极限的吗? 4,cpu中断返回后,是不是没有立即去等到队列等待处去执行,过了会才过去?有没有对策。 5,我估计cpu每次从中断返回到驱动中的读函数数据这个切换过程可能耗时很多(猜),所以我尝试的方法:10次中断的数据存在一起后,再唤醒驱动中的读函数的等待队列去读。结果是一样的,还是来不及?很想不通。 6, 有没有延时中断子函数的方法?local_irq_save()?