CN108196849A - 一种低延迟指令调度器 - Google Patents
一种低延迟指令调度器 Download PDFInfo
- Publication number
- CN108196849A CN108196849A CN201810030690.3A CN201810030690A CN108196849A CN 108196849 A CN108196849 A CN 108196849A CN 201810030690 A CN201810030690 A CN 201810030690A CN 108196849 A CN108196849 A CN 108196849A
- Authority
- CN
- China
- Prior art keywords
- bus
- low latency
- instruction
- microprocessor
- scheduler
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
- 238000000034 method Methods 0.000 claims description 5
- 230000004048 modification Effects 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004044 response Effects 0.000 description 2
- 230000009286 beneficial effect Effects 0.000 description 1
- 230000001419 dependent effect Effects 0.000 description 1
- 230000008672 reprogramming Effects 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/40—Transformation of program code
- G06F8/41—Compilation
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/38—Concurrent instruction execution, e.g. pipeline or look ahead
- G06F9/3836—Instruction issuing, e.g. dynamic instruction scheduling or out of order instruction execution
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Software Systems (AREA)
- General Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Executing Machine-Instructions (AREA)
- Advance Control (AREA)
Abstract
本发明公开了一种低延迟指令调度器,包括微处理器和指令调度器,微处理器通过内部低延迟总线连接指令调度器,指令调度器分别连接多个硬件模块,且多个硬件模块分别连接局部内存总线,局部内存总线连接内部低延迟总线,本发明将指令调度器改接在局部内存总线或低延迟总线,如此可以大幅降低微处理器发命令的延迟时间,提升数十倍速度;将中央命令调度控制器改接于上述低延迟总线,省去每次系统经过外部总线发出命令与数据,等待子模块接收执行完毕后,送回执行结果的时间,可大大降低微处理器之等待下指令完成时间,大幅提升效能。
Description
技术领域
本发明涉及指令调度技术领域,具体为一种低延迟指令调度器。
背景技术
指令调度是编译器挖掘程序潜在的指令级并行的有效手段。它是在不改变程序语义,满足目标机器的相关性和资源依赖性的前提下,通过重新调整指令顺序来提高一个周期内目标机器能够执行的指令数目(IPC)。指令调度是现代高性能编译器的一项关键技术,它决定各操作的相对执行顺序,具体执行时间及使用哪些硬件资源等。从代码块划分角度来看,指令调度可以分为局部指令调度和全局指令调度,其中局部指令调度是指基本块内的指令调度,而全局调度是指基本块间的指令调度。
现有系统级芯片架构中的命令调度控制器常见的做法都连接在外部中央总线,传统命令调配控制器中微处理器执行步骤一,经过外部总线送出指令与写入数据,此动作完成约耗费15个周期时间,步骤二,等待指令调度器执行指令完成送回执行结果,约耗费约15个周期时间,如此两个动作及耗费微处理器共约30个周期时间。此作法对于微处理器来说等于闲置了30个指令周期去等待两个动作完成,相当浪费运算能力;而本发明微处理器同时写出指令与数据,不需等待响应。如此约耗1至5个周期时间,相较于外部总线节省了数倍到数十倍的时间,进而大幅提升微处理器的效能。
发明内容
本发明的目的在于提供一种低延迟指令调度器,以解决上述背景技术中提出的问题。
为实现上述目的,本发明提供如下技术方案:一种低延迟指令调度器,包括微处理器和指令调度器,所述微处理器通过内部低延迟总线连接指令调度器,所述指令调度器分别连接多个硬件模块,且多个硬件模块分别连接局部内存总线,所述局部内存总线连接内部低延迟总线。
优选的,使用方法包括以下步骤:
A、微处理器经由内部低延迟总线对此指令中央控制模块下予命令;
B、多个硬件模块根据cmdq cfg讯号得知目前有多少指令需要处理并透过外部总线进入到微处理器之低延迟总线抓取指令;
C、抓取完成后,再透过总线改写寄存器以通知微处理器指令已经被抓取,主要节省微处理器所发出之读写等待时间,进而提升微处理器对指令中央支配模块读写速度至数十倍。
优选的,多个硬件模块包括第一硬件模块、第二硬件模块、第三硬件模块、第N硬件模块,N为大于3的整数。
与现有技术相比,本发明的有益效果是:本发明将指令调度器改接在局部内存总线或低延迟总线,如此可以大幅降低微处理器发命令的延迟时间,提升数十倍速度;将中央命令调度控制器改接于上述低延迟总线,省去每次系统经过外部总线发出命令与数据,等待子模块接收执行完毕后,送回执行结果的时间,可大大降低微处理器之等待下指令完成时间,大幅提升效能。
附图说明
图1为本发明结构示意图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
请参阅图1,本发明提供一种技术方案:一种低延迟指令调度器,包括微处理器1和指令调度器2,所述微处理器1通过内部低延迟总线3连接指令调度器2,所述指令调度器2分别连接多个硬件模块,且多个硬件模块分别连接局部内存总线4,所述局部内存总线4连接内部低延迟总线3; 多个硬件模块包括第一硬件模块5、第二硬件模块6、第三硬件模块7、第N硬件模块,N为大于3的整数。
本发明的使用方法包括以下步骤:
A、微处理器经由内部低延迟总线对此指令中央控制模块下予命令;
B、多个硬件模块根据cmdq cfg讯号得知目前有多少指令需要处理并透过外部总线进入到微处理器之低延迟总线抓取指令;
C、抓取完成后,再透过总线改写寄存器以通知微处理器指令已经被抓取,主要节省微处理器所发出之读写等待时间,进而提升微处理器对指令中央支配模块读写速度至数十倍。
本发明将指令调度器连接于内部低延迟总线或是局部内存总线,处理动作如下:步骤一,微处理器同时写出指令与数据,不需等待响应。如此约耗1至5个周期时间,相较于外部总线节省了数倍到数十倍的时间,进而大幅提升微处理器的效能。
综上所述,本发明将指令调度器改接在局部内存总线或低延迟总线,如此可以大幅降低微处理器发命令的延迟时间,提升数十倍速度;将中央命令调度控制器改接于上述低延迟总线,省去每次系统经过外部总线发出命令与数据,等待子模块接收执行完毕后,送回执行结果的时间,可大大降低微处理器之等待下指令完成时间,大幅提升效能。
尽管已经示出和描述了本发明的实施例,对于本领域的普通技术人员而言,可以理解在不脱离本发明的原理和精神的情况下可以对这些实施例进行多种变化、修改、替换和变型,本发明的范围由所附权利要求及其等同物限定。
Claims (3)
1.一种低延迟指令调度器,包括微处理器(1)和指令调度器(2),其特征在于:所述微处理器(1)通过内部低延迟总线(3)连接指令调度器(2),所述指令调度器(2)分别连接多个硬件模块,且多个硬件模块分别连接局部内存总线(4),所述局部内存总线(4)连接内部低延迟总线(3)。
2.实现权利要求1所述的一种低延迟指令调度器的使用方法,其特征在于:使用方法包括以下步骤:
A、微处理器经由内部低延迟总线对此指令中央控制模块下予命令;
B、多个硬件模块根据cmdq cfg讯号得知目前有多少指令需要处理并透过外部总线进入到微处理器之低延迟总线抓取指令;
C、抓取完成后,再透过总线改写寄存器以通知微处理器指令已经被抓取,主要节省微处理器所发出之读写等待时间,进而提升微处理器对指令中央支配模块读写速度至数十倍。
3.根据权利要求1所述的一种低延迟指令调度器,其特征在于:多个硬件模块包括第一硬件模块(5)、第二硬件模块(6)、第三硬件模块(7)、第N硬件模块,N为大于3的整数。
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810030690.3A CN108196849A (zh) | 2018-01-12 | 2018-01-12 | 一种低延迟指令调度器 |
PCT/CN2018/099762 WO2019136983A1 (zh) | 2018-01-12 | 2018-08-09 | 一种低延迟指令调度器 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810030690.3A CN108196849A (zh) | 2018-01-12 | 2018-01-12 | 一种低延迟指令调度器 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN108196849A true CN108196849A (zh) | 2018-06-22 |
Family
ID=62588876
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201810030690.3A Pending CN108196849A (zh) | 2018-01-12 | 2018-01-12 | 一种低延迟指令调度器 |
Country Status (2)
Country | Link |
---|---|
CN (1) | CN108196849A (zh) |
WO (1) | WO2019136983A1 (zh) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2019136983A1 (zh) * | 2018-01-12 | 2019-07-18 | 江苏华存电子科技有限公司 | 一种低延迟指令调度器 |
WO2020015120A1 (zh) * | 2018-07-19 | 2020-01-23 | 江苏华存电子科技有限公司 | 低延迟指令调度器及过滤猜测访问方法 |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1334516A (zh) * | 2000-07-21 | 2002-02-06 | 三星电子株式会社 | 总线系统及其存取命令的执行调度方法 |
CN1373427A (zh) * | 2001-03-01 | 2002-10-09 | 深圳市中兴通讯股份有限公司 | 一种实现双系统槽的装置和方法 |
CN102289390A (zh) * | 2010-06-01 | 2011-12-21 | 微软公司 | 系统管理程序调度器 |
CN202996016U (zh) * | 2012-11-14 | 2013-06-12 | 西安众智惠泽光电科技有限公司 | 基于rfid电子标签的公交车运行监管系统 |
US20130305022A1 (en) * | 2012-05-14 | 2013-11-14 | International Business Machines Corporation | Speeding Up Younger Store Instruction Execution after a Sync Instruction |
CN104809075A (zh) * | 2015-04-20 | 2015-07-29 | 电子科技大学 | 一种存取实时并行处理的固态记录装置及方法 |
Family Cites Families (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7395415B2 (en) * | 2004-09-30 | 2008-07-01 | Intel Corporation | Method and apparatus to provide a source operand for an instruction in a processor |
CN101136754A (zh) * | 2006-09-27 | 2008-03-05 | 中兴通讯股份有限公司 | 一种以太网芯片的数据传输控制系统 |
CN101477502B (zh) * | 2008-01-04 | 2011-04-27 | 研祥智能科技股份有限公司 | 一种lpc/isa接口转换方法及装置 |
CN101377764B (zh) * | 2008-09-12 | 2011-10-12 | 北京中星微电子有限公司 | Gpio的配置系统及其数据通信方法 |
US7930519B2 (en) * | 2008-12-17 | 2011-04-19 | Advanced Micro Devices, Inc. | Processor with coprocessor interfacing functional unit for forwarding result from coprocessor to retirement unit |
CN108196849A (zh) * | 2018-01-12 | 2018-06-22 | 江苏华存电子科技有限公司 | 一种低延迟指令调度器 |
-
2018
- 2018-01-12 CN CN201810030690.3A patent/CN108196849A/zh active Pending
- 2018-08-09 WO PCT/CN2018/099762 patent/WO2019136983A1/zh active Application Filing
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1334516A (zh) * | 2000-07-21 | 2002-02-06 | 三星电子株式会社 | 总线系统及其存取命令的执行调度方法 |
CN1373427A (zh) * | 2001-03-01 | 2002-10-09 | 深圳市中兴通讯股份有限公司 | 一种实现双系统槽的装置和方法 |
CN102289390A (zh) * | 2010-06-01 | 2011-12-21 | 微软公司 | 系统管理程序调度器 |
US20130305022A1 (en) * | 2012-05-14 | 2013-11-14 | International Business Machines Corporation | Speeding Up Younger Store Instruction Execution after a Sync Instruction |
CN202996016U (zh) * | 2012-11-14 | 2013-06-12 | 西安众智惠泽光电科技有限公司 | 基于rfid电子标签的公交车运行监管系统 |
CN104809075A (zh) * | 2015-04-20 | 2015-07-29 | 电子科技大学 | 一种存取实时并行处理的固态记录装置及方法 |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2019136983A1 (zh) * | 2018-01-12 | 2019-07-18 | 江苏华存电子科技有限公司 | 一种低延迟指令调度器 |
WO2020015120A1 (zh) * | 2018-07-19 | 2020-01-23 | 江苏华存电子科技有限公司 | 低延迟指令调度器及过滤猜测访问方法 |
Also Published As
Publication number | Publication date |
---|---|
WO2019136983A1 (zh) | 2019-07-18 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
Ibanez et al. | The nanopu: A nanosecond network stack for datacenters | |
CN101221541B (zh) | 用于soc的可编程通信控制器 | |
KR101748506B1 (ko) | 실시간 명령어 추적 프로세서들, 방법들 및 시스템들 | |
US8006069B2 (en) | Inter-processor communication method | |
RU2651238C2 (ru) | Синхронизация обработки прерывания для уменьшения потребления энергии | |
CN103842933B (zh) | 多核平台中的受约束引导技术 | |
WO2017016480A1 (en) | System and method for multithreaded processing | |
CN110427337B (zh) | 基于现场可编程门阵列的处理器内核及其运行方法 | |
CN101986263B (zh) | 支持单指令流与多指令流动态切换执行的方法及微处理器 | |
CN108196849A (zh) | 一种低延迟指令调度器 | |
CN110018791A (zh) | 基于ssd soc的功耗管理控制方法和系统 | |
CN115033356B (zh) | 一种基于异构可重构的动态资源调度方法及系统 | |
CN105607874B (zh) | Sata协议加速模块、主机与硬盘通信方法及固态硬盘控制器 | |
US20060156062A1 (en) | Method for effecting the controlled shutdown of data processing units | |
CN105487989A (zh) | 一种降低响应延时提高系统效率的中断控制器及控制方法 | |
CN108196883A (zh) | 一种智能指令调度器 | |
CN111008042B (zh) | 基于异构流水线的高效通用处理器执行方法及系统 | |
US10503541B2 (en) | System and method for handling dependencies in dynamic thread spawning for a multi-threading processor | |
CN116757132A (zh) | 异构多核fpga电路架构、构建方法及数据传输方法 | |
CN108228242B (zh) | 一种可配置且具弹性的指令调度器 | |
CN102023846A (zh) | 基于单片多处理器系统的共享前端流水线结构 | |
US20220027278A1 (en) | Techniques for core-specific metrics collection | |
CN100533392C (zh) | 一种同步处理方法及其装置 | |
US9323575B1 (en) | Systems and methods for improving data restore overhead in multi-tasking environments | |
CN114218067A (zh) | 一种异构众核软件调试装置及调试方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20180622 |
|
RJ01 | Rejection of invention patent application after publication |