CN1333344C - Method for reducing software load of system-on-chip (SoC) - Google Patents
Method for reducing software load of system-on-chip (SoC) Download PDFInfo
- Publication number
- CN1333344C CN1333344C CNB2005100288880A CN200510028888A CN1333344C CN 1333344 C CN1333344 C CN 1333344C CN B2005100288880 A CNB2005100288880 A CN B2005100288880A CN 200510028888 A CN200510028888 A CN 200510028888A CN 1333344 C CN1333344 C CN 1333344C
- Authority
- CN
- China
- Prior art keywords
- node
- linked list
- instruction
- state
- control
- 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.)
- Expired - Fee Related
Links
- 238000000034 method Methods 0.000 title claims abstract description 24
- 230000009471 action Effects 0.000 claims description 2
- 230000006870 function Effects 0.000 claims 5
- 238000011022 operating instruction Methods 0.000 abstract 1
- 238000010586 diagram Methods 0.000 description 2
- 230000007812 deficiency Effects 0.000 description 1
- 238000000151 deposition Methods 0.000 description 1
- 230000006872 improvement Effects 0.000 description 1
- 238000013332 literature search Methods 0.000 description 1
- 230000008520 organization Effects 0.000 description 1
- 230000008569 process Effects 0.000 description 1
- 230000004044 response Effects 0.000 description 1
- 230000007704 transition Effects 0.000 description 1
Images
Landscapes
- Stored Programmes (AREA)
Abstract
The present invention relates to a method for reducing software load of a system on a chip, which adopts linked list principle. Software organizes a plurality of operating instructions into a linked list in charge, and controls the start and the reset of hardware; each node of the linked list is automatically read in the hardware after the hardware is started to complete operations of pertinent data; an interruption signal is sent after the whole linked list of the instructions is enforced and completed; all parameters of instruction words are combined into one order node; each node is correspondent to one operation; the last NIP is a pointer to point a next node; the initial memory address of the next node is stored; the present invention contracts that if a cell value is 0, the cell value indicates the node is the last node of the linked list; one linked list of the instructions is composed of a plurality of nodes. The present invention packs a plurality of operations into the linked list of the instructions, and the operations of the linked list are enforced automatically by the hardware. The multiple operations are corresponding to only one interruption. The present invention fundamentally solves the problem that the load of the software is weighted because the number of the times of the interruption is too more. Meanwhile, the implementation method is simple, and the universality is high.
Description
Technical field
What the present invention relates to is a kind of method of field of computer technology, specifically a kind of method that alleviates the SOC (system on a chip) software load.
Background technology
A SOC (system on a chip) (SoC) is made up of system framework (comprising CPU, bus, storage unit etc.) and a plurality of I/O (I/O) functional module usually.Wherein, CPU is responsible for the control of each I/O functional module (for example audio-frequency module, video decode module, video processing module, graphics system module etc.), and this control is generally finished by the register that disposes each I/O functional module.These registers are usually located in the master control interface module (HostIF), with the system storage unified addressing, generally comprise control register, order register and parameter register.Control register is finished resetting of I/O functional module and start-up control.The operation that order register indication I/O functional module need be finished.Parameter register provides the work of I/O functional module required parameter.Real-time is that most of SoC are desired, for making CPU each I/O functional module is in time responded, and can take several different methods to control.
Find through literature search prior art, " computer organization and structure one performance design (the 5th edition) " (2001.8 Higher Education Publishing House) the 182nd page to the 209th page introduction that William Stallings is shown mainly contains three kinds of I/O control methods: programmed control I/O, drives interrupts I/O, direct memory visit (DMA).These three kinds of loads that method has alleviated CPU successively.Wherein back two kinds of methods all need to adopt interrupts controlling.But the ability of CPU is quite limited among the SoC usually, and excessively frequent interruption can make the expense of CPU strengthen, and efficient reduces, and has a strong impact on system performance, even system can't normally be moved.The 207th page to the 209 pages notions that propose I/O passage (I/O channel) of this book, the load that can further alleviate CPU on this technical know-how.But concrete I/O passage implementation method is also not mentioned in the book.
Summary of the invention
The present invention is directed to deficiency of the prior art, a kind of method that alleviates the SOC (system on a chip) software load is provided, make it that a plurality of operational orders are organized into instruction link-list, after whole instruction link-list is finished, send a look-at-me, like this, originally need repeatedly to interrupt only need interrupt for 1 time now.Can obviously reduce the CPU interruption times for the module that needs continuous several times to operate, thereby alleviate cpu load.
The present invention is achieved by the following technical solutions, the present invention adopts the chained list principle, a plurality of operational orders are organized into instruction link-list, software and hardware is carried out collaborative design, and software is responsible for instruction is organized into chained list, and the startup of control hardware and resetting, automatically read in each node of chained list after hardware-initiated, finish the operation of corresponding data, after whole instruction link-list is finished, send a look-at-me.
Described a plurality of operational orders are organized into instruction link-list, are meant: the parameter that instruction word and instruction are carried is formed an instruction node, the corresponding operation of node.Last tail node pointer NIP is meant the pointer to next node, deposits the initial memory address of next node, and if agreement this element value be 0 the expression this node be last node of chained list.A plurality of nodes are formed an instruction link-list.
The startup of described software control hardware and resetting, be meant: control register and head pointer register HIP are set in HostIF, and control register is used to control the startup of I/O functional module and reset, and HIP is used to deposit the pointer of the head node of chained list.
The hardware of described I/O functional module mainly is made up of three parts: get finger unit, performance element and control module, get the finger unit and be responsible for taking out instruction node from system storage, be stored in the register in the sheet.Performance element is carried out corresponding operation according to the content of taking out node.The action that refers to unit and performance element is got in control module control.
Get finger and execution sequence and carry out, promptly take out a node, carry out, get next node again, carry out again, be finished up to all nodes.One group of register need be set in sheet, be used to deposit the node content of taking-up.Control module is realized with state machine.This state machine has three states: idle, get and refer to and carry out.Be in idle condition after system powers on, after state machine is received enabling signal, forward to and get the finger-like attitude, otherwise keep idle condition; Getting under the finger-like attitude, getting and enter executing state after finger finishes, otherwise keep getting the finger-like attitude; Under executing state, present node instruction executes the value that NIP is checked in the back, if NIP non-0 then enter again and get the finger-like attitude, otherwise would enter idle condition; After reset signal under any state is effective, all enter idle condition.Getting under the finger-like attitude, getting the finger circuit working, from system storage, take out the content of a node, and assignment is being given relevant register.Under executing state, executive circuit carries out corresponding operating according to the value of the register that upgraded just now.Under idle condition, all circuit are in reset mode.
After described I/O functional module started, at first according to the value of HIP, the data of taking out first node from system storage were carried out first operation.After operation is finished, according to the value of NIP is taken out next node from system storage data, carrying out next one operation, is 0 up to NIP.Whole instruction link-list sends look-at-me after all executing.CPU carries out Interrupt Process after receiving look-at-me, send next operational order chained list.
Described each node that reads in chained list after hardware-initiated is automatically finished the operation of corresponding data, is specially: get the finger counter getting to refer to be provided with in the unit, get and refer to that the unit whenever reads into data and get and refer to that counter adds one automatically, and when executing state, counter O reset.So get the position of the corresponding current data of value in node that refers to counter, can guide data enter corresponding registers, and when the value of counter equals the length of node, show that present node gets finger and finish, can instruct the control state machine redirect.Performance element executes instruction under the control of control state machine, sends " being finished " signal to control state machine when being finished.Because therefore data and the shared chip external memory of instruction need a selector switch in the system, select corresponding signal to deliver to memory controller (MC) under the control of state machine.
The present invention has outstanding substantive distinguishing features and marked improvement, the present invention is packaged into instruction link-list with a plurality of operations, by all operations in the hardware automatic execution instruction chained list, corresponding a plurality of operations have only an interruption, greatly reduced interruption times, thereby alleviated the load of CPU, significant for the real-time that guarantees SoC.In addition, because a large amount of register is moved out of HostIF, organize in the mode of chained list node, and chained list is to be generated by software that be placed among the outer RAM of sheet, whole like this SoC chip area can reduce, the sheet intraconnections also can reduce.The present invention has fundamentally solved interruption times and has too much caused the problem that software load increases the weight of, and it is simple to have implementation method, the characteristics of highly versatile.
Description of drawings
Fig. 1 list structure figure of the present invention
Fig. 2 hardware block diagram of the present invention
Fig. 3 state of a control transition diagram of the present invention
Embodiment
The present invention is further illustrated below in conjunction with accompanying drawing:
The present invention is finished jointly by software and hardware.Software is responsible for instruction is organized into chained list, and the startup of control hardware and resetting.
As shown in Figure 1, instruction link-list is organized as follows: an instruction node is made up of instruction word, all parameters and NIP (being used to deposit the initial memory address of next node), their depositing continuously in internal memory, the address of presumptive instruction word is X, total N parameter, then their address is followed successively by X, X+1, X+2 ... X+N+1.Last NIP is meant the pointer to next node, and if agreement this element value be 0 the expression this node be last node of chained list.The corresponding operation of node, a plurality of nodes are formed an instruction link-list, and the NIP value of last node of chained list is made as 0.
Register HIP and control register are set in HostIF, deposit the pointer of the head node of chained list with HIP, i.e. the address of first node instruction word, control register is provided with start bit and resets, and is used to control the startup of I/O functional module and reset.The step that CPU carries out is as follows:
1) preparation instruction chained list is sent in the system storage;
2) set HIP;
3) under the ready situation of I/O functional module, control register is set, starts the I/O functional module.
Automatically read in each node of chained list after hardware-initiated, finish the operation of corresponding data, after whole instruction link-list is finished, send a look-at-me.
As shown in Figure 2, hardware components of the present invention is got and is referred to unit, performance element, control module, order register group and selector switch.Get the finger unit and be responsible for from system storage, taking out instruction node, be stored in the order register group in the sheet.Performance element is carried out corresponding operation according to the content of order register group.Thereby order register consists of the bridge of getting finger unit and performance element.All work under the control of control module in all unit.This control module is realized by control state machine.
As shown in Figure 3, control state machine has three states: idle, get and refer to and carry out.Be in idle condition after system powers on, after module is received enabling signal, forward to and get the finger-like attitude, otherwise keep idle condition; Getting under the finger-like attitude, getting and enter executing state after finger finishes, otherwise keep getting the finger-like attitude; Under executing state, present node instruction executes the value that NIP is checked in the back, if NIP non-0 then enter again and get the finger-like attitude, otherwise would enter idle condition; After reset signal under any state is effective, all enter idle condition.
Enter after module starts and get the finger-like attitude, get the finger unit and send read request to memory controller (MC), the address of request is HIP, reads the size that number is a chained list node.After the MC response request, send data to and get the finger unit, by the arrival of data useful signal designation data.Get the finger counter getting to refer to be provided with in the unit, get and refer to that the unit whenever reads into data (being that the data useful signal is for high) and get and refer to that counter adds one automatically.According to getting the value that refers to counter, deliver in the order register group in the relevant register reading into data.When getting the value that refers to counter when equaling chained list node big or small, show to get to refer to finish, enter executing state, get the finger counter O reset, performance element is carried out corresponding operating according to the value of order register group, sends the signal that is finished after operation is finished.Check the value of NIP in the order register group simultaneously, if non-0, show to also have instruction to carry out, the value of NIP is composed to getting the finger unit, as the address of getting finger next time, enter and get the finger-like attitude, get next instruction node,, show that whole instruction link-list is finished if NIP is 0, send look-at-me, enter idle condition.Because therefore data and the shared chip external memory of instruction need a selector switch in the system, selector switch is controlled by state machine, is getting under the finger-like attitude, send MC with getting the signal that refers to the unit, under executing state, send MC with the signal of performance element.
The present invention is packaged into instruction link-list with a plurality of operations, by all operations in the hardware automatic execution instruction chained list, corresponding a plurality of operations have only an interruption, have fundamentally solved interruption times and have too much caused the problem that software load increases the weight of, method realizes simple, highly versatile.
Claims (9)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CNB2005100288880A CN1333344C (en) | 2005-08-18 | 2005-08-18 | Method for reducing software load of system-on-chip (SoC) |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CNB2005100288880A CN1333344C (en) | 2005-08-18 | 2005-08-18 | Method for reducing software load of system-on-chip (SoC) |
Publications (2)
Publication Number | Publication Date |
---|---|
CN1731358A CN1731358A (en) | 2006-02-08 |
CN1333344C true CN1333344C (en) | 2007-08-22 |
Family
ID=35963719
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CNB2005100288880A Expired - Fee Related CN1333344C (en) | 2005-08-18 | 2005-08-18 | Method for reducing software load of system-on-chip (SoC) |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN1333344C (en) |
Families Citing this family (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102999434A (en) * | 2011-09-15 | 2013-03-27 | 阿里巴巴集团控股有限公司 | Memory management method and device |
CN104836710B (en) * | 2015-02-10 | 2018-06-05 | 数据通信科学技术研究所 | A kind of method and apparatus based on the communication of distributed system one master and multiple slaves |
CN114443525B (en) * | 2020-11-06 | 2023-08-15 | 辰芯科技有限公司 | Data processing system, method, electronic equipment and storage medium |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4768149A (en) * | 1985-08-29 | 1988-08-30 | International Business Machines Corporation | System for managing a plurality of shared interrupt handlers in a linked-list data structure |
CN1535427A (en) * | 2001-07-30 | 2004-10-06 | 皇家菲利浦电子有限公司 | Efficient interrupt system for system on chip design |
US20040199694A1 (en) * | 2002-12-19 | 2004-10-07 | Arm Limited | Interrupt controller and interrupt controlling method for prioritizing interrupt requests generated by a plurality of interrupt sources |
CN1547082A (en) * | 2003-12-12 | 2004-11-17 | 中兴通讯股份有限公司 | Programmable interrupt controller |
CN1567277A (en) * | 2003-07-09 | 2005-01-19 | 明基电通股份有限公司 | Control device and method for reducing the number of interrupts to a processor |
-
2005
- 2005-08-18 CN CNB2005100288880A patent/CN1333344C/en not_active Expired - Fee Related
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4768149A (en) * | 1985-08-29 | 1988-08-30 | International Business Machines Corporation | System for managing a plurality of shared interrupt handlers in a linked-list data structure |
CN1535427A (en) * | 2001-07-30 | 2004-10-06 | 皇家菲利浦电子有限公司 | Efficient interrupt system for system on chip design |
US20040199694A1 (en) * | 2002-12-19 | 2004-10-07 | Arm Limited | Interrupt controller and interrupt controlling method for prioritizing interrupt requests generated by a plurality of interrupt sources |
CN1567277A (en) * | 2003-07-09 | 2005-01-19 | 明基电通股份有限公司 | Control device and method for reducing the number of interrupts to a processor |
CN1547082A (en) * | 2003-12-12 | 2004-11-17 | 中兴通讯股份有限公司 | Programmable interrupt controller |
Non-Patent Citations (3)
Title |
---|
SoC 设计领域的核心技术——软/硬件协同设计 汤磊,杨延辉,魏少军,中国集成电路,第2005年03期 2005 * |
SoC 设计领域的核心技术——软/硬件协同设计 汤磊,杨延辉,魏少军,中国集成电路,第2005年03期 2005;嵌入式Linux 的中断处理技术研究 康望星,马光胜,黄烨明,芦东昕,信息技术,第2005年08期 2005 * |
嵌入式Linux 的中断处理技术研究 康望星,马光胜,黄烨明,芦东昕,信息技术,第2005年08期 2005 * |
Also Published As
Publication number | Publication date |
---|---|
CN1731358A (en) | 2006-02-08 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US6820187B2 (en) | Multiprocessor system and control method thereof | |
US20050022196A1 (en) | Controller for multiple instruction thread processors | |
CN100527111C (en) | On-chip DMA structure and its implement method | |
US20090100200A1 (en) | Channel-less multithreaded DMA controller | |
JPH05204674A (en) | Multitasking data processing system | |
CN102193885A (en) | Virtual channel support in a nonvolatile memory controller | |
EP3077911B1 (en) | Methods and systems for autonomous memory | |
JP5309703B2 (en) | Shared memory control circuit, control method, and control program | |
US20030177288A1 (en) | Multiprocessor system | |
US5504869A (en) | High speed processing system capable of executing strings of instructions in order without waiting completion of previous memory access instruction | |
CN102446087B (en) | Instruction prefetching method and device | |
CN107402952A (en) | Big data processing accelerator and big data processing system | |
CN1333344C (en) | Method for reducing software load of system-on-chip (SoC) | |
CN109656868B (en) | Memory data transfer method between CPU and GPU | |
CN101313290A (en) | Performing an n-bit write access to an mxn-bit-only peripheral | |
CN101256541B (en) | Transmission system and method for directly accessing controller data | |
CN100432968C (en) | Direct access device of storage and data transmission method thereof | |
CN112732416A (en) | Parallel data processing method and parallel processor for effectively eliminating data access delay | |
JP2008090455A (en) | Multiprocessor signal processor | |
US6678749B2 (en) | System and method for efficiently performing data transfer operations | |
CN115525582A (en) | Method and system for task management and data scheduling of page-based inline computing engine | |
CN107168708A (en) | A kind of reconfigurable system Configuration Control Unit and its Flow-shop method | |
JPS592058B2 (en) | Storage device | |
US20050272197A1 (en) | Semiconductor device | |
JP2003203486A (en) | Semiconductor memory device and control method thereof |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
C14 | Grant of patent or utility model | ||
GR01 | Patent grant | ||
C17 | Cessation of patent right | ||
CF01 | Termination of patent right due to non-payment of annual fee |
Granted publication date: 20070822 Termination date: 20110818 |